首页 | 安全文章 | 安全工具 | Exploits | 本站原创 | 关于我们 | 网站地图 | 安全论坛
  当前位置:主页>安全文章>文章资料>网络基础>文章内容
在Linux中批量建立用户的shell
来源:vfocus.net 作者:vfocus 发布时间:2004-06-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)

   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条)] [返回顶部] [打印本页] [关闭窗口]  
匿名评论
评论内容:(不能超过250字,需审核后才会公布,请自觉遵守互联网相关政策法规。
 §最新评论:
  热点文章
·北京地区设置ADSL猫(惟帆的 KM3
·关于ip地址分类
·浅谈watchdog timeout出现的原因
·利用snmp实现remote ping
·端口大全(1-100中文)
·从IRQ到IRQL(APIC版)
·使用kgdb调试linux内核及内核模
·基于PassThru的NDIS中间层驱动程
·支持 PS/2 与 USB 的键盘过滤驱
·一种网络劫持分析、调试与编程实
·利用iptables打破电信对路由方式
·绕过Copy-On-Write机制安装全局H
  相关文章
·SQL语句导入导出大全
·在PHP中执行系统外部命令
·Apache 服务器的安装教程
·SQL Server的用户及权限
·使用rtsp-proxy突破电影站点的ip
·MySQL数据备份与恢复学习
·全面了解系统中 svchost.exe 文
·浅谈watchdog timeout出现的原因
·SQL查询语句使用
·利用ARP探测以太网中的活动主机
·asp程序错误详细说明例表
·关于对SQL注入80004005 及其它错
  推荐广告
CopyRight © 2002-2022 VFocuS.Net All Rights Reserved