基于OppoR9sk的58本地转今日头疼新闻的代码

本文涉及的产品
日志服务 SLS,月写入数据量 50GB 1个月
简介: 基于OppoR9sk的58本地转今日头疼新闻的代码

基于OppoR9sk的58本地转今日头疼新闻的代码

关键点

1、首先要定位是本地的城市,我在大连所以就是大连

2、今日头疼很多地方是三无的所以只能点击坐标

3、每次转载只能重新开始要不然容易宕掉,所以使用了stopapp的方法

auto.waitFor();//判断和等待开启无障碍
let cityName = "大连"
let executeCount = 50
for (let i = 0; i < executeCount; i++) {
    toastLog("58同城本地版第"+i+"次转载正在执行...")
    stopApp("抖音");
    stopApp("今日头条极速版");
    launchApp("今日头条极速版");
    cutDownBySleep(8)//启动App时候等待时间
    adolescentWindows();//关闭青少年窗口
    let areaBounds = bounds(219, 96, 291, 168) //R9SK特殊的地方点击搜索
    if (areaBounds.exists()) {
        clickControlBounds(areaBounds);
    }
    input(cityName)
    setText(cityName)
    clickControlBounds(text("搜索"));
    sleepRandom1()
    clickControlBounds(text("资讯"));
    sleepRandom1()
    if (i % 15 != 0 && i<15) {
        silderScreen(i) //正常滑动屏幕次数
        toastInfo("点第一个")
        click(device.width*0.5,device.height*0.2)
    }else if (i % 15 != 0 && i>15 && i<30)  {
        silderScreen(i-15) //滑动屏幕
        toastInfo("点第二个")
        click(device.width*0.5,device.height*0.51)
    }else if(i % 15 != 0 && i>30){
        silderScreen(i-15*2) //滑动屏幕
        toastInfo("点第三个")
        click(device.width*0.5,device.height*0.9)
    }else{
        if(i==0)
            click(device.width*0.5,device.height*0.2)
        if(i==15)
            click(device.width*0.5,device.height*0.5)
        if(i==30)
            click(device.width*0.5,device.height*0.9)
    }
    sleepRandom1()
    sleepRandom0() //保障一下
    let shareButton = bounds(969, 84, 1041, 156) //R9SK特殊的地方点击分享按钮
    if (shareButton.exists()) {
        shareButton.clickable().click()
        swipe(780, 1169, 119, 1169, 300); //特殊的地方右滑
        if (text("复制链接").exists()) {
            if (clickControlBounds(text("复制链接"))) {
                toastLog("剪贴板内容为:" + getClip());
                try {
                stopApp("58本地版")
                launchApp("58本地版")
                cutDownBySleep(12)//启动App时候等待时间
                closeSplashAD()
                clickControlBounds(text("我的"))
                sleepRandom1()
                let reprintButton=text("去转载").findOnce();
                if(reprintButton!=null){
                    clickBounds(reprintButton.bounds())
                }else{
                    swipe(303, 1328, 335, 171, 300);
                    reprintButton=text("去转载").findOnce();
                    clickBounds(reprintButton.bounds())
                }
                sleepRandom5()
                clickControlBounds(text("转载"))
                sleepRandom5()
            } catch (error) {
            }
            }
        } else {
            toastError("居然失败了")
        }
    }
}
function closeSplashAD(){
    if(id("wbu_home_red_package_close").exists()){
        clickControlBounds(id("wbu_home_red_package_close"));
    }
}
function silderScreen(total) {
    if(total<0){return}
    for (let i = 0; i < total; i++) {
        swipe(303, 1328, 335, 171, 300);
        sleepRandom0()
    }
}
function closeSplashAD() {
    if (id("img_close").exists()) {
        clickControlBounds(id("img_close"));
    }
}
function closeAD() {
    if (id("img_close").exists()) {
        clickControlBounds(id("img_close"));
    }
    clickControlBounds(text("我知道了"));
}
function autoCashOut() {
    try {
        if (clickControl(text("我的"))) {
            if (clickControl(text("提现"))) {
                sleepRandom9()
                sleepRandom9()
                toastInfo("18")
                swipe(303, 1328, 335, 171, 300);
                sleepRandom0()
                if (text("无门槛").exists()) {
                    clickControlBounds(text("无门槛"))
                    sleepRandom1()
                    if (text("去完成").exists()) {
                        clickControlBounds(text("去完成"))
                        sleep(60000)
                        sleepRandom1()
                        clickControlBounds(id("tt_video_ad_close"))
                        sleepRandom3()
                        clickControlBounds(text("下一步"))
                        sleepRandom3()
                        clickControlBounds(text("提交"))
                        sleepRandom3()
                        clickControlBounds(text("确定"))
                        sleepRandom3()
                        clickControlBounds(text("不再提醒"))
                        sleepRandom1()
                        back()
                    }
                }
            }
        }
    } catch (error) {
        toastError(error);
    }
}
function autoSign() {
    if (clickControl(text("赚金币"))) {
        sleep(4000)
        clickControl(text("立即签到"))
        clickControl(id("img_close"))
    }
    clickControl(id("img_close"))
    clickVideoMenu()
}
function autoClearCache() {
    try {
        if (clickControl(text("我的"))) {
            if (clickControl(id("imgSetting"))) {
                if (clickControl(text("清理缓存"))) {
                    back()
                }
            }
        }
        clickVideoMenu()
    } catch (error) {
        toastError("清理缓存出现错误" + error);
    }
}
//id = txt_coin_close
/**
 * 强制停止app
 * @param {应用名称} appName 
 */
