程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> .NET網頁編程 >> C# >> C#入門知識 >> 使用C#開發紐曼USB來電小秘書客戶端小結,

使用C#開發紐曼USB來電小秘書客戶端小結,

編輯:C#入門知識

使用C#開發紐曼USB來電小秘書客戶端小結,


在前面用C#開發完CRM的來電彈屏之後,有些客戶有了新的要求,他們希望不但能夠實現來電彈屏,更希望能夠將呼入呼出的電話錄音並上傳到CRM服務器上,方便日後跟蹤記錄。於是便有了來電小秘書客戶端的開發。 
  來電小秘書客戶端的開發是基於紐曼USB來電通客戶端的基礎上進行開發的,由於紐曼USB來電通的硬件沒有錄音功能,於是硬件上使用了紐曼的另一個硬件產品來電小秘書,雖然是同一個廠家的產品,可是它們的API卻是完全不兼容,更煩的是,來電小秘書API沒有來電的回調接口,無法通過回調觸發程序,也沒有C#的Demo,很多功能只能通過一個不是那麼詳細的文檔和一個Delphi的Demo摸索著做了,經歷了一些挫折和困惑,終於完成了這個客戶端程序。 
  首先,開發要做的就是與硬件的API進行溝通,依然通過C#的P/Invoke來完成,以下是來電小秘書的P/Invoke代碼。 
 

C#代碼  收藏代碼
  1. using System;  
  2. using System.Collections.Generic;  
  3. using System.Text;  
  4. using System.Runtime.InteropServices;  
  5.   
  6. namespace WindowsApplication1  
  7. {  
  8.     class LDT1  
  9.     {  
  10.         [DllImport("usbms.dll", EntryPoint = "LoadDRV")]  
  11.         public static extern int LoadDRV();  
  12.   
  13.         [DllImport("usbms.dll", EntryPoint = "EnableCard")]  
  14.         public static extern int EnableCard();  
  15.   
  16.         [DllImport("usbms.dll", EntryPoint = "StopSigCheck")]  
  17.         public static extern int StopSigCheck(int Handle);  
  18.   
  19.         [DllImport("usbms.dll", EntryPoint = "ReSetUsb")]  
  20.         public static extern int ReSetUsb(int Handle);  
  21.   
  22.         [DllImport("usbms.dll", EntryPoint = "HangUp")]  
  23.         public static extern int HangUp(int Handle);  
  24.   
  25.         [DllImport("usbms.dll", EntryPoint = "InitDtmfBuf")]  
  26.         public static extern int InitDtmfBuf(int Handle);  
  27.   
  28.         [DllImport("usbms.dll", EntryPoint = "SetDialPara")]  
  29.         public static extern int SetDialPara(UInt16 RingBack1, UInt16 RingBack0, UInt16 BusyLen, UInt16 RingTimes, UInt16 SendNoSignalLen);  
  30.   
  31.   
  32.         [DllImport("usbms.dll", EntryPoint = "DisableCard")]  
  33.         public static extern int DisableCard();  
  34.   
  35.         [DllImport("usbms.dll", EntryPoint = "FreeDRV")]  
  36.         public static extern int FreeDRV();  
  37.   
  38.         [DllImport("usbms.dll", EntryPoint = "GetDtmfCode")]  
  39.         public static extern int GetDtmfCode(UInt16 Line);  
  40.   
  41.         [DllImport("usbms.dll", EntryPoint = "IsRing")]  
  42.         public static extern bool IsRing(UInt16 Line);  
  43.   
  44.         [DllImport("usbms.dll", EntryPoint = "GetCallerIDStr")]  
  45.         public static extern UInt16 GetCallerIDStr(UInt16 Line, StringBuilder IDStr);  
  46.   
  47.   
  48.         [DllImport("usbms.dll", EntryPoint = "IsOffHook")]  
  49.         public static extern bool IsOffHook(UInt16 Line);  
  50.   
  51.   
  52.         [DllImport("usbms.dll", EntryPoint = "StartRecordFile")]  
  53.         public static extern bool StartRecordFile(UInt16 Line, string FileName, UInt32 dwRecordLen);  
  54.   
  55.         [DllImport("usbms.dll", EntryPoint = "CheckRecordEnd")]  
  56.         public static extern bool CheckRecordEnd(UInt16 Line);  
  57.   
  58.   
  59.         [DllImport("usbms.dll", EntryPoint = "StopRecordFile")]  
  60.         public static extern bool StopRecordFile(UInt16 Line);  
  61.   
  62.         [DllImport("usbms.dll", EntryPoint = "PCMtoWave")]  
  63.         public static extern int PCMtoWave(string SourceFileName, string TargetFileName);  
  64.   
  65.         [DllImport("usbms.dll", EntryPoint = "ReadCheckResult")]  
  66.         public static extern int ReadCheckResult(int line, int mode);  
  67.   
  68.         [DllImport("usbms.dll", EntryPoint = "StartSigCheck")]  
  69.         public static extern void StartSigCheck(int line);  
  70.   
  71.         [DllImport("usbms.dll", EntryPoint = "ReadUsbState")]  
  72.         public static extern bool ReadUsbState(int line);  
  73.   
  74.         [DllImport("usbms.dll", EntryPoint = "GetRingNum")]  
  75.         public static extern int GetRingNum(int line);  
  76.   
  77.         [DllImport("usbms.dll", EntryPoint = "InitRingNum")]  
  78.         public static extern void InitRingNum(int line);  
  79.   
  80.         [DllImport("usbms.dll", EntryPoint = "ReadSerialNo")]  
  81.         public static extern int ReadSerialNo(int line,StringBuilder serialNo);  
  82.   
  83.     }  
  84. }  
  85.   
  86.     


  然後就是關於設備狀態檢測了,由於沒有API直接支持來電回調,所以只能自己手動的檢測設備狀態來判斷,要實現這一部分一般有兩種方式,使用Timer或者使用Thread,Delphi的Demo中使用了Timer,可是Timer實現的弊端需要使用異步的思考方式,不符合我的思維模式,靈活度也不夠,而且C#創建線程太方便了,而線程是通過同步方式思考的,所以使用了Thread模式。 
  然後在特定的時刻,記錄電話號碼、彈屏(如果是來電)、電話結束後錄音和上傳文件和信息到CRM服務器,其中來電號碼可以很容易的獲取,可是播出的號碼獲取就比較的麻煩了,C#中可以使用如下代碼: 
 

