社区应用 最新帖子 精华区 社区服务 会员列表 统计排行
  • 361阅读
  • 2回复

[分享]批处理一闪即逝的几种情况分析

楼层直达
z3960 
级别: FLY版主
发帖
786303
飞翔币
211574
威望
215717
飞扬币
2615486
信誉值
8



一、批处理文件名中包含“&”、“^”


此问题在Win7、Win8、Win10中都会出现,具体表现为使用右键以管理员身份运行时批处理一闪即逝,双击运行则正常。这个问题是本人在2010年12月发现的,应该是Windows的一个BUG,当时还发了几条微博。
假设文件名为“A&B.bat”,系统会认为“&”前后是两条语句,所以会执行“A”和“B.bat”。
假设文件名为“A^B.bat”,系统会忽略“^”,所以实际上运行的是“AB.bat”。
但是一般情况下当前文件夹中并没有“A”、“B.bat”、“AB.bat”这几个文件,于是就自动退出了。这里说明一下,运行“A”时,系统不会运行无扩展名的“A”,而是会按照环境变量%PATHEXT%里面的值“.COM;.EXE;.BAT;.CMD;.VBS;.VBE;.JS;.JSE;.WSF;.WSH;.MSC”按顺序进行查找“A.COM”、“A.EXE”……
为此我们可以进行验证,在某个文件夹中新建这6个文件A、A&B.bat、A.bat、A^B.bat、AB.bat、B.bat。
除A&B.bat和A^B.bat外,内容均为


[font=Consolas, Monaco, &quot]@[font=Consolas, Monaco, &quot]Echo [font=Consolas, Monaco, &quot]%~nx0[font=Consolas, Monaco, &quot]@[font=Consolas, Monaco, &quot]Pause
其中%~nx0表示当前批处理文件(0)的文件名(n)及扩展名(x)。A&B.bat和A^B.bat需要把%~nx0换成A^&B.bat和A^^B.bat,因为“&”和“^”都需要转义才能显示。
双击直接运行A&B.bat:


右键管理员身份运行A&B.bat:


你还可以将A.bat、B.bat删除其中一个或者都删除再看看运行结果,我就不截图了。A^B.bat的结果和A&B.bat类似,也不截图了。


二、环境变量%PATH%有问题


批处理中调用了系统目录下的程序,但是PATH有问题导致找不到文件。这个问题的起因,可能是你手工修改失误,也可能是安装了什么软件对PATH进行了修改,最常见的是MacType这个软件。
虽然FlyingSnow说MacType的这个BUG早已修复,但是本人Win7 x64亲测这个BUG在目前最新版2010.1231.0中依然存在,之前没有安装过任何旧版本MacType。
目前导致这个问题的具体原因还不太清楚,因为PATH看上去是正确的,一种可能有效的解决办法是在PATH最后加一个“;”再保存,如果不行可以再把最后的“;”删掉再保存。


三、批处理本身编写有误


拼写错误、忘记加pause这些低级错误我就不说了。说一个稍微高级一点儿的关于for的错误。
在批处理中for语句的变量都要写两个%,比如%%i,而在CMD中只需一个,这是一个比较容易出错的地方,如果在批处理中写成了%i,在运行到这条语句时就会提示错误然后自动退出。
下面介绍一种方法可以看到一闪即逝的错误,方便找到原因:
先Win+R打开运行窗口,输入CMD回车,打开CMD窗口,然后将批处理文件拖入CMD窗口,此时文件的路径会出现在屏幕上,然后按回车即可。
当然为了方便你也可以为bat文件添加一个右键菜单,具体步骤我就不讲了,Google有的是,命令行这样写


[font=Consolas, Monaco, &quot]"C:WindowsSystem32cmd.exe" [font=Consolas, Monaco, &quot]/k [font=Consolas, Monaco, &quot]"%1"


四、CMD被禁用


这个问题一般不会导致一闪即逝,而是会提示“命令提示符已被系统管理员停用”。

既可以在组策略中修改也可以在注册表中修改
  • 组策略中的位置:

Win+R打开运行窗口输入gpedit.msc回车打开组策略
左侧选择用户配置 – 管理模板 – 系统,然后右侧找到“阻止访问命令提示符”,选择未配置即可
  • 注册表中的位置:

DisableCMD键值的位置在
HKEY_CURRENT_USERSoftwarePoliciesMicrosoftWindowsSystem
DisableCMD为1表示禁用命令提示符和批处理文件,2表示只禁用命令提示符,改成0或者删除就可以解禁了

UPDATE: 如果修改后依然提示被禁用,可能是你中过病毒,修改了注册表
HKEY_LOCAL_MACHINESOFTWAREPoliciesMicrosoftWindowsSaferCodeIdentifiersPaths{403cf677-e149-45df-bf2d-b320958e5ada}
里面内容为
  • LastModified = AA 7A 59 05 D2 2C CC 01
  • Description = “”
  • SaferFlags = 0×00000000
  • ItemData = “cmd.exe”

将这个项{403cf677-e149-45df-bf2d-b320958e5ada}整个删除即可
关键词: bot 系统 软件 Win7
 
我不喜欢说话却每天说最多的话,我不喜欢笑却总笑个不停,身边的每个人都说我的生活好快乐,于是我也就认为自己真的快乐。可是为什么我会在一大群朋友中突然地就沉默,为什么在人群中看到个相似的背影就难过,看见秋天树木疯狂地掉叶子我就忘记了说话,看见天色渐晚路上暖黄色的灯火就忘记了自己原来的方向。
级别: 超级版主
发帖
883609
飞翔币
253127
威望
224883
飞扬币
2704510
信誉值
0

只看该作者 1 发表于: 2021-06-23
来看一下
级别: 超级版主
发帖
883609
飞翔币
253127
威望
224883
飞扬币
2704510
信誉值
0

只看该作者 2 发表于: 2021-06-23
不错,了解了