Android来电拦截的实现方法
作者:Saflyer 发布时间:2023-10-09 16:42:20
标签:Android,来电拦截
本文实例为大家分享了Android来电拦截的方法,供大家参考,具体内容如下
权限
<uses-permission android:name="android.permission.READ_PHONE_STATE" />
<uses-permission android:name="android.permission.CALL_PHONE" />
<uses-permission android:name="android.permission.PROCESS_OUTGOING_CALLS" />
<!-- 注册广播 监听拨出电话 -->
<receiver android:name="com.example.administrator.endcall.PhoneStateReceiver">
<intent-filter>
<action android:name="android.intent.action.PHONE_STATE" />
<action android:name="android.intent.action.NEW_OUTGOING_CALL" />
</intent-filter>
</receiver>
拨号广播—PhoneStateReceiver
package com.example.administrator.endcall;
import android.content.BroadcastReceiver;
import android.content.Context;
import android.content.Intent;
import android.telephony.PhoneStateListener;
import android.telephony.TelephonyManager;
import android.util.Log;
public class PhoneStateReceiver extends BroadcastReceiver {
@Override
public void onReceive(Context context, Intent intent) {
if (intent.getAction().equals(Intent.ACTION_NEW_OUTGOING_CALL)) {
String phoneNumber = intent.getStringExtra(Intent.EXTRA_PHONE_NUMBER);
Log.i("BlockCallHelper", "BlockCallHelper------->>>>" + phoneNumber);
}
}
}
来电挂断
BlockCallHelper
package com.example.administrator.endcall;
import android.content.Context;
import android.content.SharedPreferences;
import android.database.Cursor;
import android.net.Uri;
import android.os.RemoteException;
import android.telephony.PhoneStateListener;
import android.telephony.TelephonyManager;
import android.util.Log;
import com.android.internal.telephony.ITelephony;
import java.lang.reflect.InvocationTargetException;
import java.lang.reflect.Method;
import java.util.ArrayList;
import java.util.List;
public final class BlockCallHelper {
private static final String TAG = "BlockCallHelper";
private Context mContext;
private TelephonyManager tManger;
private List<String> phones;
private BlockCallBack bcb;
//////////////////////////////////////////
private static final class Factory {
private static final BlockCallHelper instance = new BlockCallHelper();
}
public static BlockCallHelper getInstance() {
return Factory.instance;
}
/**
* 初始化上下文以及数据
* @param context
*/
public BlockCallHelper init(Context context) {
if (context == null) {
throw new NullPointerException("context == null!");
}
this.mContext = context;
this.tManger = (TelephonyManager) mContext.getSystemService(Context.TELEPHONY_SERVICE);
tManger.listen(new PhoneCallListener(), PhoneCallListener.LISTEN_CALL_STATE);
return this;
}
/**
* 注入需要拦截的手机号
* @param phoneL
*/
public BlockCallHelper injectBlockPhoneNum(ArrayList<String> blockCalls) {
this.phones = blockCalls;
return this;
}
/**
* 结束通话
*/
private void endCall() {
Class<TelephonyManager> tmc = TelephonyManager.class;
Method getITelephonyMethod;
try {
getITelephonyMethod = tmc.getDeclaredMethod("getITelephony", (Class[]) null);
getITelephonyMethod.setAccessible(true);
ITelephony iTelephony = (ITelephony) getITelephonyMethod.invoke(tManger, (Object[]) null);
iTelephony.endCall();
} catch (NoSuchMethodException e1) {
e1.printStackTrace();
} catch (InvocationTargetException e2) {
e2.printStackTrace();
} catch (IllegalAccessException e3) {
e3.printStackTrace();
} catch (RemoteException e4) {
e4.printStackTrace();
}
}
private final class PhoneCallListener extends PhoneStateListener {
@Override
public void onCallStateChanged(int state, String incomingNumber) {
if (state == TelephonyManager.CALL_STATE_RINGING) {
if (phones.contains(incomingNumber)) {
Log.i("BlockCallHelper", "contains contains contains");
endCall();
if (bcb != null) {
bcb.callBack(incomingNumber);
}
} else {
Log.i("BlockCallHelper", "contains not-------");
}
}
}
}
public BlockCallHelper setBlockCallBack(BlockCallBack back) {
this.bcb = back;
return this;
}
public interface BlockCallBack {
void callBack(String incomingNum);
}
}
看主界面MainActivity
package com.example.administrator.endcall;
import android.app.Activity;
import android.app.NotificationManager;
import android.os.Bundle;
import android.util.Log;
import android.widget.Toast;
import java.util.ArrayList;
public class MainActivity extends Activity {
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
ArrayList<String> blockCalls = new ArrayList();
blockCalls.add("13581922339");
blockCalls.add("+8613581922339");
blockCalls.add("18500813370");
blockCalls.add("13717717622");
blockCalls.add("+8613717717622");
BlockCallHelper.getInstance().init(this).injectBlockPhoneNum(blockCalls).setBlockCallBack(new BlockCallHelper.BlockCallBack() {
@Override
public void callBack(String incomingNum) {
Log.i("BlockCallHelper", "incomingNum-----------" + incomingNum);
}
});
}
}
最后看AIdl层面
ITelephony.aidl
package com.android.internal.telephony;
interface ITelephony {
void dial(String number);
void call(String number);
boolean showCallScreen();
boolean showCallScreenWithDialpad(boolean showDialpad);
boolean endCall();
void answerRingingCall();
void silenceRinger();
boolean isOffhook();
boolean isRinging();
boolean isIdle();
boolean isRadioOn();
boolean isSimPinEnabled();
void cancelMissedCallsNotification();
boolean supplyPin(String pin);
boolean handlePinMmi(String dialString);
void toggleRadioOnOff();
boolean setRadio(boolean turnOn);
void updateServiceLocation();
void enableLocationUpdates();
void disableLocationUpdates();
int enableApnType(String type);
int disableApnType(String type);
boolean enableDataConnectivity();
boolean disableDataConnectivity();
boolean isDataConnectivityPossible();
Bundle getCellLocation();
List<NeighboringCellInfo> getNeighboringCellInfo();
int getCallState();
int getDataActivity();
int getDataState();
}
NeighboringCellInfo.aidl
// NeighboringCellInfo.aidl
package android.telephony;
parcelable NeighboringCellInfo;