C#代碼  收藏代碼
  1. while (LDT1.IsOffHook((ushort)this.line))  
  2. {  
  3.       int temp = LDT1.GetDtmfCode((ushort)this.line);  
  4.        if (temp > 0)  
  5.        {  
  6.              phonenum = phonenum + this.convertInt(temp);  
  7.         }  
  8.        Thread.Sleep(300);  
  9.               
  10.   }  
  11.   
  12. private string convertInt(int code)  
  13.     {  
  14.         string ret="";  
  15.         switch (code)  
  16.         {  
  17.             case 10:  
  18.                 ret = "0";  
  19.                 break;  
  20.             case 11:  
  21.                 ret = "*";  
  22.                 break;  
  23.             case 12:  
  24.                 ret = "#";  
  25.                 break;  
  26.             case 13:  
  27.                 ret = "A";  
  28.                 break;  
  29.             case 14:  
  30.                 ret = "B";  
  31.                 break;  
  32.             case 15:  
  33.                 ret = "C";  
  34.                 break;  
  35.             case 16:  
  36.                 ret = "D";  
  37.                 break;  
  38.             default:  
  39.                 ret = code.ToString();  
  40.                 break;  
  41.         }  
  42.         return ret;  
  43.     }  


  下面說一下C#中的大文件上傳吧,網上有很多例子了,我參考了如下blog的代碼進行開發http://www.cnblogs.com/bccu/archive/2009/01/05/1363771.html,可是無法上傳成功,於是我讀了一下代碼,發現他將信息中的\r\n用空字符代替了,導致服務器無法識別,於是我更改了他的代碼,解決了問題,代碼如下: 

