安卓读取,添加,更新,删除联系人,读取短信

目录

读取联系人

添加联系人

更新联系人

删除联系人

读取短信


读取联系人

安卓可以通过contentResolver来读取联系人表,联系人表的Uri信息是:content://com.android.contacts/data/phones 从而输出联系人信息,

需要相关权限:

XML 复制代码
    <uses-permission android:name="android.permission.READ_CONTACTS">
    </uses-permission>

具体代码如下:

Kotlin 复制代码
    //需要读联系人权限READ_CONTACTS
    @SuppressLint("Range")
    private fun getContact() {
        //查询raw_contacts表获得联系人
        val resolver = contentResolver
        val uri = Uri.parse("content://com.android.contacts/data/phones")
        //查询联系人
        val cursor = resolver.query(uri, null, null, null, null)
        while (cursor!!.moveToNext()) {
            val name =
                cursor.getString(cursor.getColumnIndex(ContactsContract.CommonDataKinds.Phone.DISPLAY_NAME))
            val number =
                cursor.getString(cursor.getColumnIndex(ContactsContract.CommonDataKinds.Phone.NUMBER))
            Log.d(TAG, "联系人:${name}")
            Log.d(TAG, "电话:${number}")
        }
        cursor.close()
    }

输出结构如下:

复制代码
//2023-08-06 17:29:50.535 31719-31719 MainActivity2           com.example.myapplication            D  联系人:张三
//2023-08-06 17:29:50.535 31719-31719 MainActivity2           com.example.myapplication            D  电话:1 (883) 22
//2023-08-06 17:29:50.535 31719-31719 MainActivity2           com.example.myapplication            D  联系人:si li
//2023-08-06 17:29:50.535 31719-31719 MainActivity2           com.example.myapplication            D  电话:10020
//2023-08-06 17:29:50.535 31719-31719 MainActivity2           com.example.myapplication            D  联系人:bo xiao
//2023-08-06 17:29:50.535 31719-31719 MainActivity2           com.example.myapplication            D  电话:10086

添加联系人

同理,使用contentResolver。需要写联系人权限

Kotlin 复制代码
 <uses-permission android:name="android.permission.WRITE_CONTACTS"/>

具体代码如下:

Kotlin 复制代码
    private fun insertContact() {
        val resolver = contentResolver
        val values = ContentValues()
        //向raw_contacts表插入空数据,拿到uri
        val uri = resolver.insert(ContactsContract.RawContacts.CONTENT_URI,values)
        //拿到表id
        val id = uri?.let { ContentUris.parseId(it) }
        //插入姓名
        values.clear()
        //put id
        values.put(ContactsContract.Data.RAW_CONTACT_ID,id)
        //put type
        values.put(ContactsContract.Data.MIMETYPE,StructuredName.CONTENT_ITEM_TYPE)
        //put 值
        values.put(StructuredName.GIVEN_NAME,"xiaohong")
        resolver.insert(ContactsContract.Data.CONTENT_URI,values)

        //插入手机号
        values.clear()
        //put id
        values.put(ContactsContract.Data.RAW_CONTACT_ID,id)
        //put type
        values.put(ContactsContract.Data.MIMETYPE,Phone.CONTENT_ITEM_TYPE)
        //put 值
        values.put(Phone.NUMBER,"15541383234")
        values.put(Phone.TYPE,Phone.TYPE_MOBILE)
        resolver.insert(ContactsContract.Data.CONTENT_URI,values)

        //插入邮箱
        values.clear()
        //put id
        values.put(ContactsContract.Data.RAW_CONTACT_ID,id)
        //put type
        values.put(ContactsContract.Data.MIMETYPE,Email.CONTENT_ITEM_TYPE)
        //put 值
        values.put(Email.DATA,"163@qq.com")
        values.put(Email.TYPE,Email.TYPE_WORK)
        resolver.insert(ContactsContract.Data.CONTENT_URI,values)
    }

运行结果如下:

更新联系人

这里我们是根据手机号码先获取联系人表id,也仅有这种方式,获取id

Kotlin 复制代码
    @SuppressLint("Range")
    private fun getContactByPhone(phone: Long): String? {
        val resolver = contentResolver
        val uri = Uri.parse("content://com.android.contacts/data/phones/filter/$phone")
        val cursor= resolver.query(uri, arrayOf(ContactsContract.Data.CONTACT_ID),null,null,null)
        return if (cursor!!.moveToNext()){
            val id = cursor.getString(cursor.getColumnIndex(ContactsContract.Data.CONTACT_ID))
            cursor.close()
            id
        }else{
            null
        }
    }

