android > SMS 短信数据库访问

.java

package test.mft;

import java.text.DateFormat;
import java.text.SimpleDateFormat;
import java.util.ArrayList;
import java.util.Date;

import android.app.Activity;
import android.app.TabActivity;
import android.content.Context;
import android.content.Intent;
import android.database.Cursor;
import android.net.Uri;
import android.os.Bundle;
import android.provider.CallLog;
import android.provider.ContactsContract;
import android.provider.ContactsContract.CommonDataKinds.Phone;
import android.util.Log;
import android.widget.TabHost;


public class TestActivity extends Activity {
    /** Called when the activity is first created. */
	 
	Context Tcontext;
	
	@Override
	protected void onCreate(Bundle savedInstanceState) {
		// TODO Auto-generated method stub
		super.onCreate(savedInstanceState);
		setContentView(R.layout.main);
		
		Tcontext = TestActivity.this; 
		getSMSInPhone();
		//
		
	}
	private Cursor getSMSInPhone() {  
        Uri SMS_CONTENT = Uri.parse("content://sms/");  
        String[] projection = new String[] { "_id", "address", "person", "body", "date", "type" };  
        // type : 1-> 接收  , 2->发送
        Cursor cursor = Tcontext.getContentResolver().query(SMS_CONTENT, projection, null, null, "date desc");   // 获取手机短信   

        while (cursor.moveToNext()) {   
            System.out.println("--sms-- : " + "address:"+cursor.getString(cursor.getColumnIndex("address"))+
            		 "\nperson:"+getPeopleNameFromPerson(cursor.getString(cursor.getColumnIndex("address")))+
            		 "\nbody:"+cursor.getString(cursor.getColumnIndex("body"))+
            		 "\ndate:"+cursor.getString(cursor.getColumnIndex("date"))+
            		 "\ntype:"+cursor.getString(cursor.getColumnIndex("type")) );   
        }  

        return cursor;  
    } 

	private String getPeopleNameFromPerson(String address){
		if(address == null || address == ""){
			return "( no address )\n";
		}
		
		String strPerson = "null";
		String[] projection = new String[] {Phone.DISPLAY_NAME, Phone.NUMBER};
		
		Uri uri_Person = Uri.withAppendedPath(ContactsContract.CommonDataKinds.Phone.CONTENT_FILTER_URI, address);	// address 手机号过滤
		Cursor cursor = getContentResolver().query(uri_Person, projection, null, null, null);
		
		if(cursor.moveToFirst()){
			int index_PeopleName = cursor.getColumnIndex(Phone.DISPLAY_NAME);
			String strPeopleName = cursor.getString(index_PeopleName);
			strPerson = strPeopleName;
		}
		else{
			strPerson = address;
		}
		cursor.close();
		
		return strPerson;
	}
	
	
}

 

--sms-- : address:1388888888
person:王三
body:我是信息内容?
date:1365658438100
type:1

 

 

权限加上

<uses-permission android:name="android.permission.READ_SMS"/>
<uses-permission android:name="android.permission.READ_CONTACTS"/>

 

 

 

 

 

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值