1.Auto.js快速入门实战教程
2.autojs之lua
3.autojsproå®ç¾ç ´è§£çï¼
4.请问如何屏蔽网页中的网页网页查看源文件(源代码)
Auto.js快速入门实战教程
在深入学习Auto.js之前,我们先来了解一下它的源码源码基本概念。官方定义,网页网页Auto.js是源码源码一种无需root权限的JavaScript自动化工具。本文主要针对有一定编程基础但对Auto.js不熟悉的网页网页读者,以实例指导开发自动完成淘宝领喵币任务的源码源码spring源码自检脚本,帮助快速上手。网页网页 开始之前,源码源码需要声明,网页网页由于Auto.js暂时下线,源码源码我通过群组获得了apk安装包和打包工具,网页网页但未经过官方验证,源码源码可能存在安全风险。网页网页强烈建议自行编译,源码源码使用时需谨慎,网页网页自行承担可能的风险。安装手机上的Auto.js后,记得打开无障碍模式和启用悬浮框以便脚本执行。 实战部分,首先打开淘宝,目标是点击"领喵币"按钮。为了简化脚本,我们将预先打开喵铺主页。具体步骤如下: 1. 通过函数viewWeb模拟浏览秒(考虑到可能的加载延迟,比官方要求多5秒),找到"去进店"或"去浏览"组件,点击进入广告页,完成后返回任务栏,直到"已完成"显示。 2. 浏览广告时,通过gesture函数进行屏幕滑动操作,表示上滑。广告完成后,通过back()模拟返回键回到任务栏。 3. 重要的是定位组件,desc()函数用于查找控件,找到黑马 源码其desc信息是"任务完成",务必查看控件信息以确保定位准确。 4. 脚本测试:在Auto.js应用中导入脚本,运行后在日志中查看执行情况,利用log()记录调试信息。 最后,完成代码编写后,可以打包成apk。以下是一些额外知识点:定位选择器:findOnce()找到第一个符合条件的控件,找不到则返回null,findOne()可能造成卡顿,需谨慎使用。
click()函数:点击时需确保元素的clickable属性为true,如果为false,可能需要点击其子或父控件。
源代码可以参考github.com/ErazerContro...,v1.0.0版本。最后,我推荐我的另一个项目CodeTop,它收集了各大互联网公司的算法题库,欢迎大家参与。autojs之lua
在autojs中使用lua能提升自动化脚本的灵活性和功能。为了实现这一目标,依赖于一个名为luaJ的java实现的lua脚本解释器。下面将逐步展示如何在autojs中集成lua,以及实现的步骤和效果展示。
首先,导入luaJ类,这是实现lua脚本运行的基础。确保在项目中正确导入此类,以利用luaJ的解释功能。
接下来,创建一个Globals对象,用于管理全局状态。通过这个对象,php源码基本可以轻松地在脚本中访问和设置全局变量,使脚本的使用更加灵活。
之后,执行lua文件成为关键步骤。通过加载lua文件并调用其中的函数或执行指令,可以实现自动化的任务,如模拟用户操作、自动化数据处理等。
获取lua变量的值,是进一步操作的基础。这允许根据脚本中的逻辑,动态地访问和使用变量,从而实现复杂的功能。
还有一种运行lua脚本的方式,即通过直接执行lua代码,而非加载文件。这种方式适合编写和执行简短的脚本,或在脚本执行过程中动态生成代码。
在实际应用中,一个典型的lua代码示例可以是自动化点击操作。通过编写简单的脚本,可以模拟用户点击屏幕上的特定位置,实现自动化任务。
完整源码示例如下:
lua
Globals.set('clickPosition', { x: , y: })
function doClick()
local position = Globals.get('clickPosition')
TouchAction(device).tap({ x: position.x, y: position.y}).perform()
end
以上源码展示了如何在autojs中集成lua,通过导入luaJ类、创建全局变量、执行lua代码来实现自动化功能。使用这种方法,可以极大地提升自动化脚本的效率和可扩展性。
autojsproå®ç¾ç ´è§£çï¼
Autojs微信èªå¨æä½å rootèæ¬æºç
æ们å¯ä»¥æ³ä¸ä¸åå ³å ¬ä¼å·çæ¥éª¤ï¼éæ©å ¬ä¼å·é¿æåæ¶ãæå¼å¾®ä¿¡è¿å ¥æåå页é¢æ§è¡èæ¬å°±å¯èªå¨ç¹èµãæå¼å¾®ä¿¡è¿å ¥è§é¢å·é¡µé¢å°±å¯èªå¨ç¹èµè¯è®ºã
ç®å讲就æ¯æ érootå°±å¯æ§è¡èæ¬å®ç°ææºèªå¨åæä½ãæå¼Autojsæ¥çå¸å±è·åç¹èµæ¡æ¶ä¿¡æ¯ï¼æ们å¯ä»¥çå°ç¹èµç©ºé´ç¹å»å±æ§ä½Falseè¿æ¶æ们å¯ä»¥æ¾ä»çç¶äº²æ¡æ¶è¿è¡æ¥çç´å°ç¹å»å±æ§ä½trueã
AutoJsææ°çæ¬apkç¹è²ï¼ç®åæç¨çèªå¨æä½å½æ°ï¼æ¬æµ®çªå½å¶åè¿è¡ï¼ä¸°å¯çææ¡£ãæç¨ä¸ç¤ºä¾ï¼æ´ä¸ä¸&强大çéæ©å¨APIï¼æä¾å¯¹å±å¹ä¸çæ§ä»¶ç寻æ¾ãéåãè·åä¿¡æ¯ãæä½çã
Autojsæ£æµå¹¶å¼å¯æ éç¢æå¡Auto.jsProåºäºæ§ä»¶çæä½ä¾èµäºæ éç¢æå¡ï¼å æ¤æ好å¨èæ¬è¿è¡å¼å§æ¶ï¼ç¡®ä¿æ éç¢æå¡å·²ç»å¯ç¨ãå¦æè¿è¡å°æ个éè¦æéçè¯å¥æ éç¢æå¡å¹¶æ²¡å¯å¨ï¼åä¼æåºå¼å¸¸å¹¶è·³è½¬å°æ éç¢æå¡çé¢ãè¿æ ·çç¨æ·ä½éªå¹¶ä¸å好ã
ä¸è¬å¤§é¨å软件é½ä¼ç´æ¥æ£ç´¢å¼å¯æ éç¢æå¡çåºç¨ä»èå¤å®ä½ æ¯å¦ä½¿ç¨èæ¬ã
å¨å®å设å¤ä¸å®è£ Auto.jsåºç¨ç¨åºãæå¼Auto.jsåºç¨ç¨åºï¼ç¹å»å·¦ä¸è§çèåæé®ï¼éæ©â设置âãå¨è®¾ç½®é¡µé¢ä¸ï¼æ¾å°âæ éç¢æå¡âé项ï¼ç¹å»è¿å ¥ãå¨æ éç¢æå¡é¡µé¢ä¸ï¼æ¾å°âAuto.jsâé项ï¼ç¹å»è¿å ¥ã
å¯ä»¥ãautojsæ¯å¯ä»¥ä¸å¼å¯æ éç¢æå¡è¿è¡çï¼æ¯ä¸æ¬¾æ°çææºèæ¬å¼åå·¥å ·ï¼å¼åè¯è¨æ¯JSï¼å¼åé¨æ§ä½ï¼åè¿ç½ç«å¼åçé½ä¼åJSã
autojsproæ¯ä»ä¹autojsproæ¯ä¸ä¸ªåèæ¬çä»è´¹è½¯ä»¶ã
AutoJSProå¨ææºä¸å¯ä»¥ä½¿ç¨File.save()å½æ°æ¥ä¿åæ件ï¼å¯ä»¥æå®æ件ååæ件å 容ï¼ä»¥åæ件çåå¨è·¯å¾ã
Auto.jsProåºäºæ§ä»¶çæä½ä¾èµäºæ éç¢æå¡ï¼å æ¤æ好å¨èæ¬è¿è¡å¼å§æ¶ï¼ç¡®ä¿æ éç¢æå¡å·²ç»å¯ç¨ãå¦æè¿è¡å°æ个éè¦æéçè¯å¥æ éç¢æå¡å¹¶æ²¡å¯å¨ï¼åä¼æåºå¼å¸¸å¹¶è·³è½¬å°æ éç¢æå¡çé¢ãè¿æ ·çç¨æ·ä½éªå¹¶ä¸å好ã
请问如何屏蔽网页中的查看源文件(源代码)
众所周知,要保护一个页面,最基础的就是要屏蔽右键。而现在网页上用得最多的是function click(),即下面这段代码:
〈script〉
function click(){
if(event.button==2){
alert( ’本网站欢迎您 !!’);
}
}
document.onmousedown=click
〈/script〉
但是这种屏蔽方法的破解方法也是众所周知的。那就是asp人员源码连续单击鼠标左键和右键便又可以看到右键菜单了。但是,我见过一种很好的屏蔽右键的方法。它的原理和上面所说的不同。它并不是用JS来编写的脚本,而是利用定义网页属性来起到限制的作用。而且,在屏蔽中应该尽量的避开使用JS脚本。因为只要浏览者把IE里的java script脚本禁用了。那么一切屏蔽都白费。
那么继续说那种通过修改网页属性的屏蔽右键的方法。这种方法利用了HTML里的〈body〉来作修改,它只有以下短短的一行代码:
〈body oncontextmenu=self.event.returnvalue=false〉
这里,定义了oncontextmenu。使得右键的值为false,起到了屏蔽右键的效果。现在,再试试看刚才的破解方法,已经不行了。左右键连击已经不能再打开右键菜单。不但是这个,再试试看其他的方法。无论你怎样的乱点,右键都没有用。因为在这个网页里,右键已经不存在了。对于一个不存在的功能键,你又能做什么呢?
但是,屏蔽了右键还不能解决问题。如果我要复制一段文字,或是一张。那么,把它选中后用ctrl+C 再用 ctrl+V不就可以复制粘贴了嘛。对了,接下来要讲的,就是触动注册源码屏蔽左键(什么?屏蔽左键?那这个网页不就差不多废掉了?别急,没说完呢,左键只有一项功能是很讨厌的)的选定功能。
那么,如上所说,用JS来屏蔽是没有用的,治标不治本的。那么,我们就还用网页的最基础的语言:HTML来定义吧。还是老招数,定义〈body〉。这次用的参数是:onselectstart。就是左键选定的参数。代码如下:
〈body onselectstart="return false"〉
这样,左键选定功能就给轻易屏蔽了。原理和上面的一样。现在,再用你的左键选择任意内容把,已经没有用了。自然也不能ctrl + C,ctrl +V了。那么,现在我们来把这两部分合并起来。彻底控制左右键!:
〈body oncontextmenu=self.event.returnvalue=false onselectstart="return
false"〉
现在,左右键的问题总算是解决了吧。
好,现在我们来看另一个问题。大家都知道,在IE浏览器的菜单栏里的“查看”项里。有一个“查看源代码”选项。这么一来,虽然我们屏蔽了右键里的查看源代码。但是,只要用菜单栏里的查看源代码,还是可以看到源代码的。这可怎么办呢?
我最初的想法是用框架来避开源代码的查看。也就是说,只要一个网页是嵌在框架里的,那么在菜单栏里选择查看源代码查看到的只是框架网页的源代码。一般格式如下:
〈html〉
〈head〉
〈meta HTTP-EQUIV="Content-Type" CONTENT="text/html; charset=gb"〉
〈title〉本网站标题〈/title〉
〈/head〉
〈frameset rows=",*" framespacing="0" border="0"
frameborder="0"〉
〈frame name="header" scrolling="no" noresize target="main"
src="top.htm"〉
〈frame name="main" src="main.htm" scrolling="auto"
target="_self"〉
〈noframes〉
〈body〉
〈p〉此网页使用了框架,但您的浏览器不支持框架。〈/p〉
〈/body〉
〈/noframes〉
〈/frameset〉
〈/html〉
这样看起来对方是没有直接看到你的源代码了。但是,如果一个人要看你的源代码,那他八成是能看懂的。如果懂一点HTML的话,都能看出这两句是什么意思:
〈frame name="header" scrolling="no" noresize target="main"
src="top.htm"〉
〈frame name="main" src="main.htm" scrolling="auto"
target="_self"〉
这两句的意思就是:在header(也就是网页顶部)处引用相对路径下的top.htm网页文件。而在main(也就是占据网页大部分页面的位置)处引用相对路径下的main.htm网页文件。就这两点是关键的,其他就不作解释了,大家也都懂的。而上面所讲的利用框架来隐藏源代码的方法就是将要显示页面放在main部分。而将header部分的大小设为0。但是这样一来,利用菜单栏里的查看源代码,还是能查看到框架网页的源代码。只要看到这两句,就知道我们前面用的手法了。也就是说,只要将框架网页的名字改为目标网页,便可以用相同的方法直接看到目标网页的源代码了。如:框架网页:/red.htm的源代码如上,就可以改为/main.htm。这样便可直接浏览被保护网页,屏蔽源代码的效果还是没有达到。
得到的永远比失去的多!
-4- : #1
UID
会员 狒狒
用户组 版主 [查看详情]
性别 : 男
阅读权限 :
来自 : 湖北 武汉
状态
帖子 [查看详情]
精华 3
主题
回复
积分策略 积分 :
现金 MMB 存款 MMB
星级
失踪 0 天 [查看详情]
注册 天
注册 -3-9
| 今日免费申请会员!
--------------------------------------------------------------------------------
那么,有些人就会想到,如果对方看不到框架网页的源代码。又何谈去直接打开被保护网页?对,这就是接下来我要讲的。如果要一个页面的菜单栏内的查看源代码失去效用。那最简单的办法就是去掉菜单栏。而这一点是可以通过弹出窗口来实现的。之所以不选用超链接打开无菜单栏窗口是因为那样会暴露目标地址,浏览者可以直接在浏览器中敲入地址,而绕过这个屏蔽的菜单栏。要使用超链接打开无菜单栏窗口,就必须在一个已受到源代码屏蔽保障的网页中使用相关链接。
那么,我们就看看如何利用弹出窗口来去掉菜单栏。其实,我们要做的,就是让目标网页在一个广告条中打开。这个代码几乎每个大型网站都会有的。代码如下:
〈script〉
〈!--
window.open("red.htm", "red", "resizable=yes,width=,height=");
--〉
〈/script〉
这里,在window.open后的括号里的第一个参数就是弹出窗口所显示的网页的位置,这里例子里是先对位置下的red.htm网页文件。这时运行便会谈出一个显示有red.htm的无菜单栏的窗口。好,我们的目的达到了。但是,这个窗口有一个缺陷,就是没有滚动条。因为在谈出窗口的语句:window.open里并没有关于滚动条的参数,(或是我不知道?欢迎高手来信指出),所以这里打开的网页建议只做成网页的导航页。
但是,用以上方法取消菜单栏,必须有一个第二方的网页来作弹出的工作。那么,这个用来弹出窗口的网页又成为了一个问题的所在。举例来说:假设,我们用一个index.htm来作弹出窗口的工作。也就是打开index.htm之后,会弹出red.htm的无菜单栏窗口。前面我们也提到了,如果知道了一个网页的地址后,无论这个网页是否隐藏在无菜单栏之下,你都能看到它的源代码。那么,不让这个red.htm的地址暴露也就成了解决这个问题的关键。但是,只要这个index.htm被打开,就可以看到源代码。但是,不妨反过来想想,如果我们把index.htm给关起来呢?只要在浏览者没有来得及查看index.htm之前将它关闭,就能保住它的源代码了。那么,在这个index.htm里就有得做些文章了。
那就是,添加关闭网页的代码。
那么,我们就可以用window.close来关闭窗口。代码如下:
〈script〉
〈!--
window.open();
--〉
〈/script〉
那么,现在我们把两部分代码合并起来。现在,得到的效果就是——直接有一个无菜单栏的窗口打开了。因为计算机的处理速度很快,如果我们将这两段代码紧接着写在一起,那么我们就只能看到新建的窗口。代码如下:
〈script〉
〈!--
window.open("red.htm", "red", "resizable=yes,width=,height=");
window.close();
--〉
〈/script〉
而原来的窗口,已在我们无察觉的情况下关闭了。这样,就别说查看该网页的源代码了。这里,加入上面源代码的网页起了一个跳板的作用。但是,在这里,我们要注意几点。第一,用来做跳板的网页不应该命名为index.htm。将它换一个名字,然后把默认首页的名字改为更改过的名字。这样,是浏览者能在输入网之后便自动访问该页。而又不致让对方知道该页的名称。如果不这样做,就会导致对方猜测出该页的位置。如:.0.0.0/index.htm。这样,就可以通过在浏览器中提交:View-Source:’)。当然,括号内也支持相对路径。最后写出来的格式应该是:
〈script〉
function open1(url){
newwin=window.open(url,’newwindow’,’fullscreen=1’)
newwin.resizeTo(,)
newwin.moveTo(screen.width/0-,screen.height/0-)
}
〈/script〉
〈body oncontextmenu=self.event.returnvalue=false onselectstart="return
false"〉
〈td width="%"〉〈a href="java script:open1(’main.htm’),window.close()"〉〈img
border="0" src="pic/blank1.gif" style="position: absolute;
left: ; top: " width="" height=""〉〈/a〉〈/td〉
〈/body〉
这样,我们就达到了打开无窗口边的网页了。并且,在这个网页中,会自动加入滚动条,这样,就不会像前面那样看不到下面的内容啦。
最后我们要做的工作,就是把每一页,或者你认为重要的关键的页面进行加密,就OK啦。怎样对网页的源代码进行加密就不用我多说了吧?网上到处都有,可以用工具,也可以自己写一个htm文件来转换。加密软件,我推荐“Batch
HTML Encryptor”,去google找吧。还有转换加密网页的代码如下:
〈HTML〉〈HEAD〉〈TITLE〉网页加密解密〈/TITLE〉
〈META pileIt.style.backgroundColor="#C0C0A8";
c.compileIt.style.cursor="hand";
c.select.style.backgroundColor="#C0C0A8";
c.select.style.cursor="hand";
c.view.style.backgroundColor="#C0C0A8";
c.view.style.cursor="hand";
c.retur.style.backgroundColor="#C0C0A8";
c.retur.style.cursor="hand";
c.clear.style.backgroundColor="#C0C0A8";
c.clear.style.cursor="hand";
}
else return;
}
/* Buttons Enlightment of "Compilation" panel */
function LightOn(what)
{
if (ie) what.style.backgroundColor = ’#E0E0D0’;
else return;
}
function FocusOn(what)
{
if (ie) what.style.backgroundColor = ’#EBEBEB’;
else return;
}
function LightOut(what)
{
if (ie) what.style.backgroundColor = ’#C0C0A8’;
else return;
}
function FocusOff(what)
{
if (ie) what.style.backgroundColor = ’#DDDDDD’;
else return;
}
/* Buttons Enlightment of "Compilation" panel */
function generate() /* Generation of "Compilation" */
{
code = document.pad.text.value;
if (code)
{
document.pad.text.value=’Compiling...Please wait!’;
setTimeout("compile()",);
}
else alert(’First enter something to compile and then press CompileIt’)
}
function compile() /* The "Compilation" */
{
document.pad.text.value=’’;
compilation=escape(code);
document.pad.text.value="〈script〉\n〈!--\ndocument.write(unescape(\""+compilation+"\"));\n//--〉\n〈\/script〉";
i++;
if (i=1) alert("Page compiled 1 time!");
else alert("Page compiled "+i+" times!");
}
function selectCode() /* Selecting "Compilation" for Copying */
{
if(document.pad.text.value.length〉0)
{
document.pad.text.focus();
document.pad.text.select();
}
else alert(’Nothing for be selected!’)
}
function preview() /* Preview for the "Compilation" */
{
if(document.pad.text.value.length〉0)
{
pr=window.open("","Preview","scrollbars=1,menubar=1,status=1,width=,height=,left=,top=");
pr.document.write(document.pad.text.value);
}
else alert(’Nothing for be previewed!’)
}
function uncompile() /* Decompiling a "Compilation" */
{
if (document.pad.text.value.length〉0)
{
source=unescape(document.pad.text.value);
document.pad.text.value=""+source+"";
}
else alert(’You need compiled code to uncompile it!’)
}
// --〉
〈/SCRIPT〉
〈BR〉〈B〉〈FONT color=#〉网页HTML源代码加密解密器〈/FONT〉〈/B〉〈/H2〉〈/DIV〉
〈TABLE cellSpacing=0 borderColorDark=# cellPadding= width=
align=center borderColorLight=#ffffff border=2〉
〈TBODY〉
〈TR〉
〈TD〉
〈DIV align=center〉〈BR〉将你的源代码贴到编辑区域即可〈BR〉〈BR〉
〈TABLE cellSpacing=0 cellPadding=0 width="%" border=0〉
〈TBODY〉
〈TR〉
〈TD width="%"〉〈!-- Compilation Panel --〉
〈FORM name=pad method=post align="center"〉
〈DIV align=center〉〈TEXTAREA style="WIDTH: %; BACKGROUND-COLOR: #ebebeb"
name=text rows= cols=〉〈/TEXTAREA〉
〈BR〉〈BR〉〈BR〉〈INPUT onmouseover=LightOn(this) onclick=generate() onmouseout=LightOut(this)
type=button value=加密 name=compileIt〉
〈INPUT onmouseover=LightOn(this) onclick=selectCode() onmouseout=LightOut(this)
type=button value=全选 name=select〉
〈INPUT onmouseover=LightOn(this) onclick=preview() onmouseout=LightOut(this)
type=button value=预览 name=view〉
〈INPUT onmouseover=LightOn(this) onclick=uncompile() onmouseout=LightOut(this)
type=button value=解密 name=retur〉
〈INPUT onmouseover=LightOn(this) onmouseout=LightOut(this) type=reset value=清除
name=clear〉
〈/DIV〉〈/FORM〉〈!-- Compilation Panel --〉〈/TD〉〈/TR〉〈/TBODY〉〈/TABLE〉〈/DIV〉〈/TD〉〈/TR〉〈/TBODY〉〈/TABLE〉
〈DIV align=center〉〈BR〉〈/DIV〉
〈DIV align=center〉〈/DIV〉 〈/TD〉〈/TR〉〈/TBODY〉〈/TABLE〉
〈/DIV〉
〈DIV〉〈/DIV〉〈/BODY〉〈/HTML〉
总结一下……按我的思路,屏蔽网页源代码主要分为以下几个步骤:
1. 做一个网页跳板,弹出要保护的广告条状页面,并将自身关闭,以避免泄露需保护网页的地址。
2. 由于上述条件屏蔽了广告条内网页的源代码,所以可以用这个网页作为欢迎页。
3. 在欢迎页中,利用java script以超连接的形式来打开无窗口边的新窗口显示网站内容。
4. 对每一个页面或者对重要的关键的页面进行源代码加密,为源代码加一把锁。(有些人说对源代码进行加密没有用,但是我觉得要使用另类点的加密方法就可以了,比如软件的加密方法就很普通。但是用我自己写的htm文件加密的源代码,一般软件是不能进行解密的。大家有兴趣的话可以试试。)
5. 最后不得不提的就是windows网页临时文件夹了,那里面会把源代码纪录的。但是不用怕,加入一种代码,就可以使windows不下载网页的源代码,直接浏览。可以去找找。
有些东西要注意的:
1. 在文中所说的自动关闭网页的语句:window.close()有一个弊病。就是会在关闭窗口之前询问是否关闭窗口,如果选择否的话目的还是达不到。
2. 以上一切都只对IE浏览器有效用,如果用别的浏览器来浏览,就有可能出现屏蔽不成功的现象。
3. 关于网页源代码屏蔽,一直以来是可望而不可及的。我只是把思路写下来,具体实现,还是要靠大家自己研究的啦。
2025-01-16 11:53
2025-01-16 11:21
2025-01-16 10:51
2025-01-16 09:43
2025-01-16 09:42
2025-01-16 09:32