C#代碼  收藏代碼
  1. public static string UploadFileEx(string uploadfile, string url,  
  2.      string fileFormName, string contenttype, NameValueCollection querystring,  
  3.      CookieContainer cookies)  
  4.   {  
  5.       if ((fileFormName == null) ||  
  6.           (fileFormName.Length == 0))  
  7.       {  
  8.           fileFormName = "file";  
  9.       }  
  10.   
  11.       if ((contenttype == null) ||  
  12.           (contenttype.Length == 0))  
  13.       {  
  14.           contenttype = "application/octet-stream";  
  15.       }  
  16.   
  17.   
  18.       string postdata;  
  19.       postdata = "?";  
  20.       if (querystring != null)  
  21.       {  
  22.           foreach (string key in querystring.Keys)  
  23.           {  
  24.               postdata += key + "=" + querystring.Get(key) + "&";  
  25.           }  
  26.       }  
  27.       Uri uri = new Uri(url + postdata);  
  28.   
  29.   
  30.       string boundary = "----------" + DateTime.Now.Ticks.ToString("x");  
  31.       HttpWebRequest webrequest = (HttpWebRequest)WebRequest.Create(uri);  
  32.       //webrequest.CookieContainer = cookies;  
  33.       webrequest.ContentType = "multipart/form-data; boundary=" + boundary;  
  34.       webrequest.Method = "POST";  
  35.       string huanhang = "\r\n";  
  36.       byte[] huanhangbyte = Encoding.UTF8.GetBytes(huanhang);  
  37.   
  38.       // Build up the post message header     
  39.       StringBuilder sb = new StringBuilder();  
  40.       sb.Append("--");  
  41.       sb.Append(boundary);  
  42.       sb.Append("\r\n");  
  43.       sb.Append("Content-Disposition: form-data; name=\"");  
  44.       sb.Append(fileFormName);  
  45.       sb.Append("\"; filename=\"");  
  46.       sb.Append(Path.GetFileName(uploadfile));  
  47.       sb.Append("\"");  
  48.       sb.Append("\r\n");  
  49.       sb.Append("Content-Type: ");  
  50.       sb.Append(contenttype);  
  51.       sb.Append("\r\n");  
  52.       sb.Append("\r\n");  
  53.   
  54.       string postHeader = sb.ToString();  
  55.       byte[] postHeaderBytes = Encoding.UTF8.GetBytes(postHeader);  
  56.   
  57.       // Build the trailing boundary string as a byte array     
  58.       // ensuring the boundary appears on a line by itself     
  59.       byte[] boundaryBytes =  
  60.              Encoding.ASCII.GetBytes("--" + boundary + "");  
  61.   
  62.       FileStream fileStream = new FileStream(uploadfile,  
  63.                                   FileMode.Open, FileAccess.Read);  
  64.       long length = postHeaderBytes.Length + fileStream.Length +  
  65.                                              boundaryBytes.Length + huanhangbyte.Length;  
  66.       webrequest.ContentLength = length;  
  67.   
  68.       Stream requestStream = webrequest.GetRequestStream();  
  69.   
  70.       // Write out our post header     
  71.       requestStream.Write(postHeaderBytes, 0, postHeaderBytes.Length);  
  72.   
  73.       // Write out the file contents     
  74.       byte[] buffer = new Byte[checked((uint)Math.Min(4096,  
  75.                                (int)fileStream.Length))];  
  76.       int bytesRead = 0;  
  77.       while ((bytesRead = fileStream.Read(buffer, 0, buffer.Length)) != 0)  
  78.           requestStream.Write(buffer, 0, bytesRead);  
  79.       requestStream.Write(huanhangbyte, 0, huanhangbyte.Length);  
  80.       // Write out the trailing boundary     
  81.       requestStream.Write(boundaryBytes, 0, boundaryBytes.Length);  
  82.       fileStream.Dispose();  
  83.       requestStream.Dispose();  
  84.       WebResponse responce = webrequest.GetResponse();  
  85.       Stream s = responce.GetResponseStream();  
  86.       StreamReader sr = new StreamReader(s);  
  87.       string retval=sr.ReadToEnd();  
  88.       sr.Dispose();  
  89.   
  90.       if (File.Exists(uploadfile))  
  91.       {  
  92.           try  
  93.           {  
  94.               File.Delete(uploadfile);  
  95.           }catch(Exception e)  
  96.           {  
  97.           }  
  98.       }  
  99.       return retval;  
  100.   }  


  CRM來電小秘書客戶端完成了,當然要配合這個功能,服務器端CRM系統也要做一些修改,不過不是這篇文章的主要內容,關於服務器端的修改的小節,就等下次再說吧。


