Android项目之电话黑名单

本文详细介绍了如何在Android项目中实现电话黑名单功能,包括添加黑名单到数据库、使用ContentProvider以及拦截黑名单来电。具体步骤涉及创建自定义ContentProvider、监听事件、查询和显示黑名单,以及使用Service和AIDL进行来电拦截。
摘要由CSDN通过智能技术生成

本文分享了一个电话黑名单的小项目,下面是具体的实现:

1.添加黑名单。 
2.判断如果是黑名单,就对其拦截。

添加黑名单:

往数据库里面添加黑名单,手机号码,用的是ContentProvider进行添加的(当然,这里是完全没有必要用这个的)

第一步: 
新建一个MyContentProvider继承自ContentProvider,并重写其中的方法:

package com.wind.safecall.contentprovider;

import android.content.ContentProvider;
import android.content.ContentUris;
import android.content.ContentValues;
import android.content.Context;
import android.content.UriMatcher;
import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteOpenHelper;
import android.net.Uri;
import android.support.annotation.NonNull;
import android.support.annotation.Nullable;

/**
 * Created by zhangcong on 2017/4/8.
 */

public class MyContentProvider extends ContentProvider {
   
    private MyOpenHelper myOpenHelper;
    private String DB_name="blackname";//数据库名
    private String Table_name="blacknametable";//数据表名
    private SQLiteDatabase sqLiteDatabase;
    private static UriMatcher uriMatcher;
    public static  final String AUTHORITY="blacknum";
    public static final  Uri uri =Uri.parse("content://blacknum/path_simon");

    // 注册该内容提供者匹配的uri
    static {
        uriMatcher=new UriMatcher(UriMatcher.NO_MATCH);//Creates the root node of the URI tree.
        uriMatcher.addURI(AUTHORITY,"path_simon",1);// 代表当前表中的所有的记录,第三个参数必须为正数
        uriMatcher.addURI(AUTHORITY,"path_simon/1",2);// 代表当前表中的某条特定的记录,记录id便是#处得数字
    }
    //数据表列名映射
    private static  final  String blacknum="blacknum";
    private static final String _id = "id";

    @Override
    public boolean onCreate() {
        try {
            myOpenHelper=new MyOpenHelper(getContext(),DB_name,null,1);
        }
        catch (Exception e)
        {
            return  false;
        }
        return true;
    }

    @Nullable
    @Override
    public Cursor query(@NonNull Uri uri, @Nullable String[] projection, @Nullable String selection, @Nullable String[] selectionArgs, @Nullable String sortOrder) {
        Cursor cursor = null;
        sqLiteDatabase = myOpenHelper.getReadableDatabase();
        int code = uriMatcher.match(uri);//addURI()传的第三个参数
        switch (code) {
            case 1:
                cursor = sqLiteDatabase.query(Table_name, projection, selection,
                        selectionArgs, null, null, sortOrder);
                break;
            case 2:
                // 从uri中解析出ID
                long id = ContentUris.parseId(uri);
                selection = (selection == null || "".equals(selection.trim())) ? _id
                        + "=" + id
                        : selection + " and " + _id + "=" + id;
                cursor = sqLiteDatabase.query(Table_name, projection, selection,
                        selectionArgs, null, null, sortOrder);
                break;
            default:
                throw new IllegalArgumentException("参数错误");
        }

        return cursor;
    }

    @Nullable
    @Override
    public String getType(@NonNull Uri uri) {
        return null;
    }

    @Nullable
    @Override
    public Uri insert(@NonNull Uri uri, @Nullable ContentValues values) {
        sqLiteDatabase=myOpenHelper.getWritableDatabase();
        sqLiteDatabase = myOpenHelper.getWritableDatabase();
        int code = uriMatcher.match(uri);//前面addURI传的第三个参数
        switch (code) {
            case 1:
                sqLiteDatabase.insert(Table_name, blacknum, values);
                break;
            case 2:
                long id = sqLiteDatabase.insert(Table_name, blacknum, values);
                // withAppendId将id添加到uri的最后
                ContentUris.withAppendedId(uri, id);
                break;
            default:
                throw new IllegalArgumentException("异常参数");
        }

        return uri;
    }

    @Override
    public int delete(@NonNull Uri uri, @Nullable String selection, @Nullable String[] selectionArgs) {
        return 0;
    }

    @Override
    public int update(@NonNull Uri uri, @Nullable ContentValues values, @Nullable String selection, @Nullable String[] selectionArgs) {
        return 0;
    }

    private class MyOpenHelper extends SQLiteOpenHelper
    {
   

        public MyOpenHelper(Context context, String name, SQLiteDatabase.CursorFactory factory, int version) {
            super(context, name, factory, version);
        }

        @Override
        public void onCreate(SQLiteDatabase db) {
            /**
             * 官方解释
             * Called when the database is created for the first time. This is where the
             * creation of tables and the initial population of the tables should happen.
             *
             * @param db The database.
             */
            String sql = " create table if not exists " + Table_name
                    + 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值