Невозможно отправить сообщение с помощью smslib

Я использую модем Simado GDT11 и драйвер Prolific USB to Serial port. Новое подключение появится в списке «Диспетчер устройств» > «Порты». Однако я не могу отправлять сообщения с помощью smslib.

Я использую базовый класс, как указано в примерах smslib, но всегда возникает какая-то ошибка, указывающая на отсутствие ответа от устройства. Я добавил параметры опроса из-за использования порта USB, но безрезультатно. Утилита Commtest может подключаться к тому же порту, поэтому я не думаю, что номер порта является проблемой.

Трассировки стека:

log4j:WARN No appenders could be found for logger (smslib).
log4j:WARN Please initialize the log4j system properly.
log4j:WARN See http://logging.apache.org/log4j/1.2/faq.html#noconfig for more info.
org.smslib.TimeoutException: No response from device.
  at org.smslib.modem.AModemDriver$CharQueue.get(AModemDriver.java:535)
  at org.smslib.modem.AModemDriver.getResponse(AModemDriver.java:338)
  at org.smslib.modem.AModemDriver.getResponse(AModemDriver.java:313)
  at org.smslib.modem.athandler.ATHandler.getSimStatus(ATHandler.java:145)
  at org.smslib.modem.AModemDriver.connect(AModemDriver.java:132)
  at org.smslib.modem.ModemGateway.startGateway(ModemGateway.java:189)
  at org.smslib.Service$1Starter.run(Service.java:277)

Код:

public class SendMessage {

public void doIt() throws Exception
{
    SerialModemGateway gateway = new SerialModemGateway("modem.com4", "COM4", 115200, "Simado", "GDT11");
    try {
        OutboundNotification outboundNotification = new OutboundNotification();
        System.out.println("Example: Send message from a serial gsm modem.");
        System.out.println(Library.getLibraryDescription());
        System.out.println("Version: " + Library.getLibraryVersion());
        gateway.setInbound(false);
        gateway.setOutbound(true);
        gateway.setSimPin("0000");
        // Explicit SMSC address set is required for some modems.
        // Below is for VODAFONE GREECE - be sure to set your own!
        gateway.setSmscNumber("+919560734413");
        Service.getInstance().setOutboundMessageNotification(outboundNotification);
        Service.getInstance().addGateway(gateway);
        Service.getInstance().S.SERIAL_NOFLUSH = true;
        Service.getInstance().S.SERIAL_POLLING = true;
        Service.getInstance().S.SERIAL_POLLING_INTERVAL = 200;
        Service.getInstance().startService();
        System.out.println();
        System.out.println("Modem Information:");
        System.out.println("  Manufacturer: " + gateway.getManufacturer());
        System.out.println("  Model: " + gateway.getModel());
        System.out.println("  Serial No: " + gateway.getSerialNo());
        System.out.println("  SIM IMSI: " + gateway.getImsi());
        System.out.println("  Signal Level: " + gateway.getSignalLevel() + " dBm");
        System.out.println("  Battery Level: " + gateway.getBatteryLevel() + "%");
        System.out.println();
        // Send a message synchronously.
        OutboundMessage msg = new OutboundMessage("+918095065000", "Hello from SMSLib!");
        Service.getInstance().sendMessage(msg);
        System.out.println(msg);
    } finally {
        gateway.stopGateway();
        Service.getInstance().stopService();
    }

}

public class OutboundNotification implements IOutboundMessageNotification
{
    public void process(AGateway gateway, OutboundMessage msg)
    {
        System.out.println("Outbound handler called from Gateway: " + gateway.getGatewayId());
        System.out.println(msg);
    }
}

public static void main(String args[])
{
    SendMessage app = new SendMessage();
    try
    {
        app.doIt();
    }
    catch (Exception e)
    {
        e.printStackTrace();
    }
}
}

person Neel Borooah    schedule 24.09.2013    source источник


Ответы (1)


Я решил проблему. Код правильный. Судя по всему, использование сим-карты, находящейся в роуминге, не лучшая идея. Я переключился на местную SIM-карту, и сообщение было отправлено.

Кроме того, я использовал эмулятор USB-COM-порта (Prolific USB- Серийный), из-за которого модем не инициализировался во время выполнения кода.

Чтобы решить эту проблему, я выполнил команду инициализации (AT + CMGF = 1) при запуске сервера.

person Neel Borooah    schedule 25.09.2013