C語言中 ^怎使用

a1 = 0x01; //0000 0001
a2 = 0x00; //0000 0000
a3 = 0x03; //0000 0011
a4 = 0x02; //0000 0010

b1 = a1 ^ a2; //0000 0001
b2 = a1 ^ a3; //0000 0010
b3 = a1 ^ a4; //0000 0011

^異或運算符,位值相同為0,不同為1,見上示例.

//
簡單實際問題舉例:
======\=======\=======
======a=======b=======
上面是2條電路,2個開關分別為a和b,打開狀態:\[1],關閉狀態:/[0].
若同時打開或者關閉,兩條電路均不通.
若a打開[1],b關閉[0],電路1通電
======\=======/=======
若a關閉[0],b打開[1],電路2通電
======/=======\=======
綜上,電路在a,b狀態相同時不通[0],在a,b不同時通電[1].
 

c語言中for語句是怎使用的

1:for循環

for語句的格式為:
for (初始化語句; 條件語句; 控制語句)
{
語句1 ;
語句2 ;
....

語句n ;
}

for 語句的執行順序是:首先執行“初始化語句”;然後測試“條件語句”;若條件成立,則執行語句1到語句n;然後執行“控制”語句;接著再測試條件語句是否成立,如果成立則重復執行以上過程,直至條件不成立時才結束for循環。如:

for(i=0;i<10;i++)......;

int i,a[]=new int[10];
for (i=0,i<10;i++) a[i]= 0;

這段代碼把整型數組a中的所有元素都賦成0。
你可以在for循環的頭部說明你的變量,而且最後一個表達式可以省略,不過要確定在語句中對變量的值有所改變,如:

for(int i=0;i<=10;) i+=i;

for循環中,“初始化語句”、“條件語句”和“控制語句”都可以省略,但是其間的分號不能省略。例如:
int i =0 ;
for (; ; ;)
{
if i>10 break ;
i = i +1 ;
}

for循環中省略“條件語句”時,在for語句{}中必須包換轉句語句控制程序在某個條件滿足時跳出for循環,否則將形成死循環

2:while循環

while循環和for循環類似,其格式為:
while (條件語句)
{
語句1 ;
語句2 ;
....

語句n ;
}

執行while時,先測試“條件語句”,如果條件成立,則執行語句1到語句n,直至條件不成立時調處循環。
int i=0 ;
while (i<10)
{
i++ ;
System.out.println("Hey!.get me out of here!:);
}

3:do ... while 循環
do ... while 循環語句的格式為:
do
{
語句1 ;
語句2 ;
....

語句n ;
}
while (條件語句) ;

do ...while 語句的功能是首先執行語句1到語句n,然後進行條件測試,如果條件成立,則繼續執行語句1到語句n,否這跳出循環。如:
boolean test=false;
do
{
......

}
while(test);

這種控制並不是很常用,但有時卻非常重要,使用時注意結尾處while語句後的分號。
 

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved