在Android应用中读取彩信文件涉及到Android的一个数据库/data/data /com.android.providers.telephony/databases/mmssms.db和一个文件夹/data/data /com.android.providers.telephony/app_parts。要备份彩信,可以将这个数据库和文件夹拷贝到硬盘,但是在应用中却不能通过openDatabase系列方法来读这个数据库,也不能通过直接打开文件来读取附件文件,因为你的应用不是它们的所有者,不能直接读取,而要使用ContentProvider来读取。
1、读取mmssms.db数据库
彩信的标题、发送者号码、日期等数据存储在mmssms.db的pdu表中,要读取这个表可以使用系统提供的一个ContentProvider,URI 是“content://mms”。操作这个ContentProvider和操作数据库一样,这个ContentProvider的结构也和pdu表的结构一样,Android文档对这些字段没有说明,但是可以通过将mmssms.db数据库备份到硬盘上,然后再通过Sqlite Database Browser软件来查看分析,具体可参考:http://www.blogjava.net/easywu/archive/2010/01/10/308959.html。
content://mms主要的几个字段如下:
◆ _id:该条彩信的主键,对应着part表(ContentProvider的URI是content://mms/part,详见后)中的mid字段。
◆sub:该条彩信的标题
◆date:该条彩信的接收日期
下面的代码可以查询该CotnetProvider,得到一个cursor,并列出所有的列名。
- Cursor cur = getContentResolver().query(Uri.parse("content://mms"),null, null, null, null);
- String [] temp=cur.getColumnNames();
- for (int i=0;i<temp.length;i++)
- System.out.println(i+":"+temp);
Cursor cur = getContentResolver().query(Uri.parse("content://mms"),null, null, null, null);
String [] temp=cur.getColumnNames();
for (int i=0;i<temp.length;i++)
System.out.println(i

本文介绍了如何在Android应用中读取彩信文件,包括通过ContentProvider读取mmssms.db数据库中的彩信数据和附件文件。首先,利用ContentProvider查询彩信数据,如标题、发送者号码和日期。接着,通过查询part表获取彩信附件,读取并转换为字节数组。此外,确保在AndroidManifest.xml中声明READ_SMS权限。
824

被折叠的 条评论
为什么被折叠?



