LINUX课程设计shell编程Word下载.docx
《LINUX课程设计shell编程Word下载.docx》由会员分享,可在线阅读,更多相关《LINUX课程设计shell编程Word下载.docx(25页珍藏版)》请在冰点文库上搜索。
add文件是用来增加信息;
delete文件是用来删除信息。
对于任务6和7,需要编写单独的Shell脚本文件(必须分别命名为add和delete)并且在主脚本menu文件中调用这些脚本文件。
四.设计步骤:
1.功能图
2.流程图
2.2.1主菜单
2.2.2add模块
2.2.3delete模块
3.截图
1)menu脚本执行后,大概应该呈现为下图所示的情况:
假如,passwd文件中的内容如下所示:
root:
x:
0:
/root:
/bin/bash
linux:
500:
/home/linux:
lianmin:
503:
/home/lianmin:
800:
liuxy:
/home/0:
liuxianyu:
801:
lxy:
/home/liuxianyu:
2)选择菜单1时,显示的结果如下图所示:
3)选择菜单2时,显示的结果如下图所示:
4)选择菜单3时,显示的结果如下图所示:
5)选择菜单4时,显示的结果如下图所示:
6)选择菜单5,并输入需要查询的用户名时,显示的结果如下图所示:
7)选择菜单6,显示的结果如下图所示:
完成添加用户后,在调用菜单2应该能够看到新添加用户mycount的信息条目。
8)选择菜单7,通过用户ID来删除用户,显示的结果如下图所示:
9)选择菜单q时,显示的结果如下图所示:
五.源代码
1).源代码主要思路
1.menu主菜单
无效输入
当用户做了选择且所选的操作完成之后,应再次显示主菜单以供用户做下一步选择。
在以上等待用户做出选择的菜单中,如果用户偶尔输入了一个代码而不是1、2、3、4、5、6、7、q或Q,就有信息提示“请按回车继续...”。
等用户按了回车键之后,再次显示主菜单供用户做其他选择。
查询用户是否存在,先判断是否输入,再判断用户名是否存在。
whiletrue
do
echo"
请输入要查询的用户名:
"
readanswer
$b$answer"
if(test-z"
$answer"
)
then
你还没有输入"
continue
elif
grep-i$answer$dataSource
then
"
break
else
你输入的用户不存在,没有找到$answer"
fi
done;
;
自定义函数,判断passwd文件是否存在,如果文件不存在,会显示警告。
CheckDataSourceFileExist()
{
if[-f$dataSource]
then
#文件存在
return0;
#文件不存在
clear;
echo-n"
警告【$dataSource】不存在!
请确认!
read;
return1;
}
2.Add文件
该脚本实现与用户的交互式添加用户信息,包括需要添加用户的:
用户名、用户密码、用户ID、组ID、全名、用户家目录、登录shell类型。
对于每一项信息需要进行单独的读取和必要验证。
此外,我还加入了对于是否继续添加的判断,故添加了isContinue已辅助。
对于用户创建的用户名的判断,先判断用户名是否为空,再对于首字母的判断,最后判断所以字符是不是字母和数字
userName="
while[-z$userName]#判断用户输入一个无效的用户名
do
echo-n"
用户名:
readuserName;
if[-z$userName]
then
echo"
错误!
用户名是不能为空的,请重新输入!
continue;
fi
if[`exprmatch$userName"
[a-zA-Z][0-9a-zA-Z]*"
`-ne`exprlength$userName`]
用户名的只能由非数字打头的字符和数字组成,请重新输入!
userName="
done
对于用户名密码的判断,判断密码是否为空,且密码长度必须为6位的大小写字母、数字和控制字符组成,然后判断两次输入的用户名和密码是否一样。
while[-z$passWord]
密码:
readpassWord;
if[-z$passWord]
密码是不能为空的,请重新输入!
if[`exprlength$passWord`-ne6]
密码长度为6位,请重新输入!
passWord="
if[`exprmatch$passWord"
[0-9a-zA-Z]*"
`-ne`exprlength$passWord`]
密码由大小写字母、数字和控制字符组成,请重新输入!
请在输入一次密码:
readpassWordAgain;
if[$passWordAgain!
=$passWord]
两次输入的密码不一样,请重新输入!
对于用户UID输入处理,UID为数字,一般非超级用户的ID大等于500,范围为500~60000,且不为空。
对于用户组GID处理,一般非超级用户的GID大等于500,范围为500~60000,且不为空。
用户的工作目录默认为“/home/用户名”。
登录权限有bash,sh,csh,ksh可以供选择。
3.Detele文件
delete脚本通过用户ID,找到passwd文件中对应用户ID的记录,并将其删除。
同时要考虑到用户可能误操作,因此要在真正删除用户信息前,进行用户确认,如果用户不确认删除,那么就不能将用户信息记录从passwd中删除。
这就需要一个临时文件tempFile进行辅助,将删除后的效果保存于该临时文件中,只有用户确认删除后,再将临时文件tempFile内容写入到passwd文件。
否者保持passwd内容不变。
此外,我还加入了对于是否继续删除的判断,故isContinue已做辅助。
2).源代码原码
1.menu主脚本文件代码
#!
/bin/bash
dataSource='
passwd'
homePath='
.'
AddUsers="
."
DeleteUsers="
#自定义函数,判断passwd文件是否存在
a="
你的选择是:
b="
输入关键字是:
clear
do
CheckDataSourceFileExist;
==========信息主菜单======================="
1.打印当前所有记录"
2.打印当前所有记录(格式化后)"
3.打印用户名和用户ID"
4.打印(格式化了的)用户名和用户ID"
5.查询特定记录"
6.增加新记录"
7.删除记录?
退出"
echo-e"
你的选择是:
(等待用户输入)"
echo
readchoice
$a$choice"
case$choicein
1)CheckDataSourceFileExist;
awk-F:
'
{print$1OFS$2OFS$3OFS$4OFS$5OFS$6OFS$7}'
$dataSource;
2)CheckDataSourceFileExist;
{print$1"
\t"
$2"
$3"
$4"
$5"
$6"
$7}'
$dataSource|sort;
#此处对于用户名排序,\t用于格式化,下同
3)CheckDataSourceFileExist;
{print$1OFS$3}'
4)CheckDataSourceFileExist;
$3}'
5)CheckDataSourceFileExist;
#查询用户是否存在
whiletrue
6)$AddUsers;
#读取文件
7)$DeleteUsers;
q)exit;
Q)exit;
*)echo"
无效的代码"
esac
请按回车继续..."
done
2.Add脚本文件代码
/bin/sh
isContinue="
y"
userName="
while[$isContinue="
-o$isContinue="
Y"
]
echo"
用户信息增加情况"
================================="
输入新用户的具体情况"
#用户名处理,输入一致到字符串长度不为0为止
userName="
#密码处理:
1.验空,3.密码长度要6位,由大小写字母、数字和控制字符组成,2.验两次输入的一致性,
passWord="
passWordAgain="
while[-z$passWord]
#用户UID输入处理,UID为数字、一般非超级用户的ID大等于500
uID="
while[-z$uID]
用户ID:
readuID;
if[-z$uID]
用户UID是不能为空的,请重新输入!
if[`exprmatch$uID"
[0-9]*"
`-ne`exprlength$uID`]
用户的UID必须为数字,请重新输入!
uID="
if[$uID-lt500-o$uID-gt60000]
一般非超级用户的ID范围为500~60000,请重新输入!
#用户组GID处理
gID="
while[-z$gID]
GroupID:
readgID;
if[-z$gID]
用户GID是不能为空的,请重新输入!
if[`exprmatch$gID"
`-ne`exprlength$gID`]
用户的GID必须为数字,请重新输入!
gID="
if[$gID-lt500-o$gID-gt60000]
用户组的ID范围为500~60000,请重新输入!
用户全名:
readnote;
#bash,sh,csh,ksh
shellVersion="
while[-z$shellVersion]
登录SHELL(bash,sh,csh,ksh):
readshellVersion;
if[$shellVersion!
="
bash"
-a$shellVersion!
sh"
csh"
ksh"
输入的Shell类型【$shellVersion】不在本系统支持范围内,请重新输入!
shellVersion="
用户工作目录:
sudomkdir/home/$userName;
if[$?
-eq0]
echo$userName"
成功创建!
fi
userInfo="
$userName:
$passWord:
$uID:
$gID:
$note:
$shellVersion"
echo$userInfo>
>
echo"
$userName用户信息添加成功!
else
$userName用户信息添加失败!
是否继续添加其他用户?
?
(y/n)"
readisContinue;
done
3.Detele脚本文件代码
do
while[$isContinue="
输入用户的名称:
if[-z"
$userName"
用户名不能为空,请重新输入!
isContinue="
CheckDataSourceFileExist;
if[$?
-ne1]
deleteUser=$(awk-F"
:
$1=="
'
$userName'
{print$0}'
$dataSource);
if[$deleteUser]
then
echo"
目标帐号确认:
$deleteUser;
echo-n"
是否删除该信息?
readisContinue;
if[-z$isContinue]
then
isContinue="
N"
fi
if[$isContinue="
CheckDataSourceFileExist;
if[$?
then
rowID=$(grep-n$deleteUser$dataSource|awk-F"
{print$1}'
);
sed-e"
$rowIDd"
$dataSource>
tempFile;
cattempFile>
rmtempFile;
fi
echo"
删除成功!
else
系统错误,删除失败!
else
你输入的【$userName