拿到ContactId后,去更新数据

Kotlin 复制代码
    //根据手机号更新
    @SuppressLint("SuspiciousIndentation")
    private fun updateContact() {
    val id  = getContactByPhone(15541383234)
        if(id!=null){
            val values = ContentValues()
            val resolver = contentResolver
            values.put(ContactsContract.Data.MIMETYPE,CommonDataKinds.StructuredName.CONTENT_ITEM_TYPE)
            values.put(CommonDataKinds.StructuredName.GIVEN_NAME,"xiaohong_update")
            resolver.update(ContactsContract.Data.CONTENT_URI, values,"${ContactsContract.Data.CONTACT_ID}=?",
                arrayOf(id)
            )
        }
    }

删除联系人

删除联系人,比较简单,我们可以通过联系人名字,删除

Kotlin 复制代码
    private fun deteleContact() {
        val resolver = contentResolver
        //根据联系人删除
        val ret = resolver.delete(RawContacts.CONTENT_URI, CommonDataKinds.Phone.DISPLAY_NAME+"=?",
            arrayOf("si li")
        )
        if(ret > 0){
            Toast.makeText(this, "删除成功", Toast.LENGTH_LONG).show()
        }
    }

也可以根据联系人手机号删除,具体代码如下:

Kotlin 复制代码
    private fun deteleContact() {
        val resolver = contentResolver
        //根据手机号删除
         val id = getContactByPhone(10020)
         val ret = resolver.delete(RawContacts.CONTENT_URI, CommonDataKinds.Phone.CONTACT_ID+"=?",
            arrayOf(id)
         )
        if(ret > 0){
            Toast.makeText(this, "删除成功", Toast.LENGTH_LONG).show()
        }
    }

读取短信

除此,我们还可以通过contentResolver读取短信信息,短信表的uri信息content://sms/

用途比如验证码快捷输入,像ios短信验证码快速copy到输入框。

下面看看任何实现

第一,读取短信信息,需要权限:

XML 复制代码
    <uses-permission android:name="android.permission.READ_SMS">
    </uses-permission>

具体代码如下;

Kotlin 复制代码
    private fun getMsgs() {
        val uri = Uri.parse("content://sms/")
        val resolver = contentResolver
        val  cursor =resolver.query(uri, arrayOf("address","date","type","body"),null,
        null,null)
        while (cursor!!.moveToNext()){
            val  address = cursor.getString(0)
            val  date = cursor.getString(1)
            val  type = cursor.getString(2)
            val  body = cursor.getString(3)
            Log.d(TAG,"address:${address},date:${date},type:${type},body:${body}")
        }
        cursor.close()
    }

下面是一些表的uri信息:

相关推荐
Libraeking1 小时前
破壁行动:在旧项目中丝滑嵌入 Compose(混合开发实战)
android·经验分享·android jetpack
市场部需要一个软件开发岗位1 小时前
JAVA开发常见安全问题:Cookie 中明文存储用户名、密码
android·java·安全
JMchen1233 小时前
Android后台服务与网络保活:WorkManager的实战应用
android·java·网络·kotlin·php·android-studio
crmscs4 小时前
剪映永久解锁版/电脑版永久会员VIP/安卓SVIP手机永久版下载
android·智能手机·电脑
localbob4 小时前
杀戮尖塔 v6 MOD整合版(Slay the Spire)安卓+PC端免安装中文版分享 卡牌肉鸽神作!杀戮尖塔中文版,电脑和手机都能玩!杀戮尖塔.exe 杀戮尖塔.apk
android·杀戮尖塔apk·杀戮尖塔exe·游戏分享
机建狂魔4 小时前
手机秒变电影机:Blackmagic Camera + LUT滤镜包的专业级视频解决方案
android·拍照·摄影·lut滤镜·拍摄·摄像·录像
hudawei9964 小时前
flutter和Android动画的对比
android·flutter·动画
lxysbly6 小时前
md模拟器安卓版带金手指2026
android
儿歌八万首7 小时前
硬核春节:用 Compose 打造“赛博鞭炮”
android·kotlin·compose·春节
消失的旧时光-19439 小时前
从 Kotlin 到 Dart:为什么 sealed 是处理「多种返回结果」的最佳方式?
android·开发语言·flutter·架构·kotlin·sealed