登录
首页 >  文章 >  前端

这个 Windows 脚本并不是在寻求帮助

来源:dev.to

时间:2024-11-12 19:48:56 150浏览 收藏

有志者,事竟成!如果你在学习文章,那么本文《这个 Windows 脚本并不是在寻求帮助》,就很适合你!文章讲解的知识点主要包括,若是你对本文感兴趣,或者是想搞懂其中某个知识点,就请你继续往下看吧~

这个 Windows 脚本并不是在寻求帮助

0< /* ::

@echo off

set /a min = 15
set /a max = 45

:loop

CScript //nologo //E:JScript "%~F0" "+{F15}"
set /a rand = (%RANDOM% * (%max% - %min% + 1) / 32768) + %min% + 1
ping -n %rand% -w 1 127.0.0.1 > NUL

goto :loop

*/ 0;

WScript.CreateObject("WScript.Shell").SendKeys(WScript.Arguments(0));

这是做什么的?

花点时间看看你是否能弄清楚这里发生了什么。

继续。我会等待 15 到 45 秒,然后发送 shift + f15 组合键。

你为什么要这么做?

因为 f15 键存在,但大多数键盘不再有它,所以按 shift + f15 不太可能做任何事情,除了作为一般按下的组合键,在大多数情况下阻止计算机休眠(某些 vdi 除外)设置)。

它无需管理员权限即可在普通 windows 安装上运行,尽管有些管理员禁用 jscript。

如何...

0< /* :: 是来自文件描述符 0 的文件的输入重定向,这是一种特殊情况,指的是标准输入 (stdin)。例如,如果您运行 0< test.txt find "hello",shell 实际上会运行 find "hello" 0<test.txt,这相当于运行 find "hello",然后将 test.txt 的内容输入到迅速的。那么这有什么作用呢? 0< /* 实际上会产生错误。但是,当您在末尾添加注释命令(:: 或 rem)时,该命令将变为 :: 0< /* ,它不会执行任何操作,因为它是注释。我们使用 :: 而不是 rem,因为 rem 会将行打印到终端,而 :: 不会这样做,所以从美观角度来说 :: 更好。

那么当任何字符串都可以去那里时为什么要使用 /* 呢?因为这是 javascript/jscript 块注释的开始,并且 jscript 解释器不需要尝试解析 /* 和 */ 之间的批处理脚本。那么 jscript 解释器如何看到这段代码呢?它读取从 0< /* :: 到 */ 0 的整个块;如:0 < 0;它的计算结果为 false,但这并不重要 - 它是有效的 jscript,没有任何副作用,并且主要障碍已经完成:一种根据正在读取文件的解释器有选择地解析批处理脚本或 jscript 的方法。

我将跳过关闭回显、设置变量和标签循环,因为这些都是相当简单的概念,尽管有趣的事实 - ecmascript 也有标签。

下一个重要的行是 cscript //nologo //e:jscript "%~f0" "+{f15}",它将这个 .bat 文件发送到 cscript。 cscript 在命令行环境中启动一个脚本,有多个脚本引擎选择(本例中为 jscript)。 wscript 类似,但在 windows gui 中运行脚本,并且在此上下文中与批处理文件中的最后一行并不完全相关。 $~f0 是当前运行的批处理文件的完整路径、文件名和扩展名。 +{f15} 是 shift 键,f15 键是 sendkeys。重申一下,当发送此批处理文件时,它会将整个批处理脚本视为 0<0;然后运行最后一行,这也是有效的 jscript。

关于 set /a rand = (%random% * (%max% - %min% + 1) / 32768) + %min% + 1 唯一有趣的是 %random% 是一个内置变量生成 0 到 32767(含)之间的整数,使用 set /a 总是向下舍入,最后一个 + 1 专门用于下一行;当使用睡眠或超时时,您不会添加额外的1。

下一行, ping -n %rand% -w 1 127.0.0.1 > nul 是创建计时器的旧方法,它比睡眠和超时​​对处理器的占用更少。您基本上会 ping 自己 %rand% 次,每次尝试之间间隔 1 秒;上一行的 +1 是因为在第一次 ping 之前没有等待。 > nul 将标准输出重定向到 nul,这当然只是丢弃它。

如果这个脚本没有无限循环,你需要在 */ 0; 之前有一个 goto :eof使您的批处理脚本跳过文件中无效脚本的其余部分。

我们终于到了最后,看到了实际的 jscript:wscript.createobject("wscript.shell").sendkeys(wscript.arguments(0));。 jscript 大致相当于 javascript 1.5/ecmascript3,并且具有大致类似于 vbscript 的 wscript api。

包起来

可能不要这样做。但也许您可能想要这样做,现在其中一些是有道理的。

今天带大家了解了的相关知识,希望对你有所帮助;关于文章的技术知识我们会一点点深入介绍,欢迎大家关注golang学习网公众号,一起学习编程~

声明:本文转载于:dev.to 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>