【无标题】使用Go (或者 Python) 执行外部命令,直接模式和 Shell模式的区别

有时,我们需要通过编程语言执行外部程序、命令或脚本。

Go 语言里提供了 “os/exec” 库,Python 里面也提供了 subprocess 这样的库。

但在具体调用外部命令时,有两种方式:

  • 直接调用外部命令
  • 通过 Shell 调用外部命令

以 Go 语言为例:

cmd := exec.Command("./myscript.sh", "arg1", "arg2") // 直接执行外部命令

或者

cmd := exec.Command("sh", "-c", "./myscript.sh arg1 arg2")// 通过 Shell 调用外部命令

两者的区别如下:

直接运行 通过 SHELL 运行
参数必须以字符串数组的形式传入,不能把多个参数用空格拼接成一个字符串 把命令和参数合并居一个字符串,传给 Shell 执行
不支持 Shell 的特性,比如环境变量,通配符,管道,重定向 支持 Shell 特性,比如环境变理,通配符,管道,重定向
把参数直接传给命令,不会对参数进行解析,比如根据空格把一个字符串分成多个参数 对整个命令行字符串进行解析,但不同的操作系统 / Shell 可能把字符串解析成不同的结果
不会引起 Shell 注入 可能面临 Shell 注入的风险
继承 Go 的环境 继承 Shell 的环境变量

我个人喜欢直接执行的方式。

你可能感兴趣的:(golang,python,服务器)