function stopApp(appName) {
    try {
        openAppSetting(getPackageName(appName));
        sleep(3000);
        if (className("android.widget.Button").text("强行停止").exists()) {
            className("android.widget.Button").text("强行停止").findOnce().click();
        } else {
            if (text("强行停止").exists()) {
                text("强行停止").findOnce().click();
            }
        }
        sleep(3000);
        if (className("android.widget.Button").text("确定").exists()) {
            className("android.widget.Button").text("确定").findOnce().click();
            toastLog(appName + "已经停止!");
        }
        else {
            if (text("强行停止").exists()) {
                text("强行停止").findOnce().click();
                toastLog(appName + "已经停止!");
            } else {
                if (text("结束运行").exists()) {
                    text("结束运行").findOnce().click();
                    sleep(500);
                    if (text("确定").exists()) {
                        text("确定").findOnce().click();
                        toastLog("MIUI9 Android7" + appName + "已经停止!");
                    }
                }
            }
        }
    } catch (e) {
        toastLog(e);
    }
}
/**
 * 倒计时方法适用于脚本
 * @param {倒计时时间} lasterTime 
 */
function cutDownBySleep(lasterTime) {
    for (let i = lasterTime; i => 0; i--) {
        console.info("剩余" + i + "秒...")
        sleep(1000)
        if (i == 1) {
            return
        }
    }
}
/**
 * 点击屏幕上的坐标
 * @param {坐标} b 
 */
function clickBounds(b) {
    return clickResult = click(b.centerX(), b.centerY());
}
/**
 * 点击屏幕上的坐标
 * @param {坐标} b 
 */
function clickControlBounds(element) {
    let clickResult = false;
    if (element == null) {
        return false;
    }
    try {
        if (element.exists()) {
            toastLog("准备click:" + element);
            let b = element.findOnce().bounds();
            clickResult = click(b.centerX(), b.centerY());
            sleep(random(2000, 3200));
        } else {
        }
        return clickResult;
    } catch (error) {
        toastError("clickControlBounds方法出现错误:" + error)
        return false;
    }
}
/**
 * 点击UI上的控件
 * @param {UI上的元素} element 
 */
function clickControl(element) {
    let clickResult = false;
    try {
        if (element.exists()) {
            toastLog("准备click:" + element.findOnce().getText());
            let clickable = element.findOnce().clickable();//是否可以点击
            if (clickable) {
                clickResult = element.findOnce().click();
                sleep(random(1000, 1200));
            } else {
                let b = element.findOnce().bounds();
                clickResult = click(b.centerX(), b.centerY());
                sleep(random(1000, 1200));
            }
        }
        return clickResult;
    } catch (error) {
        toastError(error)
        return false;
    }
}
/**
 * 元素对象
 * @param {ID或name} obj 
 */
