最近有个需求,不去调用系统界面发送彩信功能。做过发送短信功能的同学可能第一反应是这样:
不使用 StartActivity,像发短信那样,调用一个类似于发短信的方法
SmsManager smsManager = SmsManager.getDefault();
smsManager.sendTextMessage(phoneCode, null, text, null, null);
可以实现吗? 答案是否定的,因为Android上根本就没有提供发送彩信的接口,如果你想发送彩信,对不起,请调用系统彩信app界面,如下:
Java代码
1. Intent sendIntent = new Intent(Intent.ACTION_SEND, Uri.parse("mms://"));
2.sendIntent.setType("image/jpeg");
3.String url = "file://sdcard//tmpPhoto.jpg";
4.sendIntent.putExtra(Intent.EXTRA_STREAM, Uri.parse(url));
5.startActivity(Intent.createChooser(sendIntent, "MMS:"));
但是这种方法往往不能满足我们的需求,能不能不调用系统界面,自己实现发送彩信呢?经过几天的努力,终于找到了解决办法。
第一步:先构造出你要发送的彩信内容,即构建一个pdu,需要用到以下几个类,这些类都是从Android源码的MMS应用中mms.pdu包中copy出来的。你需要将pdu包中的所有类
都拷贝到你的工程中,然后自己酌情调通。
Java代码 1. final SendReq sendRequest = new SendReq();
2. final PduBody pduBody = new PduBody();
3.final PduPart part = new PduPart();//存放附件,每个附件是一个part,如果添加多个附件,就想body中add多个part。
4.
5. pduBody.addPart(partPdu);
6. sendRequest.setBody(pduBody);
7. final PduComposer composer = new PduComposer(ctx, sendRequest);
8.final byte[] bytesToSend = composer.make(); //将彩信的内容以及主题等信息转化成byte数组,准备通过http协议//发送到 ”http://mmsc.monternet.com”;
第二步:发送彩信到彩信中心。
构建pdu的代码:
Java代码 1. String subject = "测试彩信";
2. String recipient = "接收彩信的号码";//138xxxxxxx
3. final SendReq sendRequest = new SendReq();
4. final EncodedStringValue[] sub = EncodedStringValue.extract(subject);
5. if (sub != null && sub.length > 0) {
6. sendRequest.setSubject(sub[0]);
7. }
8. final EncodedStringValue[] phoneNumbers = EncodedStringValue.extract(recipient);
9. if (phoneNumbers != null && phoneNumbers.length > 0) {
10. sendRequest.addTo(phoneNumbers[0]);
11. }
12. final PduBody pduBody = new PduBody();
13. final PduPart part = new PduPart();
14. part.setName("sample".getBytes());
15. part.setContentType("image/png".getBytes());
16. String furl = "file://mnt/sdcard//1.jpg";
17.
18. final PduPart partPdu = new PduPart();
19. partPdu.setCharset(CharacterSets.UTF_8);//UTF_16
20. partPdu.setName(part.getName());
21. partPdu.setContentType(part.getContentType());
22. partPdu.setDataUri(Uri.parse(furl));
23. pduBody.addPart(partPdu);
24.
25. sendRequest.setBody(pduBody);
26. final PduComposer composer = new PduComposer(ctx, sendRequest);
27. final byte[] bytesToSend = composer.make();
28.
29. Thread t = new Thread(new Runnable() {
30.
31. @Override
32. public void run() {
33. try {
34. HttpConnectInterface.sendMMS(ctx, bytesToSend);
35.//
36. } catch (IOException e) {
37. e.printStackTrace();
38. }
39. }
40. });
41. t.start();
42.发送pdu到彩信中心的代码:
43. public static String mmscUrl = "http://mmsc.monternet.com";
44.// public static String mmscUrl = "http://www.baidu.com/";
45. public static String mmsProxy = "10.0.0.172";
46. public static String mmsProt = "80";
47.
48. private static String HDR_VALUE_ACCEPT_LANGUAGE = "";
49. // Definition for necessary HTTP headers.
50. private static final String HDR_KEY_ACCEPT = "Accept";
51. private static final String HDR_KEY_ACCEPT_LANGUAGE = "Accept-Language";
52.
53. private static final String HDR_VALUE_ACCEPT =
54. "*/*, application/vnd.wap.mms-message, application/vnd.wap.sic";
55.public static byte[] sendMMS(Context context, byte[] pdu)throws IOException{
56. HDR_VALUE_ACCEPT_LANGUAGE = getHttpAcceptLanguage();
57.
58. if (mmscUrl == null) {
59. throw new IllegalArgumentException("URL must not be null.");
60. }
61.
62. HttpClient client = null;
63. try {
64. // Make sure to use a proxy which supports CONNECT.
65. client = HttpConnector.buileClient(context);
66. HttpPost post = new HttpPost(mmscUrl);
67. //mms PUD START
68. ByteArrayEntity entity = new ByteArrayEntity(pdu);
69. entity.setContentType("application/vnd.wap.mms-message");
70. post.setEntity(entity);
71. post.addHeader(HDR_KEY_ACCEPT, HDR_VALUE_ACCEPT);
72. post.addHeader(HDR_KEY_ACCEPT_LANGUAGE, HDR_VALUE_ACCEPT_LANGUAGE);
73. //mms PUD END
74. HttpParams params = client.getParams();
75. HttpProtocolParams.setContentCharset(params, "UTF-8");
76. HttpResponse response = client.execute(post);
77.
78. LogUtility.showLog(tag, "111");
79. StatusLine status = response.getStatusLine();
80. LogUtility.showLog(tag, "status "+status.getStatusCode());
81. if (status.getStatusCode() != 200) { // HTTP 200 is not success.
82. LogUtility.showLog(tag, "!200");
83. throw new IOException("HTTP error: " + status.getReasonPhrase());
84. }
85. HttpEntity resentity = response.getEntity();
86. byte[] body = null;
87. if (resentity != null) {
88. try {
89. if (resentity.getContentLength() > 0) {
90. body = new byte[(int) resentity.getContentLength()];
91. DataInputStream dis = new DataInputStream(resentity.getContent());
92. try {
93. dis.readFully(body);
94. } finally {
95. try {
96. dis.close();
97. } catch (IOException e) {
98. Log.e(tag, "Error closing input stream: " + e.getMessage());
99. }
100. }
101. }
102. } finally {
103. if (entity != null) {
104. entity.consumeContent();
105. }
106. }
107. }
108. LogUtility.showLog(tag, "result:"+new String(body));
109. return body;
110. } catch (IllegalStateException e) {
111. LogUtility.showLog(tag, "",e);
112.// handleHttpConnectionException(e, mmscUrl);
113. } catch (IllegalArgumentException e) {
114. LogUtility.showLog(tag, "",e);
115.// handleHttpConnectionException(e, mmscUrl);
116. } catch (SocketException e) {
117. LogUtility.showLog(tag, "",e);
118.// handleHttpConnectionException(e, mmscUrl);
119. } catch (Exception e) {
120. LogUtility.showLog(tag, "",e);
121. //handleHttpConnectionException(e, mmscUrl);
122. } finally {
123. if (client != null) {
124.// client.;
125. }
126. }
127. return new byte[0];
128. }
至此,彩信的发送算是完成了。
总结:Android的彩信相关操作都是没有api的,包括彩信的读取、发送、存储。这些过程都是需要手动去完成的。想要弄懂这些过程,需要仔细阅读android源码中的mms这个app。还有就是去研究mmssms.db数据库,因为彩信的读取和存储其实都是对mmssms.db这个数据库的操作过程。而且因为这个是共享的数据库,所以只能用ContentProvider这个组件去操作db。
总之,想要研究彩信这块(包括普通短信),你就必须的研究mmssms.db的操作方法,多多了解每个表对应的哪个uri,每个uri能提供什么样的操作,那些字段代表短信的那些属性等。
最后推荐个好用的sqlite查看工具:SQLite Database Browser。
本篇文章来源于 Linux公社网站(www.linuxidc.com) 原文链接:http://www.linuxidc.com/Linux/2011-08/41609.htm
不使用 StartActivity,像发短信那样,调用一个类似于发短信的方法
SmsManager smsManager = SmsManager.getDefault();
smsManager.sendTextMessage(phoneCode, null, text, null, null);
可以实现吗? 答案是否定的,因为Android上根本就没有提供发送彩信的接口,如果你想发送彩信,对不起,请调用系统彩信app界面,如下:
Java代码
1. Intent sendIntent = new Intent(Intent.ACTION_SEND, Uri.parse("mms://"));
2.sendIntent.setType("image/jpeg");
3.String url = "file://sdcard//tmpPhoto.jpg";
4.sendIntent.putExtra(Intent.EXTRA_STREAM, Uri.parse(url));
5.startActivity(Intent.createChooser(sendIntent, "MMS:"));
但是这种方法往往不能满足我们的需求,能不能不调用系统界面,自己实现发送彩信呢?经过几天的努力,终于找到了解决办法。
第一步:先构造出你要发送的彩信内容,即构建一个pdu,需要用到以下几个类,这些类都是从Android源码的MMS应用中mms.pdu包中copy出来的。你需要将pdu包中的所有类
都拷贝到你的工程中,然后自己酌情调通。
Java代码 1. final SendReq sendRequest = new SendReq();
2. final PduBody pduBody = new PduBody();
3.final PduPart part = new PduPart();//存放附件,每个附件是一个part,如果添加多个附件,就想body中add多个part。
4.
5. pduBody.addPart(partPdu);
6. sendRequest.setBody(pduBody);
7. final PduComposer composer = new PduComposer(ctx, sendRequest);
8.final byte[] bytesToSend = composer.make(); //将彩信的内容以及主题等信息转化成byte数组,准备通过http协议//发送到 ”http://mmsc.monternet.com”;
第二步:发送彩信到彩信中心。
构建pdu的代码:
Java代码 1. String subject = "测试彩信";
2. String recipient = "接收彩信的号码";//138xxxxxxx
3. final SendReq sendRequest = new SendReq();
4. final EncodedStringValue[] sub = EncodedStringValue.extract(subject);
5. if (sub != null && sub.length > 0) {
6. sendRequest.setSubject(sub[0]);
7. }
8. final EncodedStringValue[] phoneNumbers = EncodedStringValue.extract(recipient);
9. if (phoneNumbers != null && phoneNumbers.length > 0) {
10. sendRequest.addTo(phoneNumbers[0]);
11. }
12. final PduBody pduBody = new PduBody();
13. final PduPart part = new PduPart();
14. part.setName("sample".getBytes());
15. part.setContentType("image/png".getBytes());
16. String furl = "file://mnt/sdcard//1.jpg";
17.
18. final PduPart partPdu = new PduPart();
19. partPdu.setCharset(CharacterSets.UTF_8);//UTF_16
20. partPdu.setName(part.getName());
21. partPdu.setContentType(part.getContentType());
22. partPdu.setDataUri(Uri.parse(furl));
23. pduBody.addPart(partPdu);
24.
25. sendRequest.setBody(pduBody);
26. final PduComposer composer = new PduComposer(ctx, sendRequest);
27. final byte[] bytesToSend = composer.make();
28.
29. Thread t = new Thread(new Runnable() {
30.
31. @Override
32. public void run() {
33. try {
34. HttpConnectInterface.sendMMS(ctx, bytesToSend);
35.//
36. } catch (IOException e) {
37. e.printStackTrace();
38. }
39. }
40. });
41. t.start();
42.发送pdu到彩信中心的代码:
43. public static String mmscUrl = "http://mmsc.monternet.com";
44.// public static String mmscUrl = "http://www.baidu.com/";
45. public static String mmsProxy = "10.0.0.172";
46. public static String mmsProt = "80";
47.
48. private static String HDR_VALUE_ACCEPT_LANGUAGE = "";
49. // Definition for necessary HTTP headers.
50. private static final String HDR_KEY_ACCEPT = "Accept";
51. private static final String HDR_KEY_ACCEPT_LANGUAGE = "Accept-Language";
52.
53. private static final String HDR_VALUE_ACCEPT =
54. "*/*, application/vnd.wap.mms-message, application/vnd.wap.sic";
55.public static byte[] sendMMS(Context context, byte[] pdu)throws IOException{
56. HDR_VALUE_ACCEPT_LANGUAGE = getHttpAcceptLanguage();
57.
58. if (mmscUrl == null) {
59. throw new IllegalArgumentException("URL must not be null.");
60. }
61.
62. HttpClient client = null;
63. try {
64. // Make sure to use a proxy which supports CONNECT.
65. client = HttpConnector.buileClient(context);
66. HttpPost post = new HttpPost(mmscUrl);
67. //mms PUD START
68. ByteArrayEntity entity = new ByteArrayEntity(pdu);
69. entity.setContentType("application/vnd.wap.mms-message");
70. post.setEntity(entity);
71. post.addHeader(HDR_KEY_ACCEPT, HDR_VALUE_ACCEPT);
72. post.addHeader(HDR_KEY_ACCEPT_LANGUAGE, HDR_VALUE_ACCEPT_LANGUAGE);
73. //mms PUD END
74. HttpParams params = client.getParams();
75. HttpProtocolParams.setContentCharset(params, "UTF-8");
76. HttpResponse response = client.execute(post);
77.
78. LogUtility.showLog(tag, "111");
79. StatusLine status = response.getStatusLine();
80. LogUtility.showLog(tag, "status "+status.getStatusCode());
81. if (status.getStatusCode() != 200) { // HTTP 200 is not success.
82. LogUtility.showLog(tag, "!200");
83. throw new IOException("HTTP error: " + status.getReasonPhrase());
84. }
85. HttpEntity resentity = response.getEntity();
86. byte[] body = null;
87. if (resentity != null) {
88. try {
89. if (resentity.getContentLength() > 0) {
90. body = new byte[(int) resentity.getContentLength()];
91. DataInputStream dis = new DataInputStream(resentity.getContent());
92. try {
93. dis.readFully(body);
94. } finally {
95. try {
96. dis.close();
97. } catch (IOException e) {
98. Log.e(tag, "Error closing input stream: " + e.getMessage());
99. }
100. }
101. }
102. } finally {
103. if (entity != null) {
104. entity.consumeContent();
105. }
106. }
107. }
108. LogUtility.showLog(tag, "result:"+new String(body));
109. return body;
110. } catch (IllegalStateException e) {
111. LogUtility.showLog(tag, "",e);
112.// handleHttpConnectionException(e, mmscUrl);
113. } catch (IllegalArgumentException e) {
114. LogUtility.showLog(tag, "",e);
115.// handleHttpConnectionException(e, mmscUrl);
116. } catch (SocketException e) {
117. LogUtility.showLog(tag, "",e);
118.// handleHttpConnectionException(e, mmscUrl);
119. } catch (Exception e) {
120. LogUtility.showLog(tag, "",e);
121. //handleHttpConnectionException(e, mmscUrl);
122. } finally {
123. if (client != null) {
124.// client.;
125. }
126. }
127. return new byte[0];
128. }
至此,彩信的发送算是完成了。
总结:Android的彩信相关操作都是没有api的,包括彩信的读取、发送、存储。这些过程都是需要手动去完成的。想要弄懂这些过程,需要仔细阅读android源码中的mms这个app。还有就是去研究mmssms.db数据库,因为彩信的读取和存储其实都是对mmssms.db这个数据库的操作过程。而且因为这个是共享的数据库,所以只能用ContentProvider这个组件去操作db。
总之,想要研究彩信这块(包括普通短信),你就必须的研究mmssms.db的操作方法,多多了解每个表对应的哪个uri,每个uri能提供什么样的操作,那些字段代表短信的那些属性等。
最后推荐个好用的sqlite查看工具:SQLite Database Browser。
本篇文章来源于 Linux公社网站(www.linuxidc.com) 原文链接:http://www.linuxidc.com/Linux/2011-08/41609.htm
相关推荐
"Comsol完美吸收器:可见光薄膜与金环宽带吸收器的二维斜入射研究",Comsol完美吸收器。 包含可见光薄膜完美吸收器,涉及二维斜入射。 包含金环宽带完美吸收器。 ,Comsol完美吸收器; 可见光薄膜完美吸收器; 二维斜入射; 金环宽带完美吸收器,"Comsol二维斜入射完美吸收器:可见光薄膜与金环宽带吸收技术"
免费JAVA毕业设计 2024成品源码+论文+数据库+启动教程 启动教程:https://www.bilibili.com/video/BV1SzbFe7EGZ 项目讲解视频:https://www.bilibili.com/video/BV1Tb421n72S 二次开发教程:https://www.bilibili.com/video/BV18i421i7Dx
,西门子S7-200smart型PLC使用profinet通讯控制G120变频器程序, 可以实现速度设定与读取,启停和故障复位等功能。
免费JAVA毕业设计 2024成品源码+论文+数据库+启动教程 启动教程:https://www.bilibili.com/video/BV1SzbFe7EGZ 项目讲解视频:https://www.bilibili.com/video/BV1Tb421n72S 二次开发教程:https://www.bilibili.com/video/BV18i421i7Dx
,大众斯柯达 免玻璃车道保持新方案
基于PFC5.0的岩石循环加卸载试验的3D实现技术,PFC5.0 3D实现岩石的循环加卸载试验, ,PFC5.0; 3D岩石; 循环加卸载试验; 岩石循环; 岩石加卸载模拟,"PFC5.0三维岩石循环加卸载试验研究"
nodejs010-nodejs-boom-0.4.2-2.el6.centos.alt.noarch.rpm
小学元旦晚会PPT 模版
STEP7-MicroWIN-SMART-V3.0测试版(2025.02最新)安装包-链接地址
内容概要:卷积神经网络(CNN)是一种特殊的神经网络模型,尤其适用于处理图像类的任务,如检测任务、分类与检索、超分辨率重构、医学任务、无人驾驶、人脸识别等。与传统神经网络输入一组向量值不同,CNN能够接受更为复杂的三维输入(深度、高度、宽度),从而有效地降低输入参数量并提高图像处理效率。文中介绍了卷积操作的基本原理及其在图像中的运用,例如通过设置合适的卷积核大小、步幅和零填充等手段,控制特征图的数量和尺度,进而达到优化网络性能的目的。此外还提及了卷积参数共享的概念以及池化层的作用。经典案例包括了AlexNet、VGG网路和残差网络的设计思想和结构特性,尤其是残差网络解决了非常深网络难以训练的问题,并提升了模型的表现力。感受野的介绍则强调了深层网络中的局部感知的重要性。 适合人群:从事计算机视觉领域的研究人员和技术人员,特别是关注图像识别和高级图像处理的研究人员或开发者。 使用场景及目标:①理解并掌握CNN的基本组成单元,如卷积层、池化层的工作机制;②深入探讨经典CNN架构背后的思路及其应用场景,帮助读者提升模型构建能力,以便更好地应用于实际项目中。
nodejs010-1.2-29.el6.centos.alt.x86_64.rpm
COMSOL注浆技术:浆液扩散模型及其应用研究,comsol注浆,浆液扩散模型 ,comsol注浆; 浆液扩散模型,"Comsol注浆技术下的浆液扩散模型研究"
"Modbus全功能调试工具:RTU、ASCII支持,主站调试必备,界面简洁易操作,数据记录与转换,串口助手功能齐备,自动应答及批量连续发送功能强大,学习测试必备利器",MobbusRTU ModbusASCII Modbus调试工具Modbus主站调试工具ModbusMaster支持所有Modbus设备调试; 功能强大,是学习测试的必备工具; 1.界面简洁 2.数据记录功能 3.串口助手功能 4.数据转功能 5.自动应答功能 5.批量发送功能 6.连续发送功能 ,ModbusRTU; ModbusASCII; 调试工具; 主站调试工具; ModbusMaster; 全部设备调试; 功能强大; 界面简洁; 数据记录; 串口助手; 数据转换; 自动应答; 批量发送; 连续发送。,"多功能Modbus调试工具:支持RTU/ASCII,主站必备,功能全面,操作简洁"
一个使用 C++ 结合 DeepSeek 模型进行文本相似度计算的源码。该实例会接收两段文本,借助 DeepSeek 模型提取文本特征,然后通过余弦相似度来衡量两段文本的相似程度。
内容概要:本文详细介绍了传统RNN网络存在的问题及其局限性,进而引出了Transformer模型的核心优势及其结构原理。传统RNN由于串行计算和无法有效处理长距离依赖等问题限制了其应用效果,尤其在自然语言处理领域表现不佳。相比之下,Transformer通过引入自注意力机制(self-attention mechanism)和平行化的架构解决了这些问题。自注意力机制允许模型在同一时间处理完整的输入序列,在计算每个位置的表征时不仅考虑到该位置的元素也综合了其他所有位置的相关度。此外,文章还具体讲解了多头注意力机制(multi-head attention),以及为何引入多头能够捕获更为丰富的语义特征;位置编码(positional encoding)的作用是为了赋予模型区分相同字符在不同顺序组合的意义能力;并在末尾提到了BERT这一基于Transformer的预训练模型及其两种主要训练方式——掩码语言模型(masked language model)和下一个句子预测(next sentence prediction)。总体而言,本文揭示了Transformers架构相对于以往序列建模方法的优势所在。 适合人群:对深度学习尤其是自然语言处理技术有一定基础的理解的研究人员和技术爱好者。 使用场景及目标:帮助读者深入理解为何传统递归神经网络受限于自身的设计无法很好地应对复杂的NLP任务,如翻译或文本摘要,并展示了Transformer是如何克服这些问题的;同时也旨在让有兴趣探索最先进预训练模型如BERT背后逻辑的人群受益。 阅读建议:鉴于本文涉及到大量数学概念与公式推导,请确保自己拥有坚实的机器学习基础知识并且愿意投入足够的时间消化吸收这些新信息。建议配合代码实现一起学习,在实践中加深对各个组件作用的认知。
混合励磁爪极电机在Maxwell中的仿真分析与优化研究,爪极电机 (混合励磁爪极电机) maxwell ,核心关键词:爪极电机; 混合励磁; 爪极电机Maxwell;,混合励磁爪极电机在Maxwell中的仿真研究
内容概要:本文介绍了DeepSeek模型在不同平台上部署的方法。首先阐述了基于Ollama的本地部署,包括Ollama的安装、模型拉取以及交互模式的使用。接着讲解了DeepSeek在移动设备(iOS和Android)上的部署细节:iPhone需要通过Safari安装快捷指令,配置API Key并通过快捷指令测试运行;Android则借助Termux安装必要组件,并手动搭建Ollama环境以加载和测试模型。最后详细叙述了基于Open WebUI部署的方式,涉及Ollama、Docker Desktop及Open WebUI的安装流程及其之间的配合使用来最终达成模型的成功部署。 适用人群:面向有兴趣了解或者实际操作DeepSeek模型跨平台部署的技术开发者、研究人员以及AI爱好者。 使用场景及目标:适用于希望利用DeepSeek模型快速构建本地化应用程序、开展实验研究的用户;具体目标为掌握DeepSeek模型在桌面系统(如Linux、macOS、Windows)、iOS和Android智能手机以及云端WebUI界面上的不同部署手段和技术。 其他说明:对于每种类型的部署都提供了详细的步骤指导,旨在帮助使用者顺利完成所需工具和环境的安装,并确保模型能够正常工作。文中给出的具体链接和命令行脚本,有助于降低初次接触者的上手难度,提升部署效率和成功率。此外,还强调了一些重要的配置注意事项,例如正确输入API key以及对Ollama的初始化检查等。
交变磁场感应材料对沥青路面温度影响的研究,交变磁场下含感应材料沥青路面温度 ,交变磁场; 感应材料; 沥青路面; 温度; 变化; 加热效率,交变磁场对含感应材料沥青路面温度的影响研究
"深度探讨:利用主从博弈理论,结合双层模型与遗传算法及yalmip+cplex求解器实现代码复现的电热综合能源系统动态定价与能量管理",代码复现 《基于主从博弈的电热综合能源系统动态定价与能量管理》 采用双层模型求解 上层为主问题使用遗传算法 下层为子问题调用yalmip+cplex求解器求解 有需要的联系留邮箱 ,代码复现; 动态定价; 能量管理; 主从博弈; 双层模型; 遗传算法; cplex求解器; 联系邮箱,代码复现:双层模型求解电热综合能源系统动态定价与能量管理策略
免费JAVA毕业设计 2024成品源码+论文+数据库+启动教程 启动教程:https://www.bilibili.com/video/BV1SzbFe7EGZ 项目讲解视频:https://www.bilibili.com/video/BV1Tb421n72S 二次开发教程:https://www.bilibili.com/video/BV18i421i7Dx