SMSLib не отправляет SMS с модемом E226 3G

Я хотел бы знать, знает ли кто-нибудь, почему я не могу отправить смс с моим модемом E226 3g. Я настроил класс примера, я установил модель модема, PIN-код и номер Smsc.

public class SendMessage
{
    public void doIt() throws Exception
    {
        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());
        SerialModemGateway gateway = new SerialModemGateway("modem.com1", "COM4", 9600, "Huawei", "E226");
        gateway.setInbound(true);
        gateway.setOutbound(true);
        gateway.setSimPin("1010");
        // Explicit SMSC address set is required for some modems.
        // Below is for VODAFONE GREECE - be sure to set your own!
        gateway.setSmscNumber("+555181136200");
        Service.getInstance().setOutboundMessageNotification(outboundNotification);
        Service.getInstance().addGateway(gateway);
        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("+556199655944", "Hello from SMSLib!");
        Service.getInstance().sendMessage(msg);
        System.out.println(msg);
        // Or, send out a WAP SI message.
        //OutboundWapSIMessage wapMsg = new OutboundWapSIMessage("306974000000",  new URL("http://www.smslib.org/"), "Visit SMSLib now!");
        //Service.getInstance().sendMessage(wapMsg);
        //System.out.println(wapMsg);
        // You can also queue some asynchronous messages to see how the callbacks
        // are called...
        //msg = new OutboundMessage("309999999999", "Wrong number!");
        //srv.queueMessage(msg, gateway.getGatewayId());
        //msg = new OutboundMessage("308888888888", "Wrong number!");
        //srv.queueMessage(msg, gateway.getGatewayId());
        System.out.println("Now Sleeping - Hit <enter> to terminate.");
        System.in.read();
        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();
        }
    }
}

Он выводит

run:
Example: Send message from a serial gsm modem.
SMSLib: A Java API library for sending and receiving SMS via a GSM modem or other supported gateways.
This software is distributed under the terms of the Apache v2.0 License.
Web Site: http://smslib.org
Version: 3.5.2
0      2012-06-28 19:08:32,652 [main] INFO  org.smslib.Service  - SMSLib: A Java API library for sending and receiving SMS via a GSM modem or other supported gateways.
This software is distributed under the terms of the Apache v2.0 License.
Web Site: http://smslib.org
3      2012-06-28 19:08:32,655 [main] INFO  org.smslib.Service  - Version: 3.5.2
3      2012-06-28 19:08:32,655 [main] INFO  org.smslib.Service  - JRE Version: 1.7.0_05
5      2012-06-28 19:08:32,657 [main] INFO  org.smslib.Service  - JRE Impl Version: 23.1-b03
Exception in thread "Thread-3" java.lang.ExceptionInInitializerError
5      2012-06-28 19:08:32,657 [main] INFO  org.smslib.Service  - O/S: Windows 7 / amd64 / 6.1
8      2012-06-28 19:08:32,660 [main] DEBUG org.smslib.threading.AServiceThread  - Initialized.
8      2012-06-28 19:08:32,660 [NotifyQueueManager] DEBUG org.smslib.threading.AServiceThread  - Running...
8      2012-06-28 19:08:32,660 [NotifyQueueManager] DEBUG org.smslib.notify.NotifyQueueManager$NotificationQueueManager  - NotifyQueueManager running...
9      2012-06-28 19:08:32,661 [main] INFO  org.smslib.queues.DefaultQueueManager  - Queue directory not defined. Queued messages will not be saved to filesystem.
9      2012-06-28 19:08:32,661 [main] DEBUG org.smslib.threading.AServiceThread  - Initialized.
10     2012-06-28 19:08:32,662 [DelayQueueManager] DEBUG org.smslib.threading.AServiceThread  - Running...
10     2012-06-28 19:08:32,662 [DelayQueueManager] DEBUG org.smslib.queues.AbstractQueueManager$DelayQueueManager  - DelayQueueManager running...
10     2012-06-28 19:08:32,662 [main] DEBUG org.smslib.threading.AServiceThread  - Initialized.
    at org.smslib.modem.SerialModemDriver.connectPort(SerialModemDriver.java:69)
    at org.smslib.modem.AModemDriver.connect(AModemDriver.java:114)
10     2012-06-28 19:08:32,662 [WatchDog] DEBUG org.smslib.threading.AServiceThread  - Running...
    at org.smslib.modem.ModemGateway.startGateway(ModemGateway.java:189)
11     2012-06-28 19:08:32,663 [Thread-3] INFO  org.smslib.modem.ModemGateway  - GTW: modem.com1: Starting gateway, using Huawei E226 AT Handler.
    at org.smslib.Service$1Starter.run(Service.java:276)
