讀寫串行口數(shù)據(jù),理論上很容易,PHP倒沒試過。。。
發(fā)表時(shí)間:2023-07-30 來源:明輝站整理相關(guān)軟件相關(guān)文章人氣:
[摘要]我沒看過PHP源碼,但它有文件操作函數(shù),我想應(yīng)該可以吧?實(shí)在不行,那么做個(gè)CGI來實(shí)現(xiàn)也可以,而且獨(dú)立性好,容易維護(hù)。以前我在BCB環(huán)境下做過,思路如下:(其實(shí)相當(dāng)于普通的文件讀寫操作,呵呵)一、打...
我沒看過PHP源碼,但它有文件操作函數(shù),我想應(yīng)該可以吧?實(shí)在不行,那么做個(gè)CGI來實(shí)現(xiàn)也可以,而且獨(dú)立性好,容易維護(hù)。以前我在BCB環(huán)境下做過,思路如下:(其實(shí)相當(dāng)于普通的文件讀寫操作,呵呵)
一、打開文件
//先用文件方式打開一個(gè)串口(COM1~~COM4中任一個(gè))
HANDLE m_hComm = CreateFile("COM2", GENERIC_READ GENERIC_WRITE, NULL, OPEN_EXISTING, FILE_FLAG_OVERLAPPED, 0);
然后就可以用WriteFile()和ReadFile()來對串行口進(jìn)行讀寫了,最后記得CloseHandle(m_hComm);把當(dāng)前打開的串行口關(guān)閉哦。
由于CreateFile()函數(shù)采用FILE_FLAG_OVERLAPPED常量,那么注意一下WriteFile()和ReadFile()函數(shù)的最后一個(gè)參數(shù)是OVERLAPPED結(jié)構(gòu)的,讀寫前需要先初始化該結(jié)構(gòu):
OVERLAPPED m_ov;
m_ov.Offset = 0;
m_ov.OffsetHigh = 0;
m_ov.hEvent = NULL;
好了,上面已經(jīng)打開COM2,那么就進(jìn)行簡單讀寫:
二、寫:
BOOL bResult = true;
char* m_WriteBuffer;
DWORD BytesSent = 0;
strcpy(m_WriteBuffer, "試試寫進(jìn)去");
bResult = WriteFile(m_hComm, m_WriteBuffer, strlen((char*)m_WriteBuffer), &BytesSent, m_ov);
三、讀:
COMSTAT comstat;//該結(jié)構(gòu)包含通信設(shè)備的狀態(tài)。
BOOL bResult = true;
DWORD dwError = 0;
DWORD BytesRead = 0;
unsigned char m_ReadBuff;
//開始循環(huán)讀
for (;;)
{
bResult = ClearCommError(m_hComm, &dwError, &comstat);//更新COMSTAT結(jié)構(gòu)并清除所有錯(cuò)誤
if (comstat.cbInQue == 0)
{
break;//如果讀完了就退出for循環(huán)
}
bResult = ReadFile(m_hComm, &ReadBuff, 1, &BytesRead, m_ov);//一次讀一位,如果喜歡,你也可以一次讀n位
......
//在這里放入你的處理模塊,反正ReadBuff里是內(nèi)容(1位),可以合并起來......
......
}
四、關(guān)掉
CloseHandle(m_hComm);
以上思路可以通過函數(shù)返回值進(jìn)行錯(cuò)誤處理,至于各錯(cuò)誤常量的意思可以查書,完整處理是麻煩點(diǎn),知道方法就可以了,只要你是簡單應(yīng)用,那么簡單讀寫就足夠了。這個(gè)文件讀寫方式還適用于打印口LPT1、LPT2~~~LPTn。在Unix下我沒試過,但既然Unix類的操作系統(tǒng)比Windows更加強(qiáng)調(diào)設(shè)備文件,相信在Unix、Linux下用文件方式讀寫COM口更簡單更通用吧。。。?還是這句:知道方法就行。該出手時(shí)就出手。^_^
不過如果在Unix、Linux下作為CGI來用的話,可能要設(shè)置編譯后CGI文件的權(quán)限,自己試哦。