bash:权限不够

今天在ubuntu下面用终端打开一个文件的时候,出现了这个问题。突然想起来这个文件是只读的,所以要开放它的用户权限。

具体的实现如下 chmod 777 /home/example/filename.这样就开放了这个文件的所有权限,可以尽情的访问了。关于chmod的具体说明如下:

变更文件或目录的权限。在UNIX系统家族里,文件或目录权限的控制分别以读取,写入,执行3种一般权限来区分,另有3种特殊权限可供运用,再搭配拥有者与所属群组管理权限范围。您可以使用chmod指令去变更文件与目录的权限,设置方式采用文字或数字代号皆可。符号连接的权限无法变更,如果您对符号连接修改权限,其改变会作用在被连接的原始文件。权限范围的表示法如下:
u:User,即文件或目录的拥有者。
g:Group,即文件或目录的所属群组。
o:Other,除了文件或目录拥有者或所属群组之外,其他用户皆属于这个范围。
a:All,即全部的用户,包含拥有者,所属群组以及其他用户。
有关权限代号的部分,列表于下:
r:读取权限,数字代号为"4"。
w:写入权限,数字代号为"2"。
x:执行或切换权限,数字代号为"1"。
-:不具任何权限,数字代号为"0"。
s:当文件被执行时,根据who参数指定的用户类型设置文件的setuid或者setgid权限


语法

chmod [-cfRv][--help][--version][<权限范围>+/-/=<权限设置...>][文件或目录...]
chmod [-cfRv][--help][--version][数字代号][文件或目录...]
chmod [-cfRv][--help][--reference=<参考文件或目录>][--version][文件或目录...]

选项说明

-c或--changes  效果类似"-v"参数,但仅回报更改的部分。
-f或--quiet或--silent  不显示错误信息
-R或--recursive  递归处理,将指定目录下的所有文件及子目录一并处理。
-v或--verbose  显示指令执行过程。
--help  在线帮助。
--reference=<参考文件或目录>  把指定文件或目录的权限全部设成和参考文件或目录的权限相同
--version  显示版本信息。
<权限范围>+<权限设置>  开启权限范围的文件或目录的该项权限设置。
<权限范围>-<权限设置>  关闭权限范围的文件或目录的该项权限设置。
<权限范围>=<权限设置>  指定权限范围的文件或目录的该项权限设置。

范例

范例一 :将档案 file1.txt 设为所有人皆可读取 :
chmod ugo+r file1.txt
将档案 file1.txt 设为所有人皆可读取 :
chmod a+r file1.txt
将档案 file1.txt 与 file2.txt 设为该档案拥有者,与其所属同一个群体者可写入,但其他以外的人则不可写入 :
chmod ug+w,o-w file1.txt file2.txt
将 ex1.设定为只有该档案拥有者可以执行 :
chmod u+x ex1
将目前目录下的所有档案与子目录皆设为任何人可读取 :
chmod -R a+r *
当其他用户执行oracle的sqlplus这个程序时,他的身份因这个程序暂时变成oracle
chmod u+s sqlplus
此外,chmod也可以用数字来表示权限如 chmod 777 file
语法为:chmod abc file
其中a,b,c各为一个数字,分别表示User、Group、及Other的权限。
r=4,w=2,x=1
若要rwx属性则4+2+1=7;
若要rw-属性则4+2=6;
若要r-x属性则4+1=5。
范例二
chmod a=rwx file
chmod 777 file
效果相同
chmod ug=rwx,o=x file
chmod 771 file
效果相同
若用chmod 4755 filename可使此程式具有root的权限
范例三
如果在cd /media/amasun/java/develop/array之后执行
chmod 777 ./
是将本目录(即/media/amasun/java/develop/array)设为任何人可读,写,执行
如果是管理员也就是常说的ROOT用户的话,基本上有可以查看所有文件的权力.

  • 5
    点赞
  • 37
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 这个错误提示表明你尝试执行一个需要更高权限的命令,但当前用户的权限不足以执行该命令。通常解决这个问题的方法是以管理员权限运行该命令,可以使用sudo命令来提升权限。在终端中输入sudo加上要执行的命令,然后输入管理员密码即可。例如: sudo apt-get update 这将以管理员权限运行apt-get update命令,以便更新Ubuntu软件包。如果你不确定需要以管理员权限运行哪个命令,可以查看相关的文档或向社区求助。 ### 回答2: 当Ubuntu显示bash:权限不够时,这意味着当前用户没有足够的权限来执行特定的操作。这个错误通常发生在尝试运行某个需要管理员权限的命令时。 要解决这个问题,你可以尝试以下几个解决方案: 1. 使用sudo命令:sudo是Ubuntu中用于以管理员身份运行命令的命令。在命令前添加sudo并输入管理员密码,可以临时提升当前用户的权限以执行命令。例如,如果你想安装软件包,可以使用命令sudo apt-get install package_name。 2. 切换到root用户:如果你需要进行多个需要管理员权限的操作,可以切换到root用户。使用命令sudo su可以切换到root用户,并在此期间无需再输入sudo来执行命令。在完成需要管理员权限的操作后,记得用exit命令退出root用户。 3. 修改文件权限:如果问题发生在特定的文件上,并且你确定需要修改该文件,请使用chmod命令来更改文件的权限。例如,使用命令chmod +x filename来使文件具有可执行权限。 4. 确保当前用户拥有足够的权限:有时,当前用户可能没有足够的权限来执行某个操作。确保你是该文件或目录的所有者,并且有足够的权限来执行所需的操作。 在解决权限问题时,请谨慎操作,并确保理解自己要做出的更改。不正确的权限更改可能导致系统不稳定或安全漏洞。 ### 回答3: 当在Ubuntu系统中看到"bash:权限不够"的错误提示时,这意味着当前用户没有足够的权限执行该命令或访问特定文件。要解决这个问题,可以尝试以下几种解决方案: 1. 使用sudo命令:在命令前添加"sudo"可以获得更高的权限执行该命令。输入sudo后,系统会要求你输入密码,输入密码后即可执行命令。 2. 修改文件和目录权限:使用chmod命令更改文件和目录的权限,以便当前用户可以执行或访问它们。例如,使用"chmod +x filename"命令可以给文件添加可执行权限。 3. 切换到root用户:如果sudo命令不起作用,可以尝试切换到root用户来执行该命令。使用"sudo su"命令可以切换到root用户,然后再尝试执行命令。 4. 检查文件所有者:使用ls -l命令查看文件或目录的所有者和权限。如果当前用户不是所有者,可能无法执行该命令。可以使用chown命令更改文件或目录的所有者,以便当前用户可以执行它们。 5. 检查文件系统权限:如果对整个文件系统的访问权限不足,可能需要使用管理员权限进行修改。可以使用fsck命令检查和修复文件系统中的错误,并确保文件系统权限正确。 总之,"bash:权限不够"的错误提示通常表示当前用户没有足够的权限执行该命令或访问特定文件。通过使用sudo命令、修改文件和目录权限、切换到root用户、检查文件所有者和检查文件系统权限等方法,可以解决这个问题。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值