Caused by: java.lang.RuntimeException: CommPortIdentifier class not found
11     2012-06-28 19:08:32,663 [Thread-3] INFO  org.smslib.modem.SerialModemDriver  - GTW: modem.com1: Opening: COM4 @9600
    at org.smslib.helper.CommPortIdentifier.<clinit>(CommPortIdentifier.java:76)
    ... 4 more
15010  2012-06-28 19:08:47,662 [WatchDog] DEBUG org.smslib.threading.AServiceThread  - Running...
30011  2012-06-28 19:09:02,663 [WatchDog] DEBUG org.smslib.threading.AServiceThread  - Running...
45012  2012-06-28 19:09:17,664 [WatchDog] DEBUG org.smslib.threading.AServiceThread  - Running...
60012  2012-06-28 19:09:32,664 [WatchDog] DEBUG org.smslib.threading.AServiceThread  - Running...
75013  2012-06-28 19:09:47,665 [WatchDog] DEBUG org.smslib.threading.AServiceThread  - Running...
90014  2012-06-28 19:10:02,666 [WatchDog] DEBUG org.smslib.threading.AServiceThread  - Running...

Это все, что я получаю в течение нескольких часов. Любая идея, почему не работает?


person dextervip    schedule 28.06.2012    source источник


Ответы (3)


Вам не хватает javax.comm. Ситуация с javax.comm в Windows немного запутанная, инструкции по установке smslib предлагают использовать rxtx и перейдите на страницу Cloudhopper для версии для Windows. Получите эту библиотеку, добавьте ее в качестве зависимости в свой проект, и все будет готово.

person fvu    schedule 28.06.2012
comment
Я пробовал javacomm, но он не поддерживает 64-битную версию Win 7, библиотека rxtx со страницы cloudhopper имеет 64-битную версию, которая работает хорошо. Спасибо - person dextervip; 29.06.2012
comment
У меня та же проблема, но в моем случае я уже сделал все эти шаги. Итак, если вы знаете другую проблему, которая может вызвать это, поделитесь ею со мной. - person Muhammed Refaat; 22.06.2013
comment
@MuhammedRefaat, пожалуйста, создайте новый вопрос для своей проблемы, не прикрепляйте его к какому-то другому вопросу в качестве комментария. Прочтите публикацию как спросить, чтобы понять, как создать хороший вопрос, на который, несомненно, будет дан быстрый ответ. Удачи! - person fvu; 23.06.2013

Caused by: java.lang.RuntimeException: CommPortIdentifier class not found

Вам не хватает библиотеки, в зависимости от того, какая из них содержит CommPortIdentifier. Выясните, какая библиотека вам нужна, и включите ее в путь к классам.

person Jim Garrison    schedule 28.06.2012
comment
Что вы посоветуете, если я включу все библиотеки, а проблема останется? - person Muhammed Refaat; 22.06.2013

Вам не хватает библиотеки связи. Есть две библиотеки, с помощью которых вы можете решить эту проблему.

Вот фрагмент кода, который выдает эту ошибку:

try
        {
            classCommPortIdentifier = Class.forName("javax.comm.CommPortIdentifier");
        }
        catch (ClassNotFoundException e1)
        {
            try
            {
                classCommPortIdentifier = Class.forName("gnu.io.CommPortIdentifier");
            }
            catch (ClassNotFoundException e2)
            {
                throw new RuntimeException("CommPortIdentifier class not found");
            }
        }

Итак, убедитесь, что javax.comm.CommPortIdentifier из gnu.io.CommPortIdentifier классов находятся в вашем пути к классам. Также убедитесь, что вы добавили собственный rxtxSerial.dll в {jre}/bin/

gnu.io.CommPortIdentifier взят из библиотеки rxtx, которая имеет новую упаковку.

Недавно было изменено имя пакета, поэтому вы запутаетесь в использовании библиотеки RxTx. Пожалуйста, подумайте над приведенным выше кодом и проясните его для себя

Вот что упоминается на сайте:

RXTX 2.1 – основная ветка разработки RXTX. Используется пространство имен gnu.io.. Если у вас нет особых причин, это рекомендуемая загрузка. Если вам нужна совместимость с javax.comm.*, загрузите RXTX 2.0, но учтите, что для этой ветки не требуется особых усилий по разработке, поэтому вы упустите все исправления, которые получает основная ветка.*

person Chand Priyankara    schedule 10.04.2013
comment
У меня та же упомянутая проблема, но я сделал все необходимые шаги, и проблема все еще существует, даже если я попробовал ваш фрагмент и запустил его правильно, ничего не поймав, не могли бы вы предложить мне другое решение, пожалуйста? - person Muhammed Refaat; 22.06.2013
comment
Получаете ли вы какие-либо исключения? тогда, пожалуйста, опубликуйте это. - person Chand Priyankara; 23.06.2013
comment
нет, не заводится, нормально - person Muhammed Refaat; 23.06.2013
comment
Каково ваше окружение? Это линукс или винда? - person Chand Priyankara; 23.06.2013