加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 综合聚焦 > 服务器 > 安全 > 正文

Bash:如何逃避$@?

发布时间:2020-12-16 01:18:41 所属栏目:安全 来源:网络整理
导读:我需要编写一个bash脚本,除其他外,应将其所有参数原封不动地传递给另一个程序. 最小的例子: $cat proxy.sh #!/bin/bash./script.sh $@^D$chmod +x proxy.sh $cat script.sh #!/bin/bashecho one $1echo two $2echo three $3 ^D$chmod +x script.sh 这种天真
我需要编写一个bash脚本,除其他外,应将其所有参数原封不动地传递给另一个程序.

最小的例子:

$cat >proxy.sh 
#!/bin/bash

./script.sh $@
^D

$chmod +x proxy.sh 

$cat >script.sh 
#!/bin/bash

echo one $1
echo two $2
echo three $3 
^D

$chmod +x script.sh 

这种天真的方法不适用于带空格的参数:

$./proxy.sh "a b" c
one a
two b
three c

预期:

$./proxy.sh "a b" c
one a b
two c
three

我应该在proxy.sh中写什么才能实现?

请注意,我不能使用别名,proxy.sh必须是一个脚本 – 它在调用script.sh之前会做一些事情.

引用$@,使其成为“$@”:
$cat >proxy.sh 
#!/bin/bash

./script.sh "$@"
^D

然后它保留原始报价:

one a b
two c
three

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读