免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 1776 | 回复: 5

这里不是要 777权限好吗 [复制链接]

论坛徽章:
0
发表于 2004-06-25 00:23 |显示全部楼层
在Linux中批量建立用户的shell

最近,笔者在校园网应用平台建设中采用了Linux操作系统,为校园网用户提供DNS、Apache、POP3、SMTP、FTP等服务。由于我校学生用户数在3000人以上,笔者在建设整个应用平台的过程中特别重视保证用户管理效率。我的基本思路和做法是:利用shell为每个学生建立一个系统账号——即提供一个E-mail地址(含FTP空间账号),然后学生可以凭借其E-mail再注册论坛用户。基于这样的管理思路,笔者编写了一个批量建立用户的shell,实践证明,利用shell可以有效地管理基于Unix内核的系统用户。

  以下是整个shell的源码及注释,此代码在Redhat 7.2及Turbo Linux 7.0上调试通过,在其他版本的Linux中使用可能需要做适当的修改。其中“@”部分是代码注释,“()”部分是笔者对于编程思路的解释。

  @!/bin/sh(定义使用sh shell)

  groupadd users(建立用户组)

  @grade code(定义第一个参数为年级代码,赋予变量“grade”)

  grade=$1

  @class code(定义第二个参数为班级代码,赋予变量“num_class”)

  num_class=`expr $2 + 0`

  if (test $num_class -le 9)(以下代码是为了保证班级码的位数为两位)

  then

   num_class="0"$num_class

  fi

  @max user id(定义第三个参数为该班学生的最大ID号,赋予变量“max_stid”)

  max_stid=`expr $3 + 0`

  @init user id(该班学生用户ID号从1开始)

  num_stid =1

  @mkdir user home(在“/home”目录为所有学生建立名为"student"的公共目录)

  if [ ! -x /home/student ]

  then

   mkdir /home/student

  fi

  if [ ! -x /home/student/$1$num_class ] (在学生公共目录下为每个班级建立以该班代码命名的目录)

  then

   mkdir /home/student/$1$num_class

  fi

  while (test $num_stid -le $max_stid)(从用户ID号1开始循环,直到最大ID号)

   do

   if (test $num_stid -le 9) (以下保证学生代码的位数为两位)

   then

   num_stid="0"$num_stid

   fi

   user_name=$grade$num_class$num_stid(把年级、班级、学生ID号三部分代码组合成用户名,并赋予变量user_name)

   @save user passwd to file user_pwlist(按“name:passwd”的格式逐行追加写入“user_pwlist”文件,以备初始化用户密码)

   echo $user_name":"$user_name >;>; user_pwlist

   @add user(建立该用户,同时赋予“users”组,创建该用户目录)

   adduser -g users -d /home/student/$1$num_class/$user_name $user_name

   @set quota(为该用户设置配额,限制最大容量为20MB,没有文件数限制)

   setquota -u $user_name 10240 20480 0 0 /home

   @set directory mode(设置该用户目录的权限为755)
!!!!####这里不是要 777权限好吗? 如果没有W的权那空间有什么用呢?!!!#$#$#

   chmod 755 /home/student/$1$num_class/$user_name

   @current user id add one(用户ID号加1,准备下一次循环,建立下一个用户)

   num_stid=`expr $num_stid + 1`

  done

  chpasswd < user_pwlist(以下两行为刚才建立的所有用户设置密码)

  pwconv

  rm user_pwlist -f(删除“user_pwlist”文件)

  

  关于使用:

  1. 用vi编辑器逐行写入以上代码部分,并以文件的形式保存,如以“addclass”命名保存,再执行以下步骤。

  2. #chmod +x addclass(设置addclass文件为可执行权限)

  3. #./addclass ga 1 50(建立ga0101-ga0150用户)

  注意:#为提示符。
  

  以上代码只是笔者在使用shell进行系统用户管理时的一点体会。由于shell可以和Linux的系统命令结合使用,所以它在管理中的功能就显得非常强大。就以上代码而言,我们只要稍加改动,就可以建立删除批量用户的shell、批量配置用户配额的shell以及批量初始用户密码的shell。如果再加上一层班级循环语句,就可以生成一次建立一个年级用户的shell。

论坛徽章:
0
发表于 2004-06-25 07:44 |显示全部楼层

这里不是要 777权限好吗

用户自己有写权限就行了。为什么要设成777给所有人写权限呢?

论坛徽章:
0
发表于 2004-06-26 13:12 |显示全部楼层

这里不是要 777权限好吗

那我就不太明了,外面的用户登录进来不是以普通用户的身份吗? 755 只是对root有写权限呀?望指教.

论坛徽章:
0
发表于 2004-06-26 13:24 |显示全部楼层

这里不是要 777权限好吗

passwd 有个stdin可以从文件获取密码,这样就不用pwconv了。

755:
user -->; 7
group -->; 5
others -->; 5

论坛徽章:
0
发表于 2004-06-27 19:47 |显示全部楼层

这里不是要 777权限好吗

原帖由 "零二年的夏天" 发表:
passwd 有个stdin可以从文件获取密码,这样就不用pwconv了。


这两个  stdin  和  pwconv 都不是很会用哦。有点详细 点的说法吗? 麻烦贴一下好否? 先谢了。

论坛徽章:
1
荣誉会员
日期:2011-11-23 16:44:17
发表于 2004-06-27 19:55 |显示全部楼层

这里不是要 777权限好吗

我自己的shell是初始密码为该学生的ID号的说。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP