数据库获取 Android 短信

简介:
读取短信需要的权限
<uses-permission android:name="android.permission.READ_SMS"/>
读取数据库短信方法
   public static List<Map<StringString>> getSmsCode() {
        String lastTime = "1534228493681"// 时间
        Log.i("SMSUtil""开始获取短信");
        Cursor cursor = null;
        // 添加异常捕捉
        try {
            //第一种, 查询所有短信
            cursor = App.mContext.getContentResolver().query(
                    Uri.parse("content://sms"),
                    new String[]{"_id""address""body""date""person""type"},
                    nullnull"date desc");
            //第二种, 通过查询条件, 例如:date > lastTime, 过滤数据
            /*cursor = App.mContext.getContentResolver().query(
                        Uri.parse("content://sms"),
                        new String[]{"_id", "address", "body", "date", "person", "type"},
                        "date > ?", new String[]{lastTime}, "date desc");*/


            if (cursor != null) {
                List<Map<StringString>> smsList = new ArrayList<>();
                while (cursor.moveToNext()) {
                    String body = cursor.getString(cursor.getColumnIndex("body"));// 在这里获取短信信息
                    String person = cursor.getString(cursor.getColumnIndex("person")); // 陌生人为null
                    String address = cursor.getString(cursor.getColumnIndex("address"));
                    String _id = cursor.getString(cursor.getColumnIndex("_id"));
                    String date = cursor.getString(cursor.getColumnIndex("date"));
                    String type = cursor.getString(cursor.getColumnIndex("type"));
                    HashMap<StringString> smsMap = new HashMap<>();
                    smsMap.put("body", body);
                    smsMap.put("person", person);
                    smsMap.put("address", address);
                    smsMap.put("_id", _id);
                    smsMap.put("date", date);
                    smsList.add(smsMap);

                    Log.i("test_sms""body = " + body + "  person = " + person + "  address = " + address
                            + "  date = " + date + "  type = " + type);
                }
                // 返回所有的短信
                return smsList;
            }
        } catch (Exception e) {
            e.printStackTrace();
            Log.i("test_sms""e = " + e.getMessage());
        } finally {
            if (cursor != null) {
                cursor.close();
            }
        }
        return null;
    }
URI 主要有:
content://sms/             所有短信 (本示例用的所有)
content://sms/inbox        收件箱
content://sms/sent         已发送
content://sms/draft        草稿
content://sms/outbox       发件箱
content://sms/failed       发送失败
content://sms/queued       待发送列表
SMS 主要结构:
_id => 短消息序号 如 100  
thread_id => 对话的序号 如 100  
address => 发件人地址,手机号. 如 + 8613811810000  
person => 发件人,返回一个数字就是联系人列表里的序号,陌生人为 null  
date => 日期  long 型。如 1256539465022  
protocol => 协议 0 SMS_RPOTO, 1 MMS_PROTO   
read => 是否阅读 0 未读, 1 已读   
status => 状态 -1 接收,0 complete, 64 pending, 128 failed   
type => 类型 1 是接收到的,2 是已发出       
   (ALL    = 0; 所有
    INBOX  = 1; 收件箱
    SENT   = 2; 已发送
    DRAFT  = 3; 草稿
    OUTBOX = 4; 发件箱
    FAILED = 5; 失败
    QUEUED = 6;)待发送

body => 短消息内容   
service_center => 短信服务中心号码编号。如 + 8613800755500  


原文发布时间为:2018-08-15

本文来自云栖社区合作伙伴“Android开发中文站”,了解相关信息可以关注“Android开发中文站”。

相关文章
|
网络协议 关系型数据库 MySQL
如何实现无公网ip远程访问本地安卓Termux部署的MySQL数据库【内网穿透】
如何实现无公网ip远程访问本地安卓Termux部署的MySQL数据库【内网穿透】
|
存储 数据库连接 数据库
Android数据存储:解释SQLite数据库在Android中的使用。
Android数据存储:解释SQLite数据库在Android中的使用。
260 0
|
5月前
|
监控 Android开发 数据安全/隐私保护
批量发送短信的平台,安卓群发短信工具插件脚本,批量群发短信软件【autojs版】
这个Auto.js脚本实现了完整的批量短信发送功能,包含联系人管理、短信内容编辑、发送状态监控等功能
|
7月前
|
XML 数据库 Android开发
Android数据库的使用(增删改查)
本文介绍了一个简单的数据库操作Demo,包含创建数据库、增删改查功能。通过5个按钮分别实现创建数据库、插入数据、删除数据、更新数据和查询数据的操作。代码结构清晰,适合初学者学习Android SQLite数据库基础操作。
234 5
|
7月前
|
数据库 Android开发
Android外部数据库的引用
简介:本文介绍了在Android项目中引用外部数据库的方法。首先,将现成的数据库文件放入项目的`assets`文件夹中(需手动创建)。其次,在APP引导界面通过代码将数据库拷贝至App目录下,确保数据库可用。最后,对数据库进行增删改查等操作。关键步骤包括判断数据库是否存在、使用`AssetManager`读取数据库文件并写入App私有目录,实现外部数据库的顺利集成与使用。
101 2
|
7月前
|
数据库 Android开发 开发者
Android常用的room增删改查语句(外部数据库)
本文分享了将一个原生数据库驱动的单词APP重构为使用Room库的过程及遇到的问题,重点解决了Room中增删改查的常用语句实现。文章通过具体示例(以“forget”表为例),详细展示了如何定义实体类、Dao接口、Database类以及Repository和ViewModel的设计与实现。同时,提供了插入、删除、更新和查询数据的代码示例,包括模糊查询、分页加载等功能。此外,针对外部数据库导入问题,作者建议可通过公众号“计蒙不吃鱼”获取更多支持。此内容适合有一定Room基础的开发者深入学习。
249 0
Android常用的room增删改查语句(外部数据库)
|
数据库 Android开发 数据安全/隐私保护
在 Android Studio 中结合使用 SQLite 数据库实现简单的注册和登录功能
在 Android Studio 中结合使用 SQLite 数据库实现简单的注册和登录功能
484 2
|
SQL 存储 数据库
48. 【Android教程】数据库:SQLite 的使用
48. 【Android教程】数据库:SQLite 的使用
468 1
|
数据库 Android开发
Android数据库框架-GreenDao入门,2024年最新flutter 页面跳转动画
Android数据库框架-GreenDao入门,2024年最新flutter 页面跳转动画
Android数据库框架-GreenDao入门,2024年最新flutter 页面跳转动画
|
存储 缓存 数据库
Android之SQLite数据库使用详解
Android之SQLite数据库使用详解
1263 0