Auto.js 调用系统短信、电话

简介: Auto.js 调用系统短信、电话

<table><tr><td bgcolor=orange>本文所有教程及源码、软件仅为技术研究。不涉及计算机信息系统功能的删除、修改、增加、干扰,更不会影响计算机信息系统的正常运行。不得将代码用于非法用途,如侵立删!</td></tr></table>


****

## Auto.js 调用系统短信、电话


### 操作环境

- VS Code

- Google nexus5x

- Auto.js Pro 7.0.4

- win10

### 调用系统短信模块

- 发送短信  

```python

importClass(android.content.Intent);

importClass(android.telephony.SmsManager);


StringBuilder = java.lang.StringBuilder;

Uri = android.net.Uri;

ArrayList = java.util.ArrayList;

List = java.util.List;

Context = android.content.Context;

SimpleDateFormat=java.text.SimpleDateFormat;

Date=java.util.Date;

Long=java.lang.Long;

var MessageInfo;

var list;


console.show();


var smsManager = android.telephony.SmsManager.getDefault();


smsManager.sendTextMessage("13888888888", null, "123123",  null, null);

toast('短信发送成功')

console.info('短信发送成功')

```

![请添加图片描述](https://ucc.alicdn.com/images/user-upload-01/8dc7a05283e64dc78edb963b38404598.gif)

- 读取短信


```bash

importClass(android.net.Uri);

importClass(android.database.Cursor);

importClass(android.content.ContentResolver);


var SMS_INBOX = Uri.parse( "content://sms/" );

var cr = context.getApplicationContext().getContentResolver();

var projection=new Array("_id" ,  "address" ,  "person" , "body" ,  "date" ,  "type" );

var cur = cr.query(SMS_INBOX, projection,  null ,  null ,  "date desc" );

var i=0;

while (cur.moveToNext()) {

    i=i+1;

    var number = cur.getString(cur.getColumnIndex("address"));//手机号

    var name = cur.getString(cur.getColumnIndex("person"));//联系人姓名列表

    var body = cur.getString(cur.getColumnIndex("body"));//短信内容

    toastLog(number);

    toastLog(name);

    toastLog(body);

    if(i>10){break;}

}

```


- 监听短信



```bash

importPackage(android.content);

importClass(android.telephony.SmsMessage);


var filter=new IntentFilter();


filter.addAction("android.provider.Telephony.SMS_RECEIVED");


var receiver = new JavaAdapter(android.content.BroadcastReceiver, {

  onReceive : function(context, intent) {

    var sender = null;

    var bundle = intent.getExtras();

    var format = intent.getStringExtra("format");


    if (bundle != null) {

        var pdus = bundle.get("pdus");

        for (object in pdus) {

          var message=SmsMessage.createFromPdu(pdus[object],format);

          sender = message.getOriginatingAddress();

          messageBody = (message.getMessageBody());

          log("发信人: " + replacepos(sender, 6, 9, "****"));

          log("短信内容: " + messageBody);

        }

    }

  }

});


context.registerReceiver(receiver,filter);


setInterval(()=>{},1000);

events.on("eixt", function () {

  context.unregisterReceiver(receiver);

})


function replacepos(text,start,stop,replacetext) {

  mystr = text.substring(0,start)+replacetext+text.substring(stop+1);

  return mystr;

}


```


### 调用系统电话模块

- 调用intent拨打电话

```bash

function call(context,id, telNum){

   // id starts from zero to one

   importClass(android.content.Intent);

   importClass(android.net.Uri);

   importClass(android.content.Context);

   importClass(android.telecom.TelecomManager);

   let telecomManager = context.getSystemService(Context.TELECOM_SERVICE);

   if(telecomManager != null){

       let phoneAccountHandleList = telecomManager.getCallCapablePhoneAccounts();

       let intent = new Intent();

       intent.setAction(Intent.ACTION_CALL);

       intent.setData(Uri.parse("tel:" + telNum));

        intent.putExtra(TelecomManager.EXTRA_PHONE_ACCOUNT_HANDLE, phoneAccountHandleList.get(id));

        app.startActivity(intent);

    }

}


call(context,0,12345678910)

```

****

PS:需要先开权限,没有权限会报错Permission denied

开启权限:设置->应用和通知->Auto.js Pro->权限



****

## 资源下载

https://download.csdn.net/download/qq_38154948/85053497

****


<table><tr><td bgcolor=orange>本文仅供学习交流使用,如侵立删!</td></tr></table>



****

相关文章
用html+javascript打造公文一键排版系统1:设计界面
用html+javascript打造公文一键排版系统1:设计界面
|
4月前
|
JavaScript 前端开发
用html+javascript打造公文一键排版系统12:删除附件说明中“附件:”里的空格
用html+javascript打造公文一键排版系统12:删除附件说明中“附件:”里的空格
|
4月前
|
前端开发
用html+javascript打造公文一键排版系统3:获取参数设置、公文标题排版
用html+javascript打造公文一键排版系统3:获取参数设置、公文标题排版
|
6天前
|
监控 算法 JavaScript
基于 Node.js Socket 算法搭建局域网屏幕监控系统
在数字化办公环境中,局域网屏幕监控系统至关重要。基于Node.js的Socket算法实现高效、稳定的实时屏幕数据传输,助力企业保障信息安全、监督工作状态和远程技术支持。通过Socket建立监控端与被监控端的数据桥梁,确保实时画面呈现。实际部署需合理分配带宽并加密传输,确保信息安全。企业在使用时应权衡利弊,遵循法规,保障员工权益。
20 7
|
5月前
|
JavaScript 前端开发 开发者
Vue.js 框架大揭秘:响应式系统、组件化与路由管理,震撼你的前端世界!
【8月更文挑战第27天】Vue.js是一款备受欢迎的前端JavaScript框架,以简洁、灵活和高效著称。本文将从三个方面深入探讨Vue.js:响应式系统、组件化及路由管理。响应式系统为Vue.js的核心特性,能自动追踪数据变动并更新视图。例如,通过简单示例代码展示其响应式特性:`{{ message }}`,当`message`值改变,页面随之自动更新。此外,Vue.js支持组件化设计,允许将复杂界面拆分为独立且可复用的组件,提高代码可维护性和扩展性。如创建一个包含标题与内容的简单组件,并在其他页面中重复利用。
90 3
|
2月前
|
Web App开发 JavaScript 前端开发
2024年5月node.js安装(winmac系统)保姆级教程
本篇博客为2024年5月版Node.js安装教程,适用于Windows和Mac系统。作者是一名熟悉JavaScript与Vue的大一学生,分享了Node.js的基本介绍、下载链接及简单安装步骤。安装完成后,通过终端命令`node -v`验证版本即可确认安装成功。欢迎关注作者,获取更多技术文章。
37 2
2024年5月node.js安装(winmac系统)保姆级教程
|
2月前
|
开发框架 JavaScript 前端开发
TypeScript 是一种静态类型的编程语言,它扩展了 JavaScript,为 Web 开发带来了强大的类型系统、组件化开发支持、与主流框架的无缝集成、大型项目管理能力和提升开发体验等多方面优势
TypeScript 是一种静态类型的编程语言,它扩展了 JavaScript,为 Web 开发带来了强大的类型系统、组件化开发支持、与主流框架的无缝集成、大型项目管理能力和提升开发体验等多方面优势。通过明确的类型定义,TypeScript 能够在编码阶段发现潜在错误,提高代码质量;支持组件的清晰定义与复用,增强代码的可维护性;与 React、Vue 等框架结合,提供更佳的开发体验;适用于大型项目,优化代码结构和性能。随着 Web 技术的发展,TypeScript 的应用前景广阔,将继续引领 Web 开发的新趋势。
45 2
|
3月前
|
缓存 JSON JavaScript
Node.js模块系统
10月更文挑战第4天
52 2
|
3月前
|
Web App开发 JavaScript API
构建高效后端系统:Node.js与Express框架的实践之路
【9月更文挑战第37天】在数字化时代的浪潮中,后端开发作为技术架构的核心,承载着数据处理和业务逻辑的重要职责。本文将深入探讨如何利用Node.js及其强大的Express框架来搭建一个高效、可扩展的后端系统。我们将从基础概念讲起,逐步引导读者理解并实践如何设计、开发和维护一个高性能的后端服务。通过实际代码示例和清晰的步骤说明,本文旨在为初学者和有经验的开发者提供一个全面的指南,帮助他们在后端开发的旅途上走得更远。
58 3
|
3月前
|
JavaScript 前端开发
前端js,vue系统使用iframe嵌入第三方系统的父子系统的通信
前端js,vue系统使用iframe嵌入第三方系统的父子系统的通信