java实现基于SGIP协议开发联通短信的方法

本文实例讲述了java实现基于SGIP协议开发联通短信的方法。分享给大家供大家参考。具体如下:

近段时间,由于公司的业务需要,开发出了联通短信.此文章的编写也是根据网上的一些示例来完成的.闲话少说,下面来看代码:(运行此程序的时候需要导入华为的开发包,此包可以到网上下载)

下行:

public class Mt {
 private static String SPNumber = "**********";
 //接入号码
 private static String ChargeNumber = "000000000000000000000";
 // 计费号码,白名单
 private static String ServiceType = "";
 //服务类型
 private static String host = "***.***.***.***";
 // 主机名,网关IP
 private static int port = ****;
 // 端口号
 private static String CorpId = "*****";
 // 企业代码
 private static String login_Name = "**";
 // 登陆名
 private static String login_PassWord = "***";
 // 登陆密码
  public static void main(String[] args) throws UnsupportedEncodingException {
  int srcnode = new BigInteger("*******").intValue();
  //源节点编号(nodeid),这一步非常重要,华为包中,该字段类型为int,而接入协议中要求在企业代码前加上30000,这样就超过了int的取值范围,所以需要用BigInteger转一下就可以了
   Args argstr = new Args();//设定连接参数
   argstr.set("host", host);
   argstr.set("port", port);
   argstr.set("transaction-timeout", 10);
   // 操作超时时间(单位:秒)
   argstr.set("read-timeout", 15);
   // 物理连接读操作超时时间(单位:秒)
   argstr.set("source-addr", srcnode);
   // SP…ID(最大为六位字符)
   argstr.set("login-name", login_Name);
   argstr.set("login-pass", login_PassWord);
   argstr.set("debug", "false");
   // 连接登陆
   SGIPSMProxy sgipsmp = new SGIPSMProxy(argstr);
   // 这里 连接到短信息网关
   try {
    //connect表示向SMG登陆,登录名与密码分别是SMG向SP分配的用户名与密码,调用这个接口方法,向SMG发送Bind命令消息。
    //如果发送消息超时或通信异常则抛出异常,需要调用者捕获处理。
    boolean reslut = sgipsmp.connect(login_Name, login_PassWord);
    // 登陆得到true和false
    if (reslut) {
     System.out.println("连接成功...........");
    } else {
     System.out.println("连接失败(用户名或密码错误)...........");
     return;
    }
   } catch (Exception ex) {
    System.out.println("网络异常...........");
    ex.printStackTrace();
    return;
   }
   String[] UserNumber = { "8618686619970","8618686619977"};
   //接收短信的手机号码,前边要加上86
   String content = "联通短信发送成功";
   byte[] MessageContent = content.getBytes("GB2312");
    System.out.println("短信内容: "+content);
   try {
    // 下发短息
    SGIPSubmitMessage sgipsubmit = new SGIPSubmitMessage(
      SPNumber, // SP的接入号码
      ChargeNumber, // 付费号码 string
      UserNumber, // 接收该短消息的手机号,最多100个号码 string[]
      CorpId, // 企业代码,取值范围为0~99999 string
      ServiceType, // 业务代码,由SP定义 stirng
      03, // 计费类型 int
      "0", // 该条短消息的收费值 stirng
      "0", // 赠送用户的话费 string
      0, // 代收费标志0:应收1:实收 int
      0, // 引起MT消息的原因 int
      06, // 优先级0~9从低 到高,默认为0 int
      null, // 短消息寿命的终止时间 date
      null, // 短消息定时发送的时间 date
      1, // 状态报告标记 int
      0, // GSM协议类型 int
      0, // GSM协议类型 int
      15, // 短消息的编码格式 int
      0, // 信息类型 int
      MessageContent.length, // 短消息内容长度 int
      MessageContent, // 短消息的内容 btye[]
      "0" // 保留,扩展用 string
    );
    // 收到的响应消息转换成rep
    int status = ProcessSubmitRep(sgipsmp.send(sgipsubmit));
    System.out.println(status);
    if (status == 0) {
     System.out.println("消息发送成功..........");
    } else {
     System.out.println("消息发送失败..........");
    }
   } catch (Exception ex) {
    ex.printStackTrace();
   }
  }
  private static int ProcessSubmitRep(SGIPMessage msg) {
   // 收到的响应消息转换成repMsg
   SGIPSubmitRepMessage repMsg = (SGIPSubmitRepMessage) msg;
   System.out.println(repMsg.getSrcNodeId());
   System.out.println("status:::::::" + repMsg.getResult());
   if (repMsg != null && repMsg.getResult() == 0) {
    System.out.println("发送成功:::");
   }
   return repMsg.getResult();
  }
}

