【发布时间】:2011-09-19 15:24:01
【问题描述】:
我有一个字符串列表,我想在单个 Windows 命令行调用中将这些字符串作为参数传递。对于简单的字母数字字符串,只需逐字传递它们就足够了:
> script.pl foo bar baz yes no
foo
bar
baz
yes
no
我了解如果参数包含空格或双引号,我需要反斜杠转义双引号和反斜杠,然后将参数双引号。
> script.pl foo bar baz "\"yes\"\\\"no\""
foo
bar
baz
"yes"\"no"
但是当我尝试使用文字百分号传递参数时,会发生这种情况:
> script.pl %PATH%
C:\Program
Files\PHP\;C:\spaceless\perl\bin\;C:\Program
Files\IBM\Java60\bin;
(...etc.)
双引号不起作用:
> script.pl "%PATH%"
C:\Program Files\PHP\;C:\spaceless\perl\bin\;C:\Program Files\IBM\Java60\bin; (...etc.)
也没有反斜杠转义(注意反斜杠是如何出现在输出中的):
> script.pl \%PATH\%
\%PATH\%
此外,反斜杠转义反斜杠的规则不一致:
> script.pl "\\yes\\"
\\yes\
> script.pl "\yes\\"
\yes\
> script.pl "\yes\"
\yes"
此外,毫无疑问,Windows 命令行 shell 中存在特殊字符,就像所有 shell 中一样。 那么,安全转义任意命令行参数以在 Windows 命令行中使用的一般过程是什么?
理想的答案将描述一个函数escape(),它可用于以下情况(Perl 示例):
$cmd = join " ", map { escape($_); } @args;
这里还有一些示例字符串应该被这个函数安全转义(我知道其中一些看起来像 Unix,这是故意的):
yes
no
child.exe
argument 1
Hello, world
Hello"world
\some\path with\spaces
C:\Program Files\
she said, "you had me at hello"
argument"2
\some\directory with\spaces\
"
\
\\
\\\
\\\\
\\\\\
"\
"\T
"\\T
!1
!A
"!\/'"
"Jeff's!"
$PATH
%PATH%
&
<>|&^
()%!^"<>&|
>\\.\nul
malicious argument"&whoami
*@$$A$@#?-_
【问题讨论】: