Android拦截黑名单(简易版)

拦截黑名单的话,一般都是去系统数据库里面取值,判断来电手机号码或者短信号码是否在我黑名单数据中是否存在。如果存在就拦截。而我这里就投机取巧了,没有去数据库。只是简单的拦截,将数据写死了!
来上代码:

public class MyPhoneState extends BroadcastReceiver {
    @Override
    public void onReceive(Context context, Intent intent) {
        if ("android.intent.action.PHONE_STATE".equals(intent.getAction())) {
            //获取电话号码
            String phone = intent.getStringExtra("incoming_number");
            Log.i("test", "有电话进来了," + phone);
            //获取电话管理者
            TelephonyManager manager = (TelephonyManager) context.getSystemService(Context.TELEPHONY_SERVICE);


    //得到电话的状态
            int s = manager.getCallState();
            switch (s) {
                case TelephonyManager.CALL_STATE_RINGING:
                    Log.i("tt", "电话打入:" + phone);
                    break;
                case TelephonyManager.CALL_STATE_OFFHOOK:
                    Log.i("tt", "电话接通:" + phone);
                    break;
                case TelephonyManager.CALL_STATE_IDLE:
                    Log.i("tt", "电话挂断:" + phone);
                    break;
            }
            if ("15616033302".equals(phone)) {
                //得到TelephonyManager class对象
                Class<TelephonyManager> telephonyManagerclass = TelephonyManager.class;
                //获取TelephonyManager.getITelephony的方法Method对象
                Method method = null;
                try {
                    method = telephonyManagerclass.getDeclaredMethod("getITelephony", new  Class[ 0 ]);
                    //允许访问使用方法
                    method.setAccessible(true);
                    //调用方法
                    try {
                        ITelephony telephony = (ITelephony) method.invoke(manager, new  Object[]{});
                        try {
                            //调用挂断方法
                            telephony.endCall();
                        } catch (RemoteException e) {
                            e.printStackTrace();
                        }
                    } catch (IllegalAccessException e) {
                        e.printStackTrace();
                    } catch (InvocationTargetException e) {
                        e.printStackTrace();
                    }
                } catch (NoSuchMethodException e) {
                    e.printStackTrace();
                }
            }
        }
    }
}

//在配置权限(manifests)

<!--电话状态的权限-->
    <uses-permission android:name="android.permission.READ_PHONE_STATE"></uses-permission>
    <uses-permission android:name="android.permission.CALL_PHONE"></uses-permission>

//具体步骤在这里(图片有看不到的可以先下载)
这里写图片描述

好了,简易版就这样了,只是不进数据库!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值