上行:

public class Mo extends SGIPSMProxy {
 //SMG服务器信息
 private static String serHost = "***.***.***.***";
 private static int serviceport = ****;
 //本机信息
 private static String localhost = "***.***.***.***";
 private static int localport = ****;
 public Mo(Args args) {
  super(args);
  System.out.println("进入启动监听........");
  startService(localhost, localport);
  //我想知道这里传递的host和port是本地的还是那的
 }
 public static void main(String[] args)
 {
  Args argstr = new Args();
  argstr.set("serHost", serHost);
  argstr.set("serviceport", serviceport);
  argstr.set("localhost", localhost);
  argstr.set("localport", localport);
  argstr.set("transaction-timeout", 10);
  // 操作超时时间(单位:秒)
  argstr.set("read-timeout", 15);
  // 物理连接读操作超时时间(单位:秒)
  //这里的安全认证问题如何解决?
  Mo mymo=new Mo(argstr);
 }
 public SGIPMessage onDeliver(SGIPDeliverMessage msg) {
  ProcessRecvDeliverMsg(msg);
  System.out.println("正在等待接收.......");
  return super.onDeliver(msg);
 }
 public void ProcessRecvDeliverMsg(SGIPMessage msg) {
  if (msg instanceof SGIPSubmitRepMessage) {
  //是否是类的实例
   System.out.println("返回下发短信的相应消息");
  }
  if (msg instanceof SGIPDeliverMessage) {
   // 收到用户发送的短信(上行)
   SGIPDeliverMessage deliverMsg = (SGIPDeliverMessage) msg;
   String userNumber = deliverMsg.getUserNumber();
   // 手机号码
   String msgContent = deliverMsg.toString();
   // 短信内容
   // byte[] msgId = deliverMsg.getMsgContent();
   System.out.println("userNumber::::::" + deliverMsg.getUserNumber());
   System.out.println("msgcontent:::::::" + deliverMsg.toString());
   System.out.println("spNumber::::::::" + deliverMsg.getSPNumber());
   //log.info("收到消息:" + deliverMsg);
   System.out.println("收到消息 :"+deliverMsg);
   int commandId = deliverMsg.getCommandId();
   // 响应类型
   System.out.println("commandId:::::::::" + commandId);
   if (commandId == 0) { //上传短信(接收)
    System.out.println("dstaddr::::::" + deliverMsg.getSPNumber());
    try {
    } catch (Exception e) {
     // TODO Auto-generated catch block
     e.printStackTrace();
    }
   }
  }
 }
}

希望本文所述对大家的java程序设计有所帮助。

时间: 2015-07-12

javaweb中Http协议详解

一.什么是HTTP协议 HTTP是hypertext transfer protocol(超文本传输协议)的简写,它是TCP/IP协议的一个应用层协议,用于定义WEB浏览器与WEB服务器之间交换数据的过程.客户端连上web服务器后,若想获得web服务器中的某个web资源,需遵守一定的通讯格式,HTTP协议用于定义客户端与web服务器通迅的格式. 二.HTTP协议的版本 HTTP协议的版本:HTTP/1.0.HTTP/1.1 三.HTTP1.0和HTTP1.1的区别 在HTTP1.0协议中,客户端

java使用Socket实现SMTP协议发送邮件

本文实例为大家分享了java 利用Socket实现SMTP协议发送邮件的具体代码,供大家参考,具体内容如下 package mail; import java.io.BufferedReader; import java.io.IOException; import java.io.InputStream; import java.io.InputStreamReader; import java.io.OutputStream; import java.io.PrintWriter; impo

Java基于socket服务实现UDP协议的方法

