小编Ein*_*969的帖子

如何在这个混合的 cmd/powershell 代码中转义有毒字符?

我要求第一个解释“这里”和“这里”,但要尝试更复杂的情况,我无法(经过两个小时的尝试)了解如何解决。我读了正则表达式的工作原理,但一无所获,我陷入了困境。

修改后的代码是这样的:

(Fsutil Dirty Query %SystemDrive%>Nul)||(powershell.exe -c "[Environment]::CommandLine; Start -Verb RunAs cmd /k, ("^""%~f0"^"" -replace '[;,()= &^]', '^$&')" & echo exit)
Run Code Online (Sandbox Code Playgroud)

带有毒字符的文件夹是这样的:

C:\Users\fposc\Desktop\Pie & tea % @ ' $^
Run Code Online (Sandbox Code Playgroud)

我尝试用 \^ 转义正则表达式中的 ^ 但不起作用。我也用 \( 和 \) 逃脱了 ( 和 ) 。但没有任何作用:

(Fsutil Dirty Query %SystemDrive%>Nul)||(powershell.exe -c "[Environment]::CommandLine; Start -Verb RunAs cmd /c, ("^""%~f0"^"" -replace '[;,\(\)= &\^]', '^$&')" & exit)
Run Code Online (Sandbox Code Playgroud)

我添加了圆括号,因为我想放置所有可能的字符以使代码尽可能通用。

我不知道我提出另一个问题是否正确。也许我应该改变原来的问题?由于其他组合也是可能的,并且不了解该机制,因此我可以提出许多其他类似的问题。你建议我做什么?

windows powershell cmd batch-file

1
推荐指数
1
解决办法
147
查看次数

标签 统计

batch-file ×1

cmd ×1

powershell ×1

windows ×1