讀寫串行口數據

發表于:2007-07-14來源:作者:點擊數: 標簽:
我沒看過 PHP 源碼,但它有文件操作函數,我想應該可以吧?實在不行,那么做個CGI來實現也可以,而且獨立性好,容易維護。以前我在BCB環境下做過,思路如下:(其實相當于普通的文件讀寫操作,呵呵) 一、打開文件 //先用文件方式打開一個串口(COM1~~COM4中
我沒看過PHP源碼,但它有文件操作函數,我想應該可以吧?實在不行,那么做個CGI來實現也可以,而且獨立性好,容易維護。以前我在BCB環境下做過,思路如下:(其實相當于普通的文件讀寫操作,呵呵)

一、打開文件

//先用文件方式打開一個串口(COM1~~COM4中任一個)
HANDLE m_hComm = CreateFile("COM2", GENERIC_READ | GENERIC_WRITE, NULL, OPEN_EXISTING, FILE_FLAG_OVERLAPPED, 0);

然后就可以用WriteFile()和ReadFile()來對串行口進行讀寫了,最后記得CloseHandle(m_hComm);把當前打開的串行口關閉哦。
由于CreateFile()函數采用FILE_FLAG_OVERLAPPED常量,那么注意一下WriteFile()和ReadFile()函數的最后一個參數是OVERLAPPED結構的,讀寫前需要先初始化該結構:

OVERLAPPED m_ov;

m_ov.Offset = 0;
m_ov.OffsetHigh = 0;
m_ov.hEvent = NULL;

好了,上面已經打開COM2,那么就進行簡單讀寫:

二、寫:

BOOL bResult = true;
char* m_WriteBuffer;
DWORD BytesSent = 0;

strcpy(m_WriteBuffer, "試試寫進去");
bResult = WriteFile(m_hComm, m_WriteBuffer, strlen((char*)m_WriteBuffer), &BytesSent, m_ov);


三、讀:

COMSTAT comstat;//該結構包含通信設備的狀態。
BOOL bResult = true;
DWORD dwError = 0;
DWORD BytesRead = 0;
unsigned char m_ReadBuff;
//開始循環讀
for (;;)
{
  bResult = ClearCommError(m_hComm, &dwError, &comstat);//更新COMSTAT結構并清除所有錯誤
  if (comstat.cbInQue == 0)
  {
    break;//如果讀完了就退出for循環
  }

  bResult = ReadFile(m_hComm, &ReadBuff, 1, &BytesRead, m_ov);//一次讀一位,如果喜歡,你也可以一次讀n位
  ......
  //在這里放入你的處理模塊,反正ReadBuff里是內容(1位),可以合并起來......
  ......
}

四、關掉
CloseHandle(m_hComm);


以上思路可以通過函數返回值進行錯誤處理,至于各錯誤常量的意思可以查書,完整處理是麻煩點,知道方法就可以了,只要你是簡單應用,那么簡單讀寫就足夠了。這個文件讀寫方式還適用于打印口LPT1、LPT2~~~LPTn。在Unix下我沒試過,但既然Unix類的操作系統比Windows更加強調設備文件,相信在Unix、Linux下用文件方式讀寫COM口更簡單更通用吧。。。?還是這句:知道方法就行。該出手時就出手。^_^
不過如果在Unix、Linux下作為CGI來用的話,可能要設置編譯后CGI文件的權限,自己試哦。

原文轉自:http://www.anti-gravitydesign.com

国产97人人超碰caoprom_尤物国产在线一区手机播放_精品国产一区二区三_色天使久久综合给合久久97