联通 SIGP 手机短信接口标准

客户端通过TCP连接到服务器(202.99.114.235:8020):
连接成功后客户端应首先发送注册串为:
Login Name=【注册名】&Pwd=【注册密码】&Type=【注册类型,0:接收和发送;1:接收;2:发送;默认为0】(回车换行)
如果所有服务注册成功,服务器返回给客户端字符串:
Pass(回车换行)
否则将断开连接。


指令集:
1:分发中心向服务方发送用户的短信请求,格式如下:


分发中心==>Deliver (空格)
CommandId=【命令标识,4字节整型,循环使用】
&GateName=【源网关名】
&ItemId=【节目标识】
&UserNumber=【用户号码】
&SpNumber=【服务号码,必须以9160开头】
&MsgCode=【短信编码,0:ASCII串;3:短信写卡操作;4:二进制信息;8:UCS2编码;15:含GB汉字;
24:UCS2编码闪电短信(Msg<=69个汉字),124:GBK编码闪电短信(Msg<=69个汉字)】
&Msg:=【短信内容,经加码处理,需解码】
(回车换行)


回应:Received CommandId=【对应于发送时的命令标识】(回车换行)


2:服务方向分发中心提交发送内容,格式如下:


服务方==>Submit (空格)
CommandId=【命令标识,4字节整型,循环使用】
&GateName=【目的网关名】,默认由分发中心根据手机号码决定目的网关名】
&ItemId=【节目标识】
&SpNumber=【服务号码,以9160开头】
&UserNumber=【目的用户号码,如果是群发将个号码之间用“,”隔开,注意最多只能有255个群发号码】
&FeeNumber=【计费号码,短信产生的费用由该号码承担,不填时默认向目的用户号码收费】
&FeeType=【计费类型,1:免费,需申请,2:按条计费,3:定制包月计费(同时要求ReportFlag=2)。默认:2】
&ScheduleTime=【定时发送时间,默认立即发送,格式举例:2002年09月10日20:08:00为:020910200800】
&ExpireTime=【短信寿命中止时间,格式举例:021201090508,默认为移动或联通(24小时后)中止时间】
&MtFlag=【*引起MT消息的原因,仅当向联通用户发短信时需要该参数,0-MO点播引起的第一条MT消息;1-MO点播引起的非第一条MT消息;
2-非MO点播引起的MT消息;3-系统反馈引起的MT消息。默认为0】
&ReportFlag=【状态报告标志,0:不需要 状态报告;1:无论成功与否都返回状态报告;2:该条消息仅携带包月计费信息,不下发给用户;
3:只有最后出错时要返回状态报告,默认:0】
注:在每次包月定制计费时都需发送一条内容为空串,ReportFlag=2,FeeType=3的记录,该短信不会下发给用户,仅用于告知网关向
该用户收取包月费用,在用户没有取消定制的情况下每月必须且只能发送一次。
&MsgCode=【短信编码,0:ASCII串;3:短信写卡操作;4:二进制信息;8:UCS2编码;15:含GB汉字;
24:UCS2编码闪电短信(Msg<=69个汉字),124:GBK编码闪电短信(Msg<=69个汉字),123:铃声图片,内容为<LS,手机类型,铃声代码>或<TP,手机类型,图片代码>】
&MsgId=【用户自定义消息标识,推荐格式:月日时分秒+6位自递增码,例如:9月23日10:00:03发出的序号为1记录可定义为
923100003000001。自定义格式最大不超过20个字符且不能有需加码解码的特殊字符】
&ExtData:=【短信扩展数据,服务方短信发送的附加信息,在有报告反馈时会连带该扩展数据反馈给服务方,需加码处理,但加码后不能超过
120个字节长度。默认为空串】
&TP_pId=【GSM协议类型。详细解释请参考GSM03.40中的9.2.3.9】
&TP_udhi=【GSM协议类型。详细解释请参考GSM03.40中的9.2.3.23,仅使用1位,右对齐】
&Msg:=【短信内容,需加码处理】
(回车换行)


回应:Received CommandId=【对应于发送时的命令标识】(回车换行)


3:分发中心向服务方发送报告,格式如下:


分发中心==>Report (空格)
CommandId=【命令标识,4字节整型,循环使用】
&GateName=【源网关名】
&MsgId=【服务方在Submit时写在MsgId参数中的值】
&ExtData=【服务方在Submit时写在ExtData参数中的值】
&State=【发送状态,0:向网关提交成功,1:向网关提交失败,2:发送成功,3:等待发送,4:发送失败,5:Submit参数错误】
(回车换行)