function uiSelector(obj) {
    let element = null;
    try {
        if (text("" + obj + "").exists()) {
            element = text("" + obj + "");
            return element;
        }
        if (desc("" + obj + "").exists()) {
            element = desc("" + obj + "");
            return element;
        }
        if (id("" + obj + "").exists()) {
            element = id("" + obj + "");
            return element;
        }
    } catch (error) {
        return null;
    }
}
/**
 * 随机点赞
 * @param {点赞ID}} view_id 
 */
function randomHeart(view_id, probability) {
    index = random(1, parseInt(probability));
    if (index == 1) {
        var target = id(view_id).findOnce();
        if (target == null) {
            return;
        } else {
            target.click();
            sleep(1000);
        }
    }
}
/**
 * 随机关注
 * @param {控件ID} follow_view_id 
 * @param {概率} probability 
 */
function randomFollow(follow_view_id, probability) {
    index = random(1, parseInt(probability));
    if (index == 1) {
        var target = id(follow_view_id).findOnce();
        if (target == null) {
            return;
        } else {
            target.click();
            sleep(1000);
        }
    }
}
function clickCancle() {
    if (text("取消").exists()) {
        text("取消").findOnce().click();
    }
}
/**
 * 青少年窗口
 */
function adolescentWindows() {
    if (text("我知道了").exists()) {
        text("我知道了").findOnce().click();
    }
    if (text("知道了").exists()) {
        text("知道了").findOnce().click();
    }
}
/**
 * 直接无视
 */
function closeUpgrageTip() {
    if (text("直接无视").exists()) {
        text("直接无视").findOnce().click();
    }
    if (text("刷新重试").exists()) {
        text("刷新重试").findOnce().click();
    }
}
/**随机点赞并休息一秒 */
function randomHeart() {
    index = random(1, 10);
    if (index == 1) {
        var target = id('ic_like').findOnce();
        if (target == null) {
            return;
        } else {
            target.click();
            sleep(1000);
        }
    }
}
/**
 * 贝塞尔曲线
 * @param {坐标点} ScreenPoint 
 * @param {偏移量} Offset 
 */
function bezier_curves(ScreenPoint, Offset) {
    cx = 3.0 * (ScreenPoint[1].x - ScreenPoint[0].x);
    bx = 3.0 * (ScreenPoint[2].x - ScreenPoint[1].x) - cx;
    ax = ScreenPoint[3].x - ScreenPoint[0].x - cx - bx;
    cy = 3.0 * (ScreenPoint[1].y - ScreenPoint[0].y);
    by = 3.0 * (ScreenPoint[2].y - ScreenPoint[1].y) - cy;
    ay = ScreenPoint[3].y - ScreenPoint[0].y - cy - by;
    tSquared = Offset * Offset;
    tCubed = tSquared * Offset;
    result = {
        "x": 0,
        "y": 0
    };
    result.x = (ax * tCubed) + (bx * tSquared) + (cx * Offset) + ScreenPoint[0].x;
    result.y = (ay * tCubed) + (by * tSquared) + (cy * Offset) + ScreenPoint[0].y;
    return result;
}
/**
 * 滑动(默认概率是百分之三十)
 * @param {*} qx 
 * @param {*} qy 
 * @param {*} zx 
 * @param {*} zy 
 * @param {*} time 
 * @param {*} timesInterval 
 */
function slideScreenDown(qx, qy, zx, zy, time, timesInterval, CurveBrushScreen) {
    if (CurveBrushScreen) {
        curveDown(qx, qy, zx, zy, time, timesInterval); //曲线概率
    } else {
        lineDown(qx, qy, zx, zy, time, timesInterval); //直线概率
    }
}
/**
 * 概率0-9 大于3的时候采用曲线概率 小于3的时候直线概率
 */
