shell 管道符| 后面的xargs 一次执行多条命令,用xargs获取到的参数
find ./*.js|xargs -i sh -c 'ls -l {}; cat -n {}'|vim -
这条命令不是很安全,This is insecure. What if your file.txt contains a datum with $(rm -rf ~) as a substring?
ls $(rm -rf ./*) 执行这条命令的时候,会把当前目录下面的东西全部删除!!
这台命令可以先输出文件名,然后再打印文件的内容。
cat file.txt | xargs -i sh -c 'command {} | command2 {} && command3 {}'
file.txt
$(rm -rf ~)
"sh -c" 命令,它可以让 bash 将一个字串作为完整的命令来执行,
reference: https://stackoverflow.com/questions/6958689/calling-multiple-commands-with-xargs
-----------------------------------------------------------------------
在Linux使用 echo 并配合命令重定向是实现向文件中写入信息的快捷方式。 比如要向 test.asc 文件中随便写入点内容,可以: $ echo "信息" > test.asc # 或者 $ echo "信息" >> test.asc 下面,如果将 test.asc 权限设置为只有 root 用户才有权限进行写操作: $ sudo chown root.root test.asc 然后,我们使用 sudo 并配合 echo 命令再次向修改权限之后的 test.asc 文件中写入信息: $ sudo echo "又一行信息" >> test.asc -bash: test.asc: Permission denied 这时,可以看到 bash 拒绝这么做,说是权限不够。这是因为重定向符号 “>” 和 ">>" 也是 bash 的命令。我们使用 sudo 只是让 echo 命令具有了 root 权限,但是没有让 “>” 和 ">>" 命令也具有 root 权限,所以 bash 会认为这两个命令都没有像 test.asc 文件写入信息的权限。 解决这一问题的途径有两种。第一种是利用 "sh -c" 命令,它可以让 bash 将一个字串作为完整的命令来执行,这样就可以将 sudo 的影响范围扩展到整条命令。具体用法如下: $ sudo sh -c 'echo "又一行信息" >> test.asc' 另一种方法是利用管道和 tee 命令,该命令可以从标准输入中读入信息并将其写入标准输出或文件中,具体用法如下: $ echo "第三条信息" | sudo tee -a test.asc 注意,tee 命令的 "-a" 选项的作用等同于 ">>" 命令,如果去除该选项,那么 tee 命令的作用就等同于 ">" 命令。
标签:
shell
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· AI与.NET技术实操系列:基于图像分类模型对图像进行分类
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· 25岁的心里话
· ollama系列01:轻松3步本地部署deepseek,普通电脑可用
· 按钮权限的设计及实现
2019-01-15 【转】Linux防火墙(iptables)之黑名单