回应:Received CommandId=【对应于发送时的命令标识】(回车换行)
注:只要是报告发送失败请先找原因,不要再重发,只要有错无论重发多少次都是失败。


4:分发中心为了测试服务方是否连接,会在等待1分钟未收到任何数据发送测试指令,该指令也可由服务方主动发起:


分发中心或服务方==>ActiveTest CommandId=【命令标识,4字节整型,循环使用】(回车换行)


回应:Received CommandId=【对应于发送时的命令标识】(回车换行)


5:无论分发中心还是服务方,只要3分钟之内未收到任何数据要主动断开连接,对于服务方在断开后重新连接。


客户端通过HTTP连接到服务器(202.99.114.235:8030):
1:服务方向分发中心提交发送内容,格式如下:


服务方==>http://202.99.114.235:8030/Submit (空格)
CommandId=【命令标识,4字节整型,循环使用】
&Name=【注册名】
&Pwd=【注册密码】
&GateName=【目的网关名】,默认由分发中心根据手机号码决定目的网关名】
&ItemId=【节目标识】
&SpNumber=【服务号码,以9160开头】
&UserNumber=【目的用户号码,如果是群发将个号码之间用“,”隔开,注意最多只能有255个群发号码】
&FeeNumber=【计费号码,短信产生的费用由该号码承担,不填时默认向目的用户号码收费】
&FeeType=【计费类型,1:免费,需申请,2:按条计费,3:定制包月计费(同时要求ReportFlag=2)。默认:2】
&ScheduleTime=【定时发送时间,默认立即发送,格式举例:2002年09月10日20:08:00为:020910200800】
&ExpireTime=【短信寿命中止时间,格式举例:021201090508,默认为移动或联通(24小时后)中止时间】
&MtFlag=【*引起MT消息的原因,仅当向联通用户发短信时需要该参数,0-MO点播引起的第一条MT消息;1-MO点播引起的非第一条MT消息;
2-非MO点播引起的MT消息;3-系统反馈引起的MT消息。默认为0】
&ReportFlag=【状态报告标志,0:不需要 状态报告;1:无论成功与否都返回状态报告;2:该条消息仅携带包月计费信息,不下发给用户;
3:只有最后出错时要返回状态报告,默认:0】
注:在每次包月定制计费时都需发送一条内容为空串,ReportFlag=2,FeeType=3的记录,该短信不会下发给用户,仅用于告知网关向
该用户收取包月费用,在用户没有取消定制的情况下每月必须且只能发送一次。
&MsgCode=【短信编码,0:ASCII串;3:短信写卡操作;4:二进制信息;8:UCS2编码;15:含GB汉字;
24:UCS2编码闪电短信(Msg<=69个汉字),124:GBK编码闪电短信(Msg<=69个汉字),123:铃声图片,内容为<LS,手机类型,铃声代码>或<TP,手机类型,图片代码>】
&MsgId=【用户自定义消息标识,推荐格式:年月日时分秒+6位自递增码,例如:9月23日10:00:03发出的序号为1记录可定义为
923100003000001。自定义格式最大不超过20个字符且不能有需加码解码的特殊字符】
&ExtData:=【短信扩展数据,服务方短信发送的附加信息,在有报告反馈时会连带该扩展数据反馈给服务方,需加码处理,但加码后不能超过
120个字节长度。默认为空串】
&TP_pId=【GSM协议类型。详细解释请参考GSM03.40中的9.2.3.9】
&TP_udhi=【GSM协议类型。详细解释请参考GSM03.40中的9.2.3.23,仅使用1位,右对齐】
&Msg:=【短信内容,需加码处理】
(回车换行)


回应:Received CommandId=【对应于发送时的命令标识】(回车换行)


2:接收短信
分发中心==>【服务方HTTP链接地址】?
Command=deliver【该指令表示接收到用户短信】
&CommandId=【命令标识,4字节整型,循环使用】
&GateName=【源网关名】
&ItemId=【节目标识】
&UserNumber=【用户号码】
&SpNumber=【服务号码,必须以9160开头】
&MsgCode=【短信编码,0:ASCII串;3:短信写卡操作;4:二进制信息;8:UCS2编码;15:含GB汉字;
24:UCS2编码闪电短信(Msg<=69个汉字),124:GBK编码闪电短信(Msg<=69个汉字)】
&Msg:=【短信内容,经加码处理,需解码】
(回车换行)


