使用Auto.js 调用系统短信、电话模块实现功能
更新时间:2023年03月24日 16:44:28 作者:拉灯的小手
这篇文章主要介绍了如何使用Auto.js调用系统短信与电话模块,并实现读取短信与联系人的功能,并给出了实现相应功能的代码
操作环境
- VS Code
- Google nexus5x
- Auto.js Pro 7.0.4
- win10
调用系统短信模块
发送短信
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('短信发送成功')
读取短信
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;}
}
监听短信
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拨打电话
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)
注意事项
需要先开权限,没有权限会报错Permission denied
开启权限:设置->应用和通知->Auto.js Pro->权限
读取短信及联系人
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;}
}
以上就是使用Auto.js 调用系统短信、电话模块以及实现联系人功能的详细方法,更多关于调用系统模块的资料请关注脚本之家其它相关文章。也希望大家可以多多关注脚本之家,我们后续将更新更多精彩内容!
相关文章
JS实现显示带倒影的图片横排居中放大展示特效实例【测试可用】
这篇文章主要介绍了JS实现显示带倒影的图片横排居中放大展示功能,可实现点击图片及点击左右按钮滑动切换的效果,涉及javascript针对鼠标事件的响应及页面元素动态操作相关技巧,需要的朋友可以参考下2016-08-08
IE11下CKEditor在Bootstrap Modal中下拉问题的解决
这篇文章主要介绍了IE11下CKEditor在Bootstrap Modal中下拉问题的解决方法,具有一定的参考价值,感兴趣的小伙伴们可以参考一下2019-09-09
详解webpack 入门总结和实践(按需异步加载,css单独打包,生成多个入口文件)
本篇文章主要介绍了webpack 入门总结和实践(按需异步加载,css单独打包,生成多个入口文件) ,具有一定的参考价值,感兴趣的小伙伴们可以参考一下2017-06-06
layer.prompt使文本框为空的情况下也能点击确定的方法
今天小编就为大家分享一篇layer.prompt使文本框为空的情况下也能点击确定的方法,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧2019-09-09


最新评论