//初始化方法
function recordInit(scriptName){
//let ipInfoJson = getIP()
// let ip = ipInfoJson.cip
// let location = ipInfoJson.cname
let deviceIMEI = '',deviceBrand='',deviceModel='',AndroidVer='',deviceWH='',deviceBoard='',deviceMac='',AndroidId=''
try {
deviceBrand = device.brand;//制造厂商
deviceBoard = device.board;//主板
deviceMac = device.getMacAddress()//Mac地址
AndroidId = device.getAndroidId()//安卓ID data={
"category":1,
"uuid":"55421",
"device_code":"086",
"configure":"5656E",
"owner":"1",
"model":device.model,
"release": device.release,
"memory":~~(device.getAvailMem()/1024/1024)+'MB',
"imei":device.getIMEI(),
"width":device.width,
"height":device.height,
"battery":device.getBattery()
}
var token=setting.storage.get('access_token')
var res = http.postJson(setting.api_domain+'device/?access-token='+token,data);
if(res.statusCode==200){
log('已添加')
return true
}
else if(res.statusCode==201){
log("已更新")
return true
}else{
log("添加设备失败")
return false
} } catch (error) {
log(error)
return false;
}
} var ws = {
run:function(){
setting.ws_status =true;
console.log('使用软件的过程中,请确保您的网络流畅~')
console.log('Websocket连接中..')
setting.ws = web.newWebSocket(setting.websocket_domain, {
//eventThread: 'this'
}); //ws监听
setting.ws.on("open", (res) => {
log("WebSocket连接成功!");
//心跳检测 let hi={'type':'connect','uuid':'033246','device_code':'003'}
setting.ws.send(JSON.stringify(hi)); setting.heartbeat = threads.start(function(){
setInterval(function(){
console.log('发送心跳包');
}, 10000);
}); }).on("failure", (err, res) => {
// 关闭心跳包线程
setting.heartbeat.interrupt();
//console.error(err);
setting.ws_status =false;
// 断线重连
if(setting.allow_ws_re){
console.error('与总控的连接已断开,五秒后重连...');
sleep(5000)
this.run()
}
// 改变“连接总控”颜色
ui.run(function(){
ui.start.setBackgroundColor(colors.parseColor("#d6d7d7"))
ui.start.text("连接总控")
ui.start.setTextColor(colors.parseColor("#000000"))
});
//alert("提示","ws通道已断开!");
//exit();
}).on("closing", (code, reason) => {
log("WebSocket关闭中");
}).on("text", (text) => {
log("收到消息") try { let data = JSON.parse(text);
switch(data.type){
case 'init':
console.log('等待总控响应...')
var ret=recordInit('init')
console.error("初始化返回:"+ret )
if(ret){
toastLog('成功与总控建立连接')
console.info('大功告成,您可以在总控端控制该终端了~');
// 改变"连接总控"颜色
ui.run(function(){
// 如果在主界面
if(ui.start){
if(setting.sys_name == "闲鱼助手"){
ui.start.setBackgroundColor(colors.parseColor("#009688"))
}else{
ui.start.setTextColor(colors.parseColor("#ffffff"))
ui.start.setBackgroundColor(colors.parseColor(setting.baozeng_colour))
}
ui.start.text("已连接")
} });
device.vibrate(500);//震动700毫秒
}else{
setting.ws_status =false;
let err_msg = r['msg']
alert(err_msg);console.error(err_msg)
}
break; case 'start':
log('接到任务:',json.task)
let sid = json.sid
stopEngine()
try {try {if(main_thread) main_thread.interrupt()} catch (error) { }} catch (error) { }
if(getScriptConfig(sid)){
send_Log('[开始运行]'+json.task,true)
main_thread = threads.start(function () {
doTask(sid)
});
}else{
send_Log('[启动失败]设备获取脚本配置失败!',true)
}
break; case 'web_to_aj_command':
//执行web发来的命令
//console.warn(data.task_type + '('+data.task_id+')');
threads.start(function () {
eval(data.task_type + '('+data.task_id+')');
console.log('等待总控命令中....')
});
break; case 'exec_command': break;
case 'NO':
log(data.msg)
toast(data.msg)
setting.ws.closed();
break; case 'web_to_aj_chat_message':
//web_to_aj_chat_message
console.log(data)
// console.log('web_to_aj_chat_message')
setting.message.push({name:data['name'],message:data['message']})
break;
default:
console.log('defautl')
console.log(data)
} } catch (error) {
log("解析返回来的数据错误")
log(error)
}
}).on("closed", (code, reason) => {
//log("WebSocket已关闭: code = %d, reason = %s", code, reason);
setting.ws_status =false;
alert("提示","ws通道已断开2");
console.error('ws通道已断开2')
//exit();
});
}
} // 函数导出
module.exports = ws;

