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

避免’sudo echo x >’ 时’Permission denied’ 甲: 示例 s

发布时间:2020-12-15 16:27:57 所属栏目:安全 来源:网络整理
导读:换了公司,没有root权限后,发现还有这种破问题 避免’sudo echo x ’ 时’Permission denied’ 甲: 示例 sudo echo a 1.txt -bash: 1.txt: Permission denied 乙: 分析: bash 拒绝这么做,说是权限不够. 这是因为重定向符号 “” 也是 bash 的命令。sudo

换了公司,没有root权限后,发现还有这种破问题


避免’sudo echo x >’ 时’Permission denied’

甲: 示例
sudo echo a > 1.txt
-bash: 1.txt: Permission denied
乙: 分析:
bash 拒绝这么做,说是权限不够.
这是因为重定向符号 “>” 也是 bash 的命令。sudo 只是让 echo 命令具有了 root 权限,
但是没有让 “>” 命令也具有root 权限,所以 bash 会认为这个命令没有写入信息的权限。
丙: 解决办法。三种:
1. 利用 “sh -c” 命令,它可以让 bash 将一个字串作为完整的命令来执行,这样就可以将 sudo 的影响范围扩展到整条命令。
具体用法如下:

sudo sh -c "echo a > 1.txt"

利用bash -c 也是一样的,现在bash shell 流行。


2. 利用管道和 tee 命令,该命令可以从标准输入中读入信息并将其写入标准输出或文件中,
具体用法如下:
echo a |sudo tee 1.txt

echo a |sudo tee -a 1.txt // -a 是追加的意思,等同于 >>

tee 命令很好用,它从管道接受信息,一边向屏幕输出,一边向文件写入。

Linux总是有一些小工具为我们考虑的很贴切!


3. 提升shell 权限。
sudo -s //提到root 权限。提示符为#
当你觉得该退回到普通权限时,
sudo su username //退回到username 权限,提示符为$

centos 提升权限: su -

ubuntu 提升权限: sudu -s,sudo su

(编辑:李大同)

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

    推荐文章
      热点阅读