Разработих приложение за SMS (изпращане/получаване на SMS чрез GSM модем), използвайки тази библиотека - http://www.scampers.org/steve/sms/libraries.htm
Имам таймер, който проверява получените съобщения на всеки 3 секунди. Проблемът е, че на всеки няколко минути получавам тази грешка:
***
at GsmComm.GsmCommunication.GsmPhone.GsmComm.GsmCommunication.IProtocol.ReceiveAnything(String pattern)
at GsmComm.GsmCommunication.GsmPhone.GsmComm.GsmCommunication.IProtocol.ReceiveMultiple()
at GsmComm.GsmCommunication.GsmPhone.GsmComm.GsmCommunication.IProtocol.ExecAndReceiveMultiple(String command)
at GsmComm.GsmCommunication.GsmPhone.ListMessages(PhoneMessageStatus status)
at GsmComm.GsmCommunication.GsmCommMain.ReadMessages(PhoneMessageStatus status, String storage)
at SMS.BL.TimerCalls_rec.recProcessTimerEvent(Object sender, EventArgs e) in D:\Csharp\SMS GSM\SMS\BL\TimerCalls_rec.cs:line 57++++++++No data received from phone after waiting for 30000 ms.
Това е частта от този код:
try
{
// Read all SMS messages from the storage
if (CommSetting.comm.IsConnected())
{
DecodedShortMessage[] messages = CommSetting.comm.ReadMessages(PhoneMessageStatus.All, PhoneStorageType.Phone);
foreach (DecodedShortMessage message in messages)
{
ReadMessage(message.Data);
//delete message
indexP = message.Index;
CommSetting.comm.DeleteMessage(indexP, PhoneStorageType.Phone);
}
}
}
catch (Exception err)
{
RIWL.log(err.StackTrace + "++++++++" + err.Message, "Error: ");
}
Това е редът, където възниква грешката:
DecodedShortMessage[] messages = CommSetting.comm.ReadMessages(PhoneMessageStatus.All, PhoneStorageType.Phone);
Някакви идеи защо от време на време модемът не отговаря? Изпращането/получаването на съобщения се извършва отделно. При изпращане на SMS - четенето спира и обратното.
Мога ли да направя нещо друго, за да проверя дали серийният порт е зает?
РЕДАКТИРАНЕ: Ако има някаква помощ, в момента, когато се случи грешка, dllhost.exe - COM сурогат се появява скоро в процесите.