1、首先,連接相應linux主機,進入到linux命令行狀態(tài)下,等待輸入shell指令。
創(chuàng)新互聯(lián)公司是一家專業(yè)提供豐縣企業(yè)網(wǎng)站建設,專注與網(wǎng)站設計、成都網(wǎng)站制作、H5技術、小程序制作等業(yè)務。10年已為豐縣眾多企業(yè)、政府機構等服務。創(chuàng)新互聯(lián)專業(yè)網(wǎng)站設計公司優(yōu)惠進行中。
2、在linux命令行下輸入shell指令:chmod666/test。
3、鍵盤按“回車鍵”運行shell指令,此時會看到test文件夾被設置為了只有讀寫權限,沒有執(zhí)行權限的狀態(tài)。
Linux系統(tǒng)中的用戶是分角色的,用戶的角色是由UID和GID來識別的(也就是說系統(tǒng)是識別的是用戶的UID、GID,而非用戶用戶名),一個UID是唯一(系統(tǒng)中唯一如同身份證一樣)用來標識系統(tǒng)的用戶賬號(用戶名)。
文件的用戶與用戶組分為超級管理員,普通用戶和系統(tǒng)用戶。
1)超級管理員的UID=0,GID=0,也可以這么說系統(tǒng)只要是識別出某個用戶的UID\GID都為0時,那么這個用戶系統(tǒng)就認為是超級管理員。
2)普通用戶(管理員添加的),默認它的UID\GID是從500-65535,權限很小,只能操作自己的家目錄中文件及子目錄(注:nobody它的UID\GID是65534)。
3)系統(tǒng)用戶,也稱虛擬用戶,也就是安裝系統(tǒng)時就默認存在的且不可登陸系統(tǒng),它們的UID\GID是1-499。
我們可以通過cat /etc/passwd命令來查看所有的用戶信息,例如下圖,第三列是UID,第四列是GID:
創(chuàng)建用戶
useradd user1 創(chuàng)建用戶user1
useradd -e 12/30/2021 user2 創(chuàng)建用戶user2,有效期到2021-12-30
設置用戶密碼
passwd user1 設置密碼,有設置密碼的用戶不能用
這里設置密碼時可能會碰到密碼保護機制問題,這里需要注釋掉保護機制的問題
這個時候需要在編輯/etc/pam.d/system-auth文件,將其中的password requisite
和password sufficient兩行注釋掉,如下圖:
創(chuàng)建用戶組
groupadd –g 888 users 創(chuàng)建一個組users,其GID為888
groupadd users 不用g參數(shù),使用默認的組ID
命令 gpasswd為組添加用戶
只有root和組管理員能夠改變組的成員:
gpasswd –a user1 users 把 user1加入users組
gpasswd –d user1 users 把 user1退出users組
命令groupmod修改組
groupmod –n user2 user1 修改組名user1為user2
groupdel刪除組
groupdel users 刪除組users
真正從安全性角度上來考慮的話,是要控制用戶一定執(zhí)行命令的權限,也就是哪些用戶可以執(zhí)行哪些命令,不可以執(zhí)行哪些命令,因此也就有了sudo這個應用,對于sudo提權,也就是修改/etc/sudoers的配置文件。
linux權限設置命令用ls命令所得到的表示法的格式是類似這樣的:-rwxr-xr-x 。下面解析一下格式所表示的意思。這種表示方法一共有十位: 9 8 7 6 5 4 3 2 1 0 - r w x r - x r - x 第9位表示文件類型,可以為p、d、l、s、c、b和-: p表示命名管道文件 d表示目錄文件 l表示符號連接文件 -表示普通文件 s表示socket文件 c表示字符設備文件 b表示塊設備文件 第8-6位、5-3位、2-0位分別表示文件所有者的權限,同組用戶的權限,其他用戶的權限,其形式為rwx。linux下用chmod(change file modebit)改變一個文件的權限一般有兩種方式:1、chmod [ugoa][+-=][rwx] filename這種方法很直觀,u代表擁有者(user),g代表組(group),o代表其它用戶(other),a代表所有用戶(all)。+-=代表增加、去除、設置為相應的權限。rwx分別代表讀(read)、寫(write)、執(zhí)行(exe)。比如chmod a+x filname 表示對所有用戶增加對filename的執(zhí)行權限。2.setUid,setGid如果一個命令被設置了SUID,那么這個命令在執(zhí)行期間,執(zhí)行這個命令的用戶就具有了這個命令的屬主的權限;如果一個命令被設置了SGID,那么這個命令在執(zhí)行期間,執(zhí)行這個命令的用戶就具有了這個命令的屬組的權限.設置SetUid權限: chmod 4xxx filename取消SetUid權限: chmod xxx filename設置SetGid權限: chmod 2xxx filename取消SetGid權限: chmod xxx filename如果執(zhí)行chmod 6xxx filename命令即可同時為指定文件設置SetUid和SetGid,執(zhí)行命令chmod 0xxx filename,即可同時取消指定文件的SetUid和SetGid權限。
命令名稱:chmod
命令英文原意:change the permissions mode of a file
有兩種角色可以執(zhí)行該命令,一種是 root 用戶,另一種就是文件的所有者。
語法:
大括號里的內容表示只能選一個,其中 u 表示該文件的所有者,g 表示所屬組,o 表示其他人,a 表示所有角色。
比如,給 abc.txt 文件的所屬組加一個寫的權限:
也可以同時做多個授權,比如給文件所有者加上執(zhí)行權限,給其他人去掉寫權限:
還可以用數(shù)字表示權限。權限的數(shù)字表示:
如果一個文件的權限是 rw-r--r--,那么翻譯成數(shù)字就是 644,反過來,如果要更改文件的權限,可以這樣寫:
這樣文件的權限就改成 rw-r----- 了。
還有一個選項 -R 是遞歸修改權限,該選項的功能是更改某個目錄的權限的同時更改該目錄下所有的子目錄和文件的權限。
命令名稱: chown
英文原意:change owner
語法:chown 用戶名 文件
只有管理員賬戶可以更改文件的所屬用戶。
例如:
命令名稱:chgrp
英文原意:change group
語法:chgrp 組名 文件
例如:
命令名稱:umask
使用命令 umask -S 可以查看新建文件或目錄的默認權限。
現(xiàn)在顯示的是新建目錄的默認權限,該目錄的所有者的默認權限是 rwx,所屬組的默認權限是 rx,其他人的默認權限是 rx。為什么說這是新建目錄的默認權限而不是新建文件的默認權限,如果你查看新建文件的權限,會發(fā)現(xiàn)是 rw-r--r-- ,與新建目錄的權限 rwxr-xr-x 相比,每種角色的權限都少了 x。所以說,只要知道了新建目錄的默認權限,再去掉 x 權限,就是新建文件的默認權限。
如果直接執(zhí)行 umask 命令,會顯示一個數(shù)字。
這個數(shù)字叫做權限掩碼,用 777 減去其后三位 022 就得到了每種角色的權限,即 755。翻譯成字母就是 rwxr-xr-x 。
若想更改新建目錄或文件的默認權限,只需執(zhí)行 umask 權限掩碼 即可。
例如,我想把新建目錄的默認權限改成 rwxr-r-- ,翻譯成數(shù)字就是 744,再用 777 減去 744 就得到了權限掩碼 033。
雖然 Linux 系統(tǒng)的目錄或文件的默認權限可以修改,但是 Linux 這樣分配權限是有一定道理的,最好不要輕易修改。