Android添加手机黑名单,手机来电拦截实现详解与Demo,一个不错的练手项目,涵盖Android四大组件。

本文详细讲解了一个Android应用,用于添加手机黑名单并拦截黑名单来电。通过该练手项目,可以深入理解Android四大组件(Activity, Service, ContentProvider, BroadcastReceiver)的使用。项目代码可在GitHub和CSDN下载,涉及知识点包括正则表达式、aidl、权限管理等。" 135451677,10646427,DiSparse: 多任务模型压缩的新方法,"['深度学习', '计算机视觉', '模型压缩', '多任务模型']
摘要由CSDN通过智能技术生成

简介

这是一个小应用的详解,这个应用可以添加手机黑名单,拦截手机黑名单的来电。通过这个小demo,我们可以对Android四大组件的应用场景有个具体的了解,可以说是一个不错的练手项目。

下面给出下载地址:
1.GitHub下载地址:
https://github.com/Simon986793021/SafeCall

2.CSDN下载地址:
http://download.csdn.net/detail/simon_crystin/9809978

概述

下面先来讲下Android四大组件在demo中的应用:

Activity:这个大家肯定是比较熟悉的,也是大家比较常用的。主要是用来加载页面和一些操作。

Service:我们的Service会一直在后台运行,如果是黑名单中的号码,将会直接拦截。有两种启动方式,这里不具体分析。

ContentProvider:内容提供者,它的作用主要是对应用之间 的数据操作提供接口,不懂的可以看下我的这篇BLOG:
http://blog.csdn.net/Simon_Crystin/article/details/68517050
这这个demo中的应用主要是用来对本地数据库进行操作,这里本来是是不需要用到ContentProvider,但是基于某种原因,我这里用了。这个是不需要纠结的。

BroadcastReceiver:这里主要是在开机时发送一个广播,在接收广播的时候开启一个服务。对广播接收者不熟悉的也可以看下这片Blog:
http://blog.csdn.net/Simon_Crystin/article/details/68062838

除了这些:里面还涉及了许多知识点,比如:
1:正则表达式的用法,用来匹配手机号码;
2:aidl的使用,用来拦截来电;
3:各种权限的使用;
4:adapter的使用;
5:dialog的自定义;
6:Toast的自定义等等,还有许多小技巧。

实现

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 == <
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

AnjoyZhang

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值