CMPP协议的全称是中国移动通信互联网短信网关接口协议,它是联想亚信公司根据SMMP协议为中国移动量身定做的,是符合中国国情的一个短信协议,闲话不多说了,说说CMPP的主要功能吧。(1)短信发送(short message mobile originate)MO,就是手机给SP发短信;(2)短信接受(short message mobile terminated)MT,这个就是SP给手机发的短信了,通常我们手机上收到的不良短信就是SP给我们的MT。CMPP协议的通信基础是TCP/IP为底层通信承载的,连接方式是长连接方式。SP与ISMG之间,SMSC和ISMG之间的交互过程中均采用异步方式,即任一个网元在收到请求消息后应立即回应。
下面看看它的消息定义:CMPP中的消息分为消息头和消息体。消息头定义如下
字段名 |
字节数 |
类型 |
描述 |
Total_Length |
4 |
Unsigned Integer |
消息总长度(含消息头及消息体) |
Command_Id |
4 |
Unsigned Integer |
命令或响应类型 |
Sequence_Id |
4 |
Unsigned Integer |
消息流水号,顺序累加,步长为1,循环使用(一对请求和应答消息的流水号必须相同) |
那么下面就是SP连接到ISMG上了,看它的Bind连接消息定义
字段名 |
字节数 |
属性 |
描述 |
Source_Addr |
6 |
Octet String |
源地址,此处为SP_Id,即SP的企业代码。 |
AuthenticatorSource |
16 |
Octet String |
用于鉴别源地址。其值通过单向MD5 hash计算得出,表示如下:
AuthenticatorSource =
MD5(Source_Addr+9 字节的0 +shared secret+timestamp)
Shared secret 由中国移动与源地址实体事先商定,timestamp格式为:MMDDHHMMSS,即月日时分秒,10位。 |
Version |
1 |
Unsigned Integer |
双方协商的版本号(高位4bit表示主版本号,低位4bit表示次版本号),对于3.0的版本,高4bit为3,低4位为0 |
Timestamp |
4 |
Unsigned Integer |
时间戳的明文,由客户端产生,格式为MMDDHHMMSS,即月日时分秒,10位数字的整型,右对齐 。 |
根据上的定义我们可以写出的代码,如下,在VC环境下编写的
/*
*函数功能:建立和CMPP网关的直接通路
*输入条件:SP用户名const char *UserName,SP密码const char *PWD
*/
void Ccmpp_API::CmppConnect(const char *UserName, const char *PWD)
{
char netbuf[100];
CMPP_CONNECT *bufer;
bufer=(CMPP_CONNECT*)netbuf;
memset(bufer, 0, 100);
bufer->nTotalLength = htonl(39);//CMPP_CONNECT消息总长度
bufer->nCommandId = htonl(CMPP_CONNECT_tag);//消息标志
//自动产生SeqId号
if (sequenceid == 123456789i32)
{
sequenceid = 1;
}else{
sequenceid++;
}
bufer->nSeqId = htonl(sequenceid);
int MD5Len;
MD5_CTX md5;//MD5源字串
CTime TimeData = CTime::GetCurrentTime();
CString timestamp = TimeData.Format("%m%d%H%M%S");
unsigned char md5source[29];
int Len1 = strlen(UserName);
int Len2 = strlen(PWD);
MD5Len = Len1 + 9 +Len2 + timestamp.GetLength();
memset(md5source, 0, MD5Len);
memcpy(bufer->sSourceAddr, UserName, Len1);
memcpy(md5source, UserName, Len1);
for (int j = 0; j<Len2; j++)
{
md5source[j + Len1 + 9] = PWD[j];
}
for (int i=0;i<timestamp.GetLength();i++)
{
md5source[i + Len2 + Len1 + 9]=timestamp[i];
}
//进行md5加密转换
md5.MD5Update(md5source, MD5Len);
md5.MD5Final(md5source);
memcpy(bufer->sAuthSource, md5source, 29);
bufer->cVersion = 0x30;
bufer->nTimeStamp = htonl(atoi(timestamp));
CmppSocket.Send(bufer, 39, 0);//把消息打包发送
return;
}
今天就到这,下次再写,欢迎交流!
posted on 2006-03-15 07:58
炙热的太阳 阅读(38)
评论(2) 编辑 收藏 收藏至365Key