function randomFunction() {
    return Math.floor(Math.random() * 10);
}
function curveDown(qx, qy, zx, zy, time, timesInterval) {
    toastInfo("曲线滑动");
    var xxy = [time];
    var point = [];
    var dx0 = {
        "x": qx,
        "y": qy
    };
    var dx1 = {
        "x": random(qx - 100, qx + 100),
        "y": random(qy, qy + 50)
    };
    var dx2 = {
        "x": random(zx - 100, zx + 100),
        "y": random(zy, zy + 50),
    };
    var dx3 = {
        "x": zx,
        "y": zy
    };
    for (var i = 0; i < 4; i++) {
        eval("point.push(dx" + i + ")");
    };
    for (let i = 0; i < 1; i += 0.08) {
        let newPoint = bezier_curves(point, i);
        xxyy = [parseInt(newPoint.x), parseInt(newPoint.y)]
        xxy.push(xxyy);
    }
    gesture.apply(null, xxy);
    let randomMin = timesInterval * 1000;
    let randomMax = (parseInt(timesInterval) + 2) * 1000;
    let delayTime = random(randomMin, randomMax);
    sleep(delayTime);
}
/**
 * 屏幕向下滑动并延迟8至12秒
 */
function lineDown(startX, startY, endX, endY, pressTime, timesInterval) {
    toastInfo("屏幕向下滑动");
    swipe(startX, startY, endX, endY, pressTime);
    let randomMin = timesInterval * 1000;
    let randomMax = (parseInt(timesInterval) + 2) * 1000;
    let delayTime = random(randomMin, randomMax);
    sleep(delayTime);
}
/**
 * 按照指定概率随机上滑
 * @param {*} startX 
 * @param {*} startY 
 * @param {*} endX 
 * @param {*} endY 
 * @param {*} pressTime 
 * @param {*} probability 
 */
function randomUpSildeScreen(startX, startY, endX, endY, pressTime, probability) {
    let randomIndex = random(1, parseInt(probability));
    if (randomIndex == 1) {
        swipe(startX, startY, endX, endY, pressTime);
        delayTime = random(12000, 15000);
        sleep(delayTime);
    }
}
/**
 * 连续下滑对上一个无兴趣
 * 其实得和上滑做个排他,既然无兴趣不要在上滑
 */
function randomDownSildeScreen(startX, startY, endX, endY, pressTime, timesInterval, probability) {
    let randomIndex = random(1, parseInt(probability));
    if (randomIndex == 1) {
        swipe(startX, startY, endX, endY, pressTime);
        sleep(2000);
        swipe(startX, startY, endX, endY, pressTime);
        sleep(timesInterval);
    }
}
/**
 *点击一下屏幕
 */
function clickScreen() {
    var x = device.width - device.width * 0.2;
    var y = device.height - device.height * 0.2;
    toastLog("点击屏幕" + x + ":" + y);
    let clickResult = click(x, y);
    toastLog(clickResult);
}
/**
 * 输出Tosat和Info日志
 * @param {日志消息} messagge 
 */
function toastInfo(message) {
    toast(message)
    console.info(message)
}
/**
 * 输出Tosat和Error日志
 * @param {日志消息} messagge 
 */
function toastError(message) {
    toast(message)
    console.error(message)
}
function toastLog(message) {
    toast(message)
    console.log(message)
}
function toastWarn(message) {
    toast(message)
    console.warn(message)
}
/**
 * 休眠随机0.1秒至0.5秒
 */
function sleepRandom0() {
    sleep(random(100, 500));
}
/**
 * 休眠随机1秒至3秒
 */
function sleepRandom1() {
    sleep(random(1000, 3000));
}
/**
 * 休眠随机3秒至5秒
 */
function sleepRandom3() {
    sleep(random(3000, 5000));
}
/**
 * 休眠随机5秒至7秒
 */
function sleepRandom5() {
    sleep(random(5000, 7000));
}
/**
 * 休眠随机7秒至9秒
 */
function sleepRandom7() {
    sleep(random(7000, 9000));
}
/**
 * 休眠随机11秒至9秒
 */
function sleepRandom9() {
    sleep(random(9000, 11000));
}/**
 * 显示控件的坐标
 * @param {要查找的元素} element 
 * @index {点击的顺序} index 
 */
