LINUX课程设计shell编程Word下载.docx

上传人:b****2 文档编号:3907661 上传时间:2023-05-02 格式:DOCX 页数:25 大小:1.18MB
下载 相关 举报
LINUX课程设计shell编程Word下载.docx_第1页
第1页 / 共25页
LINUX课程设计shell编程Word下载.docx_第2页
第2页 / 共25页
LINUX课程设计shell编程Word下载.docx_第3页
第3页 / 共25页
LINUX课程设计shell编程Word下载.docx_第4页
第4页 / 共25页
LINUX课程设计shell编程Word下载.docx_第5页
第5页 / 共25页
LINUX课程设计shell编程Word下载.docx_第6页
第6页 / 共25页
LINUX课程设计shell编程Word下载.docx_第7页
第7页 / 共25页
LINUX课程设计shell编程Word下载.docx_第8页
第8页 / 共25页
LINUX课程设计shell编程Word下载.docx_第9页
第9页 / 共25页
LINUX课程设计shell编程Word下载.docx_第10页
第10页 / 共25页
LINUX课程设计shell编程Word下载.docx_第11页
第11页 / 共25页
LINUX课程设计shell编程Word下载.docx_第12页
第12页 / 共25页
LINUX课程设计shell编程Word下载.docx_第13页
第13页 / 共25页
LINUX课程设计shell编程Word下载.docx_第14页
第14页 / 共25页
LINUX课程设计shell编程Word下载.docx_第15页
第15页 / 共25页
LINUX课程设计shell编程Word下载.docx_第16页
第16页 / 共25页
LINUX课程设计shell编程Word下载.docx_第17页
第17页 / 共25页
LINUX课程设计shell编程Word下载.docx_第18页
第18页 / 共25页
LINUX课程设计shell编程Word下载.docx_第19页
第19页 / 共25页
LINUX课程设计shell编程Word下载.docx_第20页
第20页 / 共25页
亲,该文档总共25页,到这儿已超出免费预览范围,如果喜欢就下载吧!
下载资源
资源描述

LINUX课程设计shell编程Word下载.docx

《LINUX课程设计shell编程Word下载.docx》由会员分享,可在线阅读,更多相关《LINUX课程设计shell编程Word下载.docx(25页珍藏版)》请在冰点文库上搜索。

LINUX课程设计shell编程Word下载.docx

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

展开阅读全文
相关资源
猜你喜欢
相关搜索
资源标签

当前位置:首页 > 总结汇报 > 实习总结

copyright@ 2008-2023 冰点文库 网站版权所有

经营许可证编号:鄂ICP备19020893号-2