本文实例讲述了Java基于socket服务实现UDP协议的方法.分享给大家供大家参考.具体如下: 示例1: 接收类: package com.socket.demo; import java.io.IOException; import java.net.DatagramPacket; import java.net.DatagramSocket; public class UDPReceiveDemo { public static void main(String[] args) throw

Java URL自定义私有网络协议

--声明,脑残人士远离,本博客的核心不是if-else+前缀,而是如何通过URL协议处理框架定义私有协议 URI与URL的区别 URI (uniform resource identifier)统一资源标志符:URL(uniform resource location )统一资源定位符(或统一资源定位器):URI是一个相对来说更广泛的概念,URL是URI的一种,是URI命名机制的一个子集,可以说URI是抽象的,而具体要使用URL来定位资源.URI指向的一般不是物理资源路径,而是整个系统中的映射后

Java基于UDP协议实现简单的聊天室程序

最近比较闲,一直在抽空回顾一些Java方面的技术应用. 今天没什么事做,基于UDP协议,写了一个非常简单的聊天室程序. 现在的工作,很少用到socket,也算是对Java网络编程方面的一个简单回忆. 先看一下效果: 实现的效果可以说是非常非常简单,但还是可以简单的看到一个实现原理.  "聊天室001"的用户,小红和小绿相互聊了两句,"聊天室002"的小黑无人理会,在一旁寂寞着. 看一下代码实现: 1.首先是消息服务器的实现,功能很简单: •将客户端的信息(进入了哪一

使用Java通过OAuth协议验证发送微博的教程

虽然新浪微博开放平台中提供各种语言版本的开发 SDK 下载,也各自附有一些基本接口调用的 Demo 和接口说明文档.但是这几天的耐心尝试之后,感觉新浪微博开放平台上的入门指导和下载到的 Java 开发包 weibo4j 包里面的 Demo 使用注释有些不一致.再加上自身领悟能力有限,导致遇到好些摸不着头脑的难题.不过幸好没有放弃去尝试弄懂它.废话少说,下面是我学习的过程.   想要通过调用新浪微博开放平台 API 开发自己的微博应用,第一步是拥有sina 微博账号和CSDN 账号,因为我们要同时

java编程实现基于UDP协议传输数据的方法

本文实例讲述了java编程实现基于UDP协议传输数据的方法.分享给大家供大家参考,具体如下: UDP协议(User Datagram Protocol,用户数据报协议)不同于TCP协议,它是不可能靠的,但是它比TCP协议具有更快的传输速度,UDP发送的数据单元称为数据报,当网络传输UDP传输UDP数据报是无法保证数据能够到达目的地,也无法保证按发送的顺序到达目的地,也就是说先发送了"hello",再发送了"world",但接收方可能会先收到"world&q

使用java实现Xmodem协议

1.介绍 Xmodem是一种在串口通信中广泛使用的异步文件传输协议,分为Xmodem(使用128字节的数据块)和1k-Xmodem(使用1024字节即1k字节的数据块)协议两种. 本文实现的是128字节数据块的Xmodem协议,采用CRC16校验,在项目中应用时,发送端和接收端可根据具体情况修改双方的协议. 如果你对串口通信还不太了解,可以看下我写的这篇博客使用Java实现串口通信. 2.实现 在和嵌入式同学调试的过程中,发现发送端发送数据过快,导致接收端处理不过来,所以在send方法中开启了一

Java基于Tcp协议的socket编程实例

本文实例讲述了Java基于Tcp协议的socket编程方法,分享给大家供大家参考.具体分析如下: 以下是一对一的通信编程实现,后续会继续学习一个服务器监听多个客户端的实现. 这里用到的主要步骤如下: 第一步:以特定端口(如4800)新建socket对象 第二步:以系统输入设备构造BufferedReader对象,该对象用于接收系统键盘输入的字符 第三步:以socket对象 得到输出流来构造PrintWriter 第四步:以socket对象得到输入流来构造相应的BufferedReader对象,该

基于JAVA中Jersey处理Http协议中的Multipart的详解

那么Http协议中的Multipart是个什么东东?下面是摘抄http协议1.1的一段话:在multipart entity(多部分实体)的例子中,一个或多个不同的数据集合并在一个单一的body(体)中,一个"multipart"(多部分)类型 field的(域)必须出现在实体的header(头域).body(体)必须包括一个或多个body part(体部分),每一个位于boundary(边界)定界符线之前,最后一个则跟着一个结束边界定界符线.在它的边界定界符线后,每一个体部分由头域.

基于java变量和作用域以及成员变量的默认初始化(详解)

ava中的变量有成员变量和局部变量,定义在类中方法之外的变量成为成员变量或者成员字段(域),表示一个类所具有的属性,定义为类的成员变量的变量的作用于是整个类,该变量在定义的时候不需要初始化,在使用前java会自动初始化成员变量,对于基本数据类型的的自动初始化如下: java基本类型默认初始化值 int 0 short 0 byte 0 long 0 float 0.0 double 0.0 boolean false char 0 例如: public class test{ private i

java中synchronized(同步代码块和同步方法)详解及区别

 java中synchronized(同步代码块和同步方法)详解及区别 问题的由来: 看到这样一个面试题: //下列两个方法有什么区别 public synchronized void method1(){} public void method2(){ synchronized (obj){} } synchronized用于解决同步问题,当有多条线程同时访问共享数据时,如果进行同步,就会发生错误,Java提供的解决方案是:只要将操作共享数据的语句在某一时段让一个线程执行完,在执行过程中,其他

关于java中可变长参数的定义及使用方法详解

JAVA中可以为方法定义可变长参数( Varargs)来匹配不确定数量的多个参数,其定义用"..."表示.其实,这类似于为方法传了一个数组,且在使用方法上也和数组相同,如下: public void test(String... str){ for(String s : str){ } } 调用方法就像普通的调用方式相同,只不过可以匹配的参数为0到多个.如下: test(); test("lilei"); test("lilei","h

Java 中桥接模式——对象结构型模式的实例详解

Java  中桥接模式--对象结构型模式的实例详解 一.意图 将抽象部分与它的实现部分分离,使他们都可以独立的变化. 二.适用性 以下一些情况使用Bridge模式 你不希望在抽象和它的实现部分之间有一个固定的绑定关系.例如这种情况可能因为,在程序运行时刻实现部分应可以被选择或者切换. 类的抽象以及它的实现都应该可以通过生成子类的方法加以扩充.这时Bridge模式使你可以对不同的抽象接口和实现部分进行组合,并分别对他们进行扩充. 对一个抽象的实现部分的修改应对客户不产生影响,即客户代码不必重新编译

基于Python中单例模式的几种实现方式及优化详解

单例模式 单例模式(Singleton Pattern)是一种常用的软件设计模式,该模式的主要目的是确保某一个类只有一个实例存在.当你希望在整个系统中,某个类只能出现一个实例时,单例对象就能派上用场. 比如,某个服务器程序的配置信息存放在一个文件中,客户端通过一个 AppConfig 的类来读取配置文件的信息.如果在程序运行期间,有很多地方都需要使用配置文件的内容,也就是说,很多地方都需要创建 AppConfig 对象的实例,这就导致系统中存在多个 AppConfig 的实例对象,而这样会严重浪

基于vue中对鼠标划过事件的处理方式详解

鼠标事件进行监听 需求中,在一个table(组件)表中,对于其中一列(该列为图片列),当鼠标划过该列的某个单元格子(图片)时,需要展示出该单元格子对应的遮罩层 翻阅了一些博客,发现好多都提到了mouse事件,如mouseover.mouseout.mouseenter.mouseleave,在之后我自己也通过这种方法进行了尝试. <template> <el-table :data="tableData" stripe style="width: 100%&

Java中SSM框架实现增删改查功能代码详解

记录一下自己第一次整合smm框架的步骤. 参考博客和网站有:我没有三颗心脏 How2J学习网站 1.数据库使用的是mySql,首先创建数据库ssm1,并创建表student create database ssm1; use ssm1; CREATE TABLE student( id int(11) NOT NULL AUTO_INCREMENT, student_id int(11) NOT NULL UNIQUE, name varchar(255) NOT NULL, age int(1

java中的前++和后++的区别示例代码详解

java中的前加加++和后加加++,有很多人搞的很晕,不太明白!今天我举几个例子说明下前++和后++的区别! 其实大家只要记住一句话就可以了,前++是先自加再使用而后++是先使用再自加! 前++和后++总结:其实大家只要记住一句话就可以了,前++是先自加再使用而后++是先使用再自加! 请大家看下面的例子就明白了! public class Test { public static void main(String[] args) { //测试,前加加和后加加 //前++和后++总结:其实大家只要

如何在Spring Boot应用中优雅的使用Date和LocalDateTime的教程详解

Java8已经发布很多年了,但是很多人在开发时仍然坚持使用着Date和SimpleDateFormat进行时间操作.SimpleDateFormat不是线程安全的,而Date处理时间很麻烦,所以Java8提供了LocalDateTime.LocalDate和LocalTime等全新的时间操作API.无论是Date还是LocalDate,在开发Spring Boot应用时经常需要在每个实体类的日期字段上加上@DateTimeFormat注解来接收前端传值与日期字段绑定,加上@JsonFormat注