RFIDリーダーからのデータの読み取りに問題があります。tcpでリーダーに接続し、DataAvailableがtrueになるのを待ってから、データ文字の終わりを取得するまでデータを読み取ります。次に、戻って新しいDataAvailableを待ちます。これは、関数の独自のスレッドで実行されます。
ある種のタイムアウトがあるようです。数分以内にデータが取得されない場合は、データがDataAvailableを待機しているdo/loopにあります。カードをRFIDリーダーにかざすと、ビープ音が鳴りますが、利用できるデータがありません。例外は発生しません。情報によると、クライアントソケットはまだ接続されています。他に確認できることはありますか?
カードを1分間隔でリーダーに置くと、これは決して起こらないようです。したがって、2〜3分のアイドル状態:ingがこれを行うようです。
ソケットからデータを読み取るための私のコードは次のとおりです。無関係なコードをいくつか削除しました。
Sub test(ByVal ip As String, ByVal port As Integer)
' this sub is meant to run forever
Try
Dim clientSocket As New System.Net.Sockets.TcpClient()
clientSocket.Connect(ip, port)
Using serverStream As NetworkStream = clientSocket.GetStream()
Do 'loop forever or until error occur
'Every new dataentry starts here
Dim inStream(0) As Byte
Dim returndata As String = ""
Do 'loop forever
Do Until serverStream.DataAvailable 'loop until data exists to read
If clientSocket.Connected = False Then
'this will never happen.
'but if there are more than 5 minutes between data then
'it never got data again as if no data was sent.
Exit Sub
End If
Application.DoEvents()
Loop
'there is data to read, read first byte and
serverStream.Read(inStream, 0, 1)
If inStream(0) = 13 Then
'got end of data
'exit loop if reading chr 13.
returndata &= System.Text.Encoding.ASCII.GetString(inStream)
Exit Do
End If
Loop
GotData(returndata)
Loop
End Using
Catch ex As Exception
' handle error
Finally
'close connection if open
End Try
End Sub