中国移动MM7 API用户手册(八)
4.6 发送取消消息(下行业务)
当VASP发送MM7SubmitReq消息给MMSC成功后,VASP可以发送取消消息,以取消之前所发送给MMSC的消息。具体构建取消消息见4.2.2.2。
package com.cmcc.mm7.vasp.conf;
import com.cmcc.mm7.vasp.message.*;
import com.cmcc.mm7.vasp.service.MM7Sender;
import com.cmcc.mm7.vasp.common.*;
import java.io.*;
public class VaspSendTest {
public static void main(String[] args) {
MM7Config mm7Config = new MM7Config("../config/mm7Config.xml");
//设置ConnConfig.xml文件的路径
mm7Config.setConnConfigName(“../config/ConnConfig.xml”);
MM7Sender mm7Sender = new MM7Sender(mm7Config);
MM7CancelReq cancelReq = new MM7CancelReq();
cancel.setTransactionID("关联标识");
//从MM7SubmitRes中获得MessageID
cancelReq.setMesageID(“待取消的消息的标识符”);
MM7RSRes res = mm7Sender.send(cancelReq);
System.out.println("res.statuscode=" + res.getStatusCode() +
";res.statusText=" + res.getStatusText());
}
}
4.7 发送替换消息(下行业务)
当VASP发送MM7SubmitReq消息给MMSC成功后,VASP可以发送替换消息,以替换之前所发送给MMSC的消息。具体构建替换消息见4.2.2.3。
package com.cmcc.mm7.vasp.conf;
import com.cmcc.mm7.vasp.message.*;
import com.cmcc.mm7.vasp.service.MM7Sender;
import com.cmcc.mm7.vasp.common.*;
import java.io.*;
public class VaspSendTest {
public static void main(String[] args) {
MM7Config mm7Config = new MM7Config("./config/mm7Config.xml");
//设置ConnConfig.xml文件的路径
mm7Config.setConnConfigName(“./config/ConnConfig.xml”);
MM7Sender mm7Sender = new MM7Sender(mm7Config);
MM7ReplaceReq replace = new MM7ReplaceReq();
replace.setTransactionID("关联标识");
//从MM7SubmitRes中获得MessageID
replace.setMessageID("被当前消息所替换的消息的标识符");
//创建消息内容体
MMContent content = new MMContent();
content.setContentType(MMConstants.ContentType.MULTIPART_MIXED);
MMContent sub1 = MMContent.createFromString("This is a test11");
sub1.setContentID("1.txt");
content.addSubContent(sub1);
MMContent sub2 = MMContent.createFromString("This is a Test22");
sub2.setContentID("2.txt");
content.addSubContent(sub2);
replace.setContent(content);
MM7RSRes res = mm7Sender.send(replace);
System.out.println("res.statuscode=" + res.getStatusCode() +
";res.statusText=" + res.getStatusText());
}
}
5.开发过程中需用的一些Status解释
5.1 关于VASP接收到消息后设置返回响应(Res)的状态码及状态报告的解释
当VASP收到MMSC发送过来的DeliverReq、DeliverReportReq、ReadReplyReq时,可以经过判断后,返回给MMSC一个状态码和状态描述,可以返回的StatusCode和StatusText分别如下:
1000 : 成功;
1001 : 部分成功;
2000 : 客户机错误;
2001 : 操作受限;
2002 : 地址错误;
2003 : 找不到地址;
2004 : 多媒体内容被拒绝;
2005 : 找不到消息ID;
2006 : 找不到链接ID;
2007 : 消息格式破坏;
3000 : 服务器错误;
3001 : 不可接受;
3002 : 消息被拒绝;
3003 : 不支持多个地址;
4000 : 一般服务错误;
4001 : 标识不正确;
4002 : 版本不支持;
4003 : 操作不支持;
4004 : 验证错误;
4005 : 服务错误;
4006 : 无法提供服务;
4007 : 服务被拒绝;
5.2 关于VASP收到DeliverReq中MMStatus的解释
VASP收到DeliverReq消息后,其中有个MMStatus字段值,是个byte型,因此说明一下具体数字所表示的含义:
0 :过期;
1 :接收;
2 :系统拒绝;
3 :用户拒绝;
4 :未知;
5 :转发;
5.3 关于VASP收到ReadReplyReq中ReadStatus的解释
VASP收到ReadReplyReq消息后,其中有个ReadStatus字段值,是个byte型,因此说明一下具体数字所表示的含义:
0 :已读取;
1 :未读被删;
2 :未知;
6.获取MM7 API版本信息的方法
VASP要想获得自己当前使用的API的版本号,首先在环境变量中设置mm7api.jar包存放的路径,然后点击开始菜单的运行,输入cmd进入Dos 窗口,敲命令:
E:\> java com.cmcc.mm7.vasp.common.RetriveApiVersion 回车
可以看到打印信息如下:
当前使用的MM7 API的版本为:V1.5.1_20040512
7. MM7 API返回StatusCode说明
-100:系统错误;
-101:超时发送失败;
-102:接收失败;
-103:I/O错误;
-104:Socket不通;
-105:待发送的消息为空;
-106:发送消息不正确;
-107:接收消息为空;
-108:Bad Request;
-109:XML解析错误;