SMSLib不会使用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  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.(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... 

这就是我几个小时都得到的。 知道为什么不起作用?

你错过了javax.comm。 Windows上javax.comm的情况有点混乱, smslib安装说明建议使用rxtx,并指向Cloudhopper的 Windows版本页面 。 获取该库,将其作为项目的依赖项添加,您应该全部设置。

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

您缺少一个库,无论哪个库包含CommPortIdentifier 。 找出您需要的库并将其包含在类路径中。

您缺少comm库。您可以通过两个库来解决此问题。

以下是引发此错误的代码片段:

 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"); } } 

因此,请确保gnu.io.CommPortIdentifier类的gnu.io.CommPortIdentifier位于类路径中。还要确保将本机rxtxSerial.dll添加到{jre} / bin /

gnu.io.CommPortIdentifier来自rxtx库,它有新的包装对象

最近有包名更改,因此您会对使用RxTx库感到困惑。 请从上面的代码中获取一些想法,并向您明确说明

以下是网站上提到的内容:

RXTX 2.1是RXTX的主要开发分支。 使用的命名空间是gnu.io. 。 除非您有任何具体原因,否则建议您下载。 如果您需要与javax.comm兼容。*然后下载RXTX 2.0,但请注意,此分支没有提供太多的开发工作,因此您将错过主分支获得的所有修复。*