猜你喜欢
- 我这一次讲使用scroll实现弹性滑动,我不会只有一个例子就说完,因为写文章的时候我也在学习,我分几次讲完吧。首先上一段代码,private
- 前言最近想体验下最新版本的SpringBoot,逛了下官网,发现SpringBoot目前最新版本已经是2.6.4了,版本更新确实够快的。之前
- 实现效果为一个小球接触左右侧时,会反向的运动。import javafx.application.Application;import ja
- 一:问题引入前面讲到用户支付完成之后微信支付服务器会发送回调通知给商户,商户要能够正常处理这个回调通知并返回正确的状态码给微信支付后台服务器
- foreach遍历是C#常见的功能,而本文通过实例形式展现了C#使用yield关键字让自定义集合实现foreach遍历的方法。具体步骤如下:
- Spring容器中的Bean是否线程安全,容器本身并没有提供Bean的线程安全策略,因此可以说Spring容器中的Bean本身不具备线程安全
- ${} 和 #{} 都是 MyBatis 中用来替换参数的,它们都可以将用户传递过来的参数,替换到 MyBatis 最终生成的 SQL 中,
- 字节流和字符流对于文件必然有读和写的操作,读和写就对应了输入和输出流,流又分成字节和字符流。1.从对文件的操作来讲,有读和写的操作——也就是
- 在程序开发中,一个程序经常需要去调用其他的程序,C#中Process类正好提供了这样的功能。它提供对本地和远程进程的访问并使您能够启动和停止
- Spring EL表达式语言,支持在XML和注解中表达式,类是于JSP的EL表达式语言。在Spring开发中经常涉及调用各种资源的情况,包含
- 方式一:例如:”0000123” (字符串必须全为数字)处理过程:String tempStr = "0000123";
- 实例如下:public class ConfigOperator { #region 从配置文件获取V
- 1、反射的概念1、概念反射,指在运行状态中,对于任意一个类,都能够知道这个类的所有属性和方法,对任意一个对象,都能调用它的任意一个方法。这种
- C# 3.0为你提供了对象集合初始化器:/// <summary>/// 图书类/// </summary>publ
- 一 悬浮窗口特点:① 窗口一般较小,有时为不规则背景;② 置顶显示;③ 窗口支持拖动;④ 一般用于程序状态显示,比如显示下载进度;⑤ 一般支
- 一、什么是封装?封装就是将属性私有化,提供公有的方法访问私有属性。做法就是:修改属性的可见性来限制对属性的访问,并为每个属性创建一对取值(g
- 一、多线程的优缺点多线程的优点:1)资源利用率更好2)程序设计在某些情况下更简单3)程序响应更快多线程的代价:1)设计更复杂虽然有一些多线程
- 一棵二叉查找树是按二叉树结构来组织的。这样的树可以用链表结构表示,其中每一个结点都是一个对象。结点中除了数据外,还包括域left,right
- 本文实例讲述了C#获取web.config配置文件内容的方法。分享给大家供大家参考。具体实现方法如下:1.ConfigurationMana
- Android 实现单线程轮循机制批量下载图片listview 在为item 添加从网上下载下来的图片时, 如果每次都整合一个item时都需