function clickControlList(element, index) {
    try {
        let controlArray = element.find();
        if (controlArray != null) {
            let controlLength = controlArray.length;
            for (let i = 0; i < controlLength; i++) {
                toastLog(controlArray[i].bounds())
            }
            let b = controlArray[index].bounds()
            return clickBounds(b)
        } else {
            return false
        }
    } catch (error) {
        return false
    }
}

 

相关实践学习
通过日志服务实现云资源OSS的安全审计
本实验介绍如何通过日志服务实现云资源OSS的安全审计。
目录
相关文章
|
人工智能 自然语言处理 算法
国产新型AI编程助手—DevChat AI插件在VSCode中的应用
国产新型AI编程助手—DevChat AI插件在VSCode中的应用
525 0
|
9月前
|
人工智能 运维 监控
阿里云WAAP方案新升级:更智能、更高效、更易用
阿里云WAAP方案全新升级,涵盖Web防护、BOT管理和API安全三大领域,旨在应对数字化转型中的企业安全挑战。通过多引擎联合决策降低误报/漏报,增强BOT对抗能力,提升API安全的实时性和灵活性,助力企业实现更智能、高效、易用的安全防护。本次升级由阿里云安全专家魏根慧分享,针对当前网络攻击态势和企业合规、数据泄露等核心问题,提供全面解决方案。
183 11
|
12月前
|
Java Shell
「sh脚步模版自取」测试线排查的三个脚本:启动、停止、重启、日志保存
「sh脚步模版自取」测试线排查的三个脚本:启动、停止、重启、日志保存
172 1
|
12月前
|
运维 监控 Devops
DevOps实践:持续集成与部署的自动化之旅
【10月更文挑战第7天】在软件开发领域,DevOps已成为提升效率、加速交付和确保质量的关键策略。本文将深入探讨如何通过实施持续集成(CI)和持续部署(CD)来自动化开发流程,从而优化运维工作。我们将从基础概念入手,逐步过渡到实际操作,包括工具选择、流程设计以及监控和反馈机制的建立。最终,我们不仅会展示如何实现这一自动化流程,还会讨论如何克服常见的挑战,以确保成功实施。
167 9
|
7月前
|
人工智能 云栖大会 云计算
因AI相聚,新年启航
因AI相聚,新年启航
|
10月前
|
机器学习/深度学习 存储 人工智能
智能语音识别技术的深度剖析与应用前景####
本文深入探讨了智能语音识别技术的技术原理、关键技术突破及广泛应用场景,通过具体实例展现了该技术如何深刻改变我们的日常生活和工作方式。文章还分析了当前面临的挑战与未来发展趋势,为读者提供了一幅全面而深入的智能语音识别技术图景。 ####
[GHCTF 2024 新生赛]UP+——入土为安的第一天
[GHCTF 2024 新生赛]UP+——入土为安的第一天
220 0
|
JSON API 数据处理
深度解析京东商品列表数据接口:功能、参数与实战技巧
京东商品列表数据接口让开发者通过HTTP请求获取京东商品详尽列表信息,包括ID、名称、价格等。接口支持参数化搜索(关键词、价格区间等),返回JSON格式数据,便于处理与分析。开发者需注册账号并创建应用以获取访问权限。应用场景涵盖市场调研、商品管理和营销策略制定等,有效提升数据驱动决策能力。
|
小程序
微信小程序开发---购物商城系统。【详细业务需求描述+实现效果】
这篇文章详细介绍了作者开发的微信小程序购物商城系统,包括功能列表、项目结构、具体页面展示和部分源码,涵盖了从首页、商品分类、商品列表、商品详情、购物车、支付、订单查询、个人中心到商品收藏和意见反馈等多个页面的实现效果和业务需求描述。
微信小程序开发---购物商城系统。【详细业务需求描述+实现效果】
|
IDE Java Maven
Maven或Gradle:构建工具的使用和配置等知识讲解梳理
Maven或Gradle:构建工具的使用和配置等知识讲解梳理
354 1