管理资源吧

当前位置:管理资源吧首页>>>tech>>>c1>>>服务器教程

linux如何判断指定用户对指定目录具有的权限具体介绍

  脚本名:power.sh

  脚本内容:

  代码如下:

  #!/bin/sh

  username3=$1

  dir_name2=$2

  # get existing directory

  file_path=$dir_name2

  while true

  do

  if [ -d $file_path ];then

  break;

  fi

  file_path=${file_path%/*}

  done

  dir_name2=$file_path

  # Judge whether the user exists

  grep "^$username3:" /etc/passwd >/dev/null

  if [ $? -ne 0 ];then

  echo "This user "$username3" does not exist."

  exit 4

  fi

  #echo "username : $username3"

  group4=` grep "^$username3:" /etc/passwd |awk -F : {'print $4'}|xargs -i grep {} /etc/group|cut -d":" -f1`

  #echo "group : $group4"

  su -l $username3 -c "test -r $dir_name2"

  is_read=$?

  su -l $username3 -c "test -x $dir_name2"

  is_exe=$?

  su -l $username3 -c "test -w $dir_name2"

  is_write=$?

  $is_read_str

  $is_exe_str

  $is_write_str

  if [ $is_read -eq 0 ];then

  is_read_str="r"

  else

  is_read_str="-"

  fi

  if [ $is_exe -eq 0 ];then

  is_exe_str="x"

  else

  is_exe_str="-"

  fi

  if [ $is_write -eq 0 ];then

  is_write_str="w"

  else

  is_write_str="-"

  fi

  echo "${is_read_str}${is_write_str}${is_exe_str}"

  -------------------------------------------

  注意:必须以root 身份执行该脚本。

  脚本power.sh 需要两个参数,第一个表示指定的用户,第二个表示指定的目录

  测试:

  [root@ppc40 study]# sh power.sh whuanga4 /tmp/abc/dd

  This user "whuanga4" does not exist.

  [root@ppc40 study]# sh power.sh whuang4 /tmp/abc/dd

  rw-

  (说明:表示用户whuang4 对目录/tmp/abc/dd 具有读和写权限,没有执行权限)。

tech首页 更多tech