Android: 读取短信

读取短信本身没什么难度,仅仅是读取SQLite数据库而已。 
Java代码   收藏代码
  1. public Uri SMS_INBOX = Uri.parse("content://sms/inbox");  
  2.     private void fillListView() {  
  3.         ListView view = (ListView) findViewById(R.id.sms_list);  
  4.         ArrayList<HashMap<String, String>> list = readAllSMS();  
  5.         SimpleAdapter listItemAdapter = new SimpleAdapter(this, list,      
  6.                 android.R.layout.simple_list_item_2,   
  7.                 new String[] {"addr","body"},      
  8.                 new int[] {android.R.id.text1, android.R.id.text2}     
  9.             );     
  10.         view.setAdapter(listItemAdapter);  
  11.     }  
  12.       
  13.     private ArrayList<HashMap<String, String>> readAllSMS() {  
  14.         Cursor cursor = managedQuery(SMS_INBOX, new String[] { "address""person""body" },  
  15.                 nullnullnull );  
  16.         ArrayList<HashMap<String, String>> list = new ArrayList<HashMap<String, String>> ();          
  17.         if(cursor.moveToFirst()) {  
  18.             int addrIdx = cursor.getColumnIndex("address");  
  19.             int personIdx = cursor.getColumnIndex("person");  
  20.             int bodyIdx = cursor.getColumnIndex("body");  
  21.             do {  
  22.                 String addr = cursor.getString(addrIdx);  
  23.                 String person = cursor.getString(personIdx);  
  24.                 String body = cursor.getString(bodyIdx);  
  25.                   
  26.                 HashMap<String, String> item = new HashMap<String, String>();  
  27.                 item.put("addr", addr);  
  28.                 item.put("person", person);  
  29.                 item.put("body", body);  
  30.                 list.add(item);  
  31.             } while(cursor.moveToNext());  
  32.         }  
  33.         return list;  
  34.     }  

Activity::managedQuery函数基本上是一个接收SQL查询的接口,参数分别为: 
Java代码   收藏代码
  1. Parameters  
  2. uri  The URI of the content provider to query.   
  3. projection  List of columns to return.   
  4. selection  SQL WHERE clause.   
  5. selectionArgs  The arguments to selection, if any ?s are pesent   
  6. sortOrder  SQL ORDER BY clause.   

要读取短信,需要加入权限: 
Java代码   收藏代码
  1. <uses-permission android:name="android.permission.READ_SMS"></uses-permission>    

关于content://sms/inbox表,大致包含的域有: 
_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是已发出    
body | 短消息内容    
service_center | 短信服务中心号码编号。如+8613800755500 

关于短信相关的应用,大致还包括:监听短信数据库(可用于监听短信的到来)、发送短信。使用起来基本上还算简单。 



12.16.2010 updated 

上面罗列了短信表的字段名,但是没有给出数据类型。在调用Cursor.getString时,该函数会将对应的值转换为字符串(如果不是字符串的话)。要查看SMS表的字段,可以用DDMS把/data/data/com.android.providers.telephony/databases/mmssms.db这个文件,即数据库文件导出,然后找一个SQLite数据库的浏览软件,即可获取出。 

sms表大部分都是INTEGER类型,对应到JAVA里也就是long型数据。基本上我只关注以下字段: 
Java代码   收藏代码
  1. public String mAddress;  
  2. public String mBody;  
  3. public String mSubject;  
  4. public long mID;  
  5. public long mThreadID;  
  6. public long mDate;  
  7. public long mRead;  
  8. public long mPerson;  


person字段取出的值如果该短信是联系人发来的,则指定了联系人表里_id字段的值,例如1、2、3,否则就是0。所以,我们可以通过继续查询联系人数据库表里的内容来取得该短信是谁发来的: 
Java代码   收藏代码
  1. class ContactItem {  
  2.     public String mName;  
  3. }  
  4.   
  5.     ContactItem getContact(Activity activity, final SMSItem sms) {  
  6.         if(sms.mPerson == 0return null;  
  7.         Cursor cur = activity.managedQuery(ContactsContract.Contacts.CONTENT_URI,   
  8.                 new String[] {PhoneLookup.DISPLAY_NAME},   
  9.                 " _id=?",   
  10.                 new String[] {String.valueOf(sms.mPerson)}, null);  
  11.         if(cur != null &&  
  12.             cur.moveToFirst()) {  
  13.             int idx = cur.getColumnIndex(PhoneLookup.DISPLAY_NAME);  
  14.             ContactItem item = new ContactItem();  
  15.             item.mName = cur.getString(idx);  
  16.             return item;  
  17.         }  
  18.         return null;  
  19.     }  


以上代码可能会有BUG,因为在我的手机上测试,moveToFirst经常会失败,继续person字段非0,也取不出联系人信息。这个问题改日再研究。 

放上我的测试程序 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值