android 添加手机短信,获取手机短信,删除手机短信和修改手机短信
注意添加权限:
<uses-permission android:name="android.permission.READ_SMS"></uses-permission> <uses-permission android:name="android.permission.WRITE_SMS"></uses-permission>
代码如下:
//更新短信 private void UpdateSMS() { /* update支持的协议有很多: SMS_RAW_MESSAGE SMS_STATUS_PENDING SMS_ALL SMS_FAILED SMS_QUEUED SMS_INBOX SMS_SENT SMS_DRAFT SMS_OUTBOX SMS_CONVERSATIONS SMS_ALL_ID SMS_INBOX_ID SMS_FAILED_ID SMS_SENT_ID SMS_DRAFT_ID SMS_OUTBOX_ID SMS_CONVERSATIONS_ID SMS_STATUS_ID */ ContentValues cv = new ContentValues(); cv.put("thread_id", "2"); cv.put("address", "00000"); cv.put("person", "11"); //cv.put("date", "11111111"); cv.put("body", "hello,modify content333333333"); getContentResolver().update(Uri.parse("content://sms/sent/3"), cv, null,null); //getContentResolver().update(Uri.parse("content://sms/sent/3"), cv, "id=?",new String[]{"3"}); } //删除短信 private void DeleteSMS() { /* * 其中,delete方法中支持的协议为: * SMS_ALL 根据参数中的条件删除sms表数据 * SMS_ALL_ID 根据_id删除sms表数据 * SMS_CONVERSATIONS_ID 根据thread_id删除sms表数据,可以带其它条件 * SMS_RAW_MESSAGE 根据参数中的条件删除 raw表 * SMS_STATUS_PENDING 根据参数中的条件删除 sr_pending表 * SMS_SIM 从Sim卡上删除数据 * 试一下SMS_CONVERSATIONS_ID:"content://sms/conversations/3 ",删除thread_id="3", _id="5"的数据 在eclipse中的Emulator * Control中,以13800给模拟器发送三条数据,然后以13900发送一条 * this.getContentResolver().delete * (Uri.parse("content://sms/conversations/3"), "_id=?", new * String[]{"5"}); 成功删除一条数据。 * 在数据库中每个发送者的thread_id虽然一样,但不是固定的,如果把一个发送者的全部数据删除掉, * 然后换一个新号码发送短信时,thread_id是以数据库中最大的id+1赋值的。 */ /* 看了一下android的源代码,sms支持的协议有: sURLMatcher.addURI("sms", null, SMS_ALL); sURLMatcher.addURI("sms", "#", SMS_ALL_ID); sURLMatcher.addURI("sms", "inbox", SMS_INBOX); sURLMatcher.addURI("sms", "inbox/#", SMS_INBOX_ID); sURLMatcher.addURI("sms", "sent", SMS_SENT); sURLMatcher.addURI("sms", "sent/#", SMS_SENT_ID); sURLMatcher.addURI("sms", "draft", SMS_DRAFT); sURLMatcher.addURI("sms", "draft/#", SMS_DRAFT_ID); sURLMatcher.addURI("sms", "outbox", SMS_OUTBOX); sURLMatcher.addURI("sms", "outbox/#", SMS_OUTBOX_ID); sURLMatcher.addURI("sms", "undelivered", SMS_UNDELIVERED); sURLMatcher.addURI("sms", "failed", SMS_FAILED); sURLMatcher.addURI("sms", "failed/#", SMS_FAILED_ID); sURLMatcher.addURI("sms", "queued", SMS_QUEUED); sURLMatcher.addURI("sms", "conversations", SMS_CONVERSATIONS); sURLMatcher.addURI("sms", "conversations/*", SMS_CONVERSATIONS_ID); sURLMatcher.addURI("sms", "raw", SMS_RAW_MESSAGE); sURLMatcher.addURI("sms", "attachments", SMS_ATTACHMENT); sURLMatcher.addURI("sms", "attachments/#", SMS_ATTACHMENT_ID); sURLMatcher.addURI("sms", "threadID", SMS_NEW_THREAD_ID); sURLMatcher.addURI("sms", "threadID/*", SMS_QUERY_THREAD_ID); sURLMatcher.addURI("sms", "status/#", SMS_STATUS_ID); sURLMatcher.addURI("sms", "sr_pending", SMS_STATUS_PENDING); sURLMatcher.addURI("sms", "sim", SMS_ALL_SIM); sURLMatcher.addURI("sms", "sim/#", SMS_SIM);*/ //getContentResolver().delete(Uri.parse("content://sms/failed/3"), "_id=?", new String[]{"99"}); getContentResolver().delete(Uri.parse("content://sms/#"),"_id=?", new String[]{"99"}); } //添加短信 private void AddSMS() { /* * insert支持的协议: * * SMS_ALL * SMS_INBOX * SMS_FAILED * SMS_QUEUED * SMS_SENT * SMS_DRAFT * SMS_OUTBOX * SMS_RAW_MESSAGE * SMS_STATUS_PENDING * SMS_ATTACHMENT * SMS_NEW_THREAD_ID * * 向sms表插入数据时,type是根据协议来自动设置, * 如果传入的数据中没有设置date时,自动设置为当前系统时间;非SMS_INBOX协议时,read标志设置为1 * SMS_INBOX协议时,系统会自动查询并设置PERSON threadId为null或者0时,系统也会自动设置 * * 一直为造不了"发送失败"的邮件而发愁,现在来做一个: content://sms/failed */ String id=null; ContentValues cv = new ContentValues(); for(int i = 0;i<5;i++) { id.valueOf(i); cv.put("_id", id); cv.put("thread_id", "0"); cv.put("address", "9999"); cv.put("person", "888"); //cv.put("date", "9999"); cv.put("protocol", "0"); cv.put("read", "1"); cv.put("status", "-1"); cv.put("body", "@@@@@@@@@"); getContentResolver().insert(Uri.parse("content://sms/sent"), cv); cv.clear(); } } //查询短信内容 private void GetSMS() { /* * content://sms/inbox 收件箱 content://sms/sent 已发送 * content://sms/draft 草稿 content://sms/outbox 发件箱 * content://sms/failed 发送失败 content://sms/queued 待发送列表 * 数据库中sms相关的字段如下: * _id 一个自增字段,从1开始 thread_id 序号,同一发信人的id相同 * 同一个联系人的thread_id是一样的,通过遍历thread id和对比就能知道一个联系人有几条短信; * 当然了,Threads表里面有个message_out的字段也是显示有条联系人的,但是Threads表还没有找到可以读取的办法; * * address 发件人手机号码 * person 联系人列表里的序号,陌生人为null ;即rawcontact表的contact_id,或者contact表的_id; * 可通过此id关联联系人;但是person对应结果不稳定,应该使用PhoneLookup.CONTENT_FILTER_URI * date 发件日期 * protocol 协议,分为: 0 SMS_RPOTO, 1 MMS_PROTO * read 是否阅读 0未读, 1已读 * status 状态 -1接收,0 complete, 64 pending, 128 failed * type ALL = 0; INBOX = 1; SENT =2; DRAFT = 3; OUTBOX = 4; FAILED = 5; QUEUED = 6; * body 短信内容 * service_center 短信服务中心号码编号 * subject 短信的主题 * reply_path_present TP-Reply-Path locked */ Log.i("SMS","开始获取短信"); String[] projection = new String[] { "_id", "address", "person", "date", "protocol", "read", "status", "body", "service_center", "subject" }; Cursor cur = getContentResolver().query(Uri.parse("content://sms"), projection, null,null, "date desc"); StringBuilder str=new StringBuilder(); if (cur.moveToFirst()) { String name; String phoneNumber; String sms; long date; String id; int idColumn = cur.getColumnIndex("_id"); int nameColumn = cur.getColumnIndex("person"); int phoneColumn = cur.getColumnIndex("address"); int smsColumn = cur.getColumnIndex("body"); int dateColumn=cur.getColumnIndex("date"); do { // Get the field values name = cur.getString(nameColumn); phoneNumber = cur.getString(phoneColumn); sms = cur.getString(smsColumn); date = cur.getLong(dateColumn); String temp = long2String(date); id = cur.getString(idColumn); //date = String2Long(date); str.append("{"); str.append(name+","); str.append(phoneNumber+","); str.append(sms+","); str.append(temp+","); str.append(id); str.append("}"); if (null==sms) sms=""; } while (cur.moveToNext()); } else { str.append("no result!"); } Log.i("SMS",str.toString()); Toast.makeText(context, str.toString(), Toast.LENGTH_SHORT).show(); System.out.print("短信结果:"+str.toString()); cur.close(); } private String long2String(long time) { SimpleDateFormat sdf = new SimpleDateFormat("yyyy年MM月dd日 HH:mm:ss:SSSS"); return sdf.format(new Date(time)); }
android 添加手机短信,获取手机短信,删除手机短信和修改手机短信的更多相关文章
- 腾讯云短信 nodejs 接入, 通过验证码修改手机示例
腾讯云短信 nodejs 接入, 通过验证码修改手机示例 参考:腾讯云短信文档国内短信快速入门qcloudsms Node.js SDK文档中心>短信>错误码 nodejs sdk 使用示 ...
- Android黑科技,读取用户短信+修改系统短信数据库
安卓系统比起ios系统最大的缺点,相信大家都知道,就是系统安全问题.这篇博客就秀一波“黑科技”. 读取用户短信 Android应用能读取用户手机上的短信,相信已经不是什么新鲜事,比如我们收到的短信验证 ...
- Android添加快捷方式(Shortcut)到手机桌面
Android添加快捷方式(Short)到手机桌面 权限 要在手机桌面上添加快捷方式,首先需要在manifest中添加权限. <!-- 添加快捷方式 --> <uses-permis ...
- 调用手机在线API获取手机号码归属地信息
手机在线(www.showji.com)始创于2001年,发展至今已拥有国内最准确.号段容量最大的手机号码归属地数据库系统, 目前号段容量将近33万条,每月保持两次以上规模数据更新,合作伙伴包括:百度 ...
- android利用adb修改手机的分辨率和dpi
在android开发过程中,适配更多的适配是必不可少的一步,而每次测试适配时,要么购买设配,要么模拟器,买设配太花钱,模拟器太占内存,不过幸好还可以通过修改手机的size(分辨率)和density来进 ...
- Android设备唯一码的获取
Android设备唯一码的获取 UTDID是集团无线设备统一ID方案,目的是给每一台设备一个ID,作为唯一标识.UTDID由客户端生成,并在设备中各个客户端之间共享.UTDID的生成中包含时间戳和随机 ...
- android ------ 实现高德定位并获取相应信息 ( 最新版高德SDK 和 Android SDK版本)
Android开发项目时常常会遇到定位这个功能, 很久以前写过一篇了,官方也更新了一些东西,我也更新下 以前使用的是jar包 导入来实现高德定位 老版本 链接:https://www.cnblogs. ...
- 【Android Demo】通过WebService获取今日天气情况
因为本身是在搞.NET方面的东东,现在在学习Android,所以想实现Android通过WebService接口来获取数据,网上很多例子还有有问题的.参考:Android 通过WebService进行 ...
- 【Android Demo】通过WebService获取今日天气情况--转
因为本身是在搞.NET方面的东东,现在在学习Android,所以想实现Android通过WebService接口来获取数据,网上很多例子还有有问题的.参考:Android 通过WebService进行 ...
- Android必知必会-获取视频文件的截图、缩略图
背景 公司最近要求给我负责的APP加上视频录制和发布的功能,我简单的完成了基本的录制和视频压缩功能,后来发现发布接口需要上传视频的截图,网上搜索了一下资料,在这里整理一下. 代码实现 /** * 获取 ...
随机推荐
- insert,extend
#insert s = ['8','9','sfd',('45','00'),{'01':'56'}] s0 = [] while 1 : extend = input("请输入要添加的内容 ...
- STM32串口程序的一般配置方法
#include "stm32f10x.h" /************************************************ 该程序讲解串口程序的一般配置方法: ...
- 调试24L01经验总结
注意的地方: 1.调试24L01的时候,信号的初始状态一定要设置,否则在设置模块的状态的时候容易出错.( CE=0; CSN=1; SCK=0; MOSI = 1; IRQ = 1;)IRQ设置成1是 ...
- 【Codeforces 231C】To Add or Not to Add
[链接] 我是链接,点我呀:) [题意] 题意 [题解] 把数组排个序, 显然优先用大的且小于枚举的数字a[i]的数字变成a[i] 那么肯定有一个范围j. 然后a[j~i-1]都能在k花费以内变成a[ ...
- BNUOJ 26229 Red/Blue Spanning Tree
Red/Blue Spanning Tree Time Limit: 2000ms Memory Limit: 131072KB This problem will be judged on HDU. ...
- 使用mysql-proxy 快速实现mysql 集群 读写分离
目前较为常见的mysql读写分离分为两种: 1. 基于程序代码内部实现:在代码中对select操作分发到从库:其它操作由主库执行:这类方法也是目前生产环境应用最广泛,知名的如DISCUZ X2.优点是 ...
- HDU 1754 I Hate It (Splay 区间操作)
题目大意 维护一个序列,支持两种操作 操作一:将第x个元素的值修改为y 操作二:询问区间[x,y]内的元素的最大值 解题分析 splay的区间操作,事先加入两个编号最小和最大的点防止操作越界. 具体的 ...
- 获取webview的截图
设置webview可以获取截图: webView.setDrawingCacheEnabled(true); 当要进行多次截图时,先要清除之前的缓存: webview.setDrawingCacheE ...
- 服务器Centos7.4 下jdk1.8环境配置、mysql环境搭建,mysql找回(重置)密码看这篇就够了
最近一直帮我的同学搭建自己的服务器,其中涉及到了以下知识点,经过查询博客资料等方式,再加上多重实践,我成功总结出了完整的配置一个简单服务器环境的步骤: (来自 ZYXS 的CSDN 博客 ,全文地址请 ...
- java基础标识符,关键字,常量
1关键字1.1关键字的概述Java的关键字对java的编译器有特殊的意义,他们用来表示一种数据类型,或者表示程序的结构等,关键字不能用作变量名.方法名.类名.包名.2标识符2.1什么是标识符就是程序员 ...