回应:Received CommandId=【对应于发送时的命令标识】(回车换行)


3:分发中心向服务方发送报告,格式如下:


分发中心==>【服务方HTTP链接地址】?
Command=report 
&CommandId=【命令标识,4字节整型,循环使用】
&GateName=【源网关名】
&MsgId=【服务方在Submit时写在MsgId参数中的值】
&ExtData=【服务方在Submit时写在ExtData参数中的值】
&State=【发送状态,0:向网关提交成功,1:向网关提交失败,2:发送成功,3:等待发送,4:发送失败,5:Submit参数错误】
(回车换行)


回应:Received CommandId=【对应于发送时的命令标识】(回车换行)
注:只要是报告发送失败请先找原因,不要再重发,只要有错无论重发多少次都是失败。


加码解码规则:
加码时将字符串中的所有字符转换成其对应的ASCII值的16进制值,例如:“A”的ASCII码值为65,以16进制值表示为41,故应发送两个字符
“41”以代表字符“A”。对于汉字则以其内码的16进制值来表示,如“测试”应为:B2E2CAD4。参数中只要参数标识与内容之间用
“:=”连接的都需要解码后方可使用,解码时将没两位当成其ASCII值的16进制值将其还原。


注: 
1、命令和回应并非一个命令完了后紧接者就回应,服务方可一次发出许多条指令,可能在若干条后才陆续收到回应,根据“Received”的
“CommandId”可知道是对于哪一条发出指令的回应。
2、指令和参数标识不区分大小写,但各参数内容区分大小写。
3、不需要的参数可不参与发送,此时系统认为该参数值为系统默认值。同时所有参数的位置并不固定,请不要按照位置获取特定参数值。
4、信息发送方对于参数如果进行过加码处理的其参数标识和参数之间用“:=”连接,否则用“=”连接。同样对于接收方,只要发现参数标识和
参数之间用“:=”连接,接收方必须对参数内容进行解码方可使用。
5、当注册类型为发送,回应内容也是从该通道反馈,但报告的反馈是从同注册名的接收注册通道反馈的。
6、新网关测试需向鸿讯要求提供测试的注册名和密码。
7、Http接收短信要求提供接收的链接地址。
8、Http接收和发送的流量无法提供很大,因此需求流量大且要求即时发送时建议选用Tcp协议连接。
9、包月计费信息在Submit时要求必须ReportFlag=2,FeeType=3。
10、对于向联通用户的Submit参数MtFlag必须填写。对于移动用户即时填写了参数MtFlag也会被忽略。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
浙江联通短信接口使用说明 一、通过 http://www.sms1688.com/ 申请开户 浙江省内各地还可通过相应的二级域名申请,如 nb.sms1688.com jh.sms1688.com 二、安装数据库服务器 Oracle SQLServer 或 Sybase 已装的可略过本步。 三、生成数据库 通过“数据库生成语句”文件夹里的一条语句来生成你的相应版本的数据库如要使用Access可先生成SQLServer的数据库,然后通过SQLServer的DTS服务导出一个Access的mdb文件,然后将SMSSocket.ini配置成dsn模式,在ODBC中创建相应的DSN(配置见四)。另外本人提供了一个SQLServer2005版的数据库,你可以直接附加到你的SQLServer2005里。 四、配置文件修改,具体内容请打开SMSSocket.ini查看,已做详细备注。 五、测试,请双击 测试.bat进行测试,若测试成功则会显示成功,不成功会显示相应用的错误信息,这是命令行界面的。 六、安装服务,测试成功后可点击 安装服务.bat安装服务。服务以windows服务方式运行,重启后仍会有效。 七、发信,直接在你的应用程序里面向数据库的sms_send表里插入数据,服务程序就会自动发送短信,表内各字段具体含义请参见“浙江联通行业应用短信平台二次开发接口使用手册.doc” 八、若要关闭服务,请执行卸载服务.bat。 九、本程序为绿色版本,放在任何目录里执行都是一样的。 十、本程序可以发短信联通、移动、电信三家的运营商的手机,费率为联通8分一条,其他10分一条,是否可在开通接口时与联通议价暂不知道。 十一、SmsNbClient文件夹里的内容不是接口的一部分,是发短信的客户端软件,当是第一步完成后的测试工具好了。 十二、又臭又长的说明请参见联通官方的“浙江联通行业应用短信平台二次开发接口使用手册.doc” 十三、个人主页www.fatsot.net欢迎交流。 小胖2010-1-14
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值