autojs websocket 核心示例代码,云控技术的更多相关文章

  1. Python如何爬取实时变化的WebSocket数据【华为云技术分享】

    一.前言 作为一名爬虫工程师,在工作中常常会遇到爬取实时数据的需求,比如体育赛事实时数据.股市实时数据或币圈实时变化的数据.如下图: Web 领域中,用于实现数据'实时'更新的手段有轮询和 WebSo ...

  2. C# WebSocket 服务端示例代码 + HTML5客户端示例代码

    WebSocket服务端 C#示例代码 using System; using System.Collections.Generic; using System.Linq; using System. ...

  3. SkylineGlobe TerraExplorer Pro 7.0 Web 控件版 第一行示例代码

    SkylineGlobe TerraExplorer Pro 7.0 是原生的64位应用程序,在Web端用插件方式开发的第一行示例代码如下: 常规代码,需要IE64位: <!DOCTYPE ht ...

  4. 【荐】JavaScript图片放大技术(放大镜)示例代码

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...

  5. AIR32F103(五) FreeRTOSv202112核心库的集成和示例代码

    目录 AIR32F103(一) 合宙AIR32F103CBT6开发板上手报告 AIR32F103(二) Linux环境和LibOpenCM3项目模板 AIR32F103(三) Linux环境基于标准外 ...

  6. 工控图表控件ProEssentials创建3D柱状图示例代码

    使用ProEssentials可以创建3D柱状图,柱状图的形式包括线框.实体和阴影. 类似于Graph control,3D柱状图只需要YData. Subsets定义沿z轴有多少行,Points定义 ...

  7. GitHub C 和 C++ 开源库的清单(含示例代码)

    内容包括:标准库.Web应用框架.人工智能.数据库.图片处理.机器学习.日志.代码分析等. 标准库 C++标准库,包括了STL容器,算法和函数等. C++ Standard Library:是一系列类 ...

  8. 灵雀云Istio技术实践专题整理

    Istio技术实践专题(1) Service Mesh Istio 基本概念和架构基础 Istio被称作Kubernetes的最佳云原生拍档.从今天起,我们推出"Istio技术实践" ...

  9. C/C++ 开源库及示例代码

    C/C++ 开源库及示例代码 Table of Contents 说明 1 综合性的库 2 数据结构 & 算法 2.1 容器 2.1.1 标准容器 2.1.2 Lockfree 的容器 2.1 ...

随机推荐

  1. 深入探讨HBASE

    HBASE基础 1. HBase简介HBase是一个高可靠.高性能.面向列的,主要用于海量结构化和半结构化数据存储的分布式key-value存储系统. 它基于Google Bigtable开源实现,但 ...

  2. binary hacks读数笔记(objdump命令)

    一.首先看一下几个常用参数的基本含义: objdump命令是Linux下的反汇编目标文件或者可执行文件的命令,它还有其他作用,下面以ELF格式可执行文件test为例详细介绍: 1.objdump -f ...

  3. yum安装指定版本ceph包

    安装ceph包的方式有很多,这里讲的是从官网直接通过yum源的安装方式进行安装 yum源对应的地址为 http://download.ceph.com/rpm-hammer/el6/x86_64/ 怎 ...

  4. Ubuntu linux系统下 su:出现: authentication failure的解决办法

    当出现这个问题后,尝试一下方法: $ sudo passwd rootEnter new UNIX password://此时输入你的密码Retype new UNIX password://再次输入 ...

  5. Mac OS终端利器 iTem2 配置大全

    转载链接:https://www.cnblogs.com/diyxiaoshitou/p/9017413.html 之前一直使用 Mac OS 自带的终端,用起来虽然有些不太方便,但总体来说还是可以接 ...

  6. docker搭建渗透环境并进行渗透测试

    目录 docker简介 docker的安装 docker.centos7.windows10(博主宿主机系统)之间相互通信 -docker容器中下载weblogic12c(可以略过不看) docker ...

  7. CTF-lottery[git文件泄露利用+PHP弱类型]

    知识点:PHP弱类型 .git文件泄露 玩攻防世界 遇到一个题lottery  进去看看  分析玩法 我们发现 进入登陆用户都是初始值 金钱是20  彩票号码必须输入7位 然后看你输入的彩票号码有多少 ...

  8. Boom 3D的广播有哪些,有啥特色

    Boom 3D(Windows系统)不仅为用户提供了包括3D立体音效.古典音乐音效在内的多种音效增强功能,而且还为用户提供了广播功能.该广播功能不仅涵盖了国内广播节目,而且还涵盖了国际广播节目. 接下 ...

  9. 下载器Folx专业版有没有iTunes整合功能

    对于使用Mac系统的用户来说,相信对iTunes都不陌生.Folx专业版提供的iTunes整合功能,能将下载的音频.电影等文件自动同步到iTunes. 该功能将会有助于用户的音频.视频整合,对于喜欢听 ...

  10. pytest的setup和teardown

    学过unittest的setup和teardown,前置和后置执行功能.pytest也有此功能并且功能更强大,今天就来学习一下吧. 用例运行级别: 模块级(setup_module/teardown_ ...