收藏 分销(赏)

LINUX课程设计shell编程(2).doc

上传人:快乐****生活 文档编号:4431852 上传时间:2024-09-22 格式:DOC 页数:20 大小:1.14MB
下载 相关 举报
LINUX课程设计shell编程(2).doc_第1页
第1页 / 共20页
LINUX课程设计shell编程(2).doc_第2页
第2页 / 共20页
LINUX课程设计shell编程(2).doc_第3页
第3页 / 共20页
LINUX课程设计shell编程(2).doc_第4页
第4页 / 共20页
LINUX课程设计shell编程(2).doc_第5页
第5页 / 共20页
点击查看更多>>
资源描述

1、LINUX课程设计shell编程(2)202020年4月19日文档仅供参考Linux操作系统课程设计说明书题 目:Shell编程用户信息管理专 业:班 级:学 号:姓 名:指导老师: 06月08日一课程设计目的Linux操作系统课程设计是网络工程专业的集中实践性环节之一,是学习完linux操作系统课程后进行的一次全面的综合练习。其目的在于加深对linux操作系统的系统管理各方面技术的掌握,使学生更好地把握linux操作系统的基础命令、shell脚本技术以及各种基础服务器的配置和基本应用。类UNIX操作系统在网络环境及手持设备环境下使用极为流行,几乎所有的网络服务器都是运行在类UNIX系统之上;

2、基于类UNIX裁剪版本的手持设备也在市场中占有极大的比重,因此,对于网络工程专业掌握类UNIX操作系统的基本使用方法是相当重要的。而Linux就是类UNIX中最为流行的一个分支,鉴于Linux的开源和Linux开发群的活跃特性,Linux都是高等院校计算机类专业必开设的课程。而Linux操作系统课程设计能够更好的加强学生在课程学习中各种知识的综合应用能力和实践经验。二课程设计内容在主Shell脚本文件里(必须以 menu 命名)要有一个多操作选项的菜单以便用户从中选择。在不同任务的中,这些操作能自动实现以下功能:1) 在屏幕上显示当前所有用户的记录2) 在屏幕上显示当前所有用户(经过格式化和排

3、序的)的记录3) 只在屏幕上显示用户名和用户ID4) 只在屏幕上显示(经过格式化和排序的)用户名和用户ID5) 查询并显示特定用户的记录6) 往passwd文件里增加新的用户记录7) 从passwd文件里删除某个用户记录在目录下有四个文件分别为menu,passwd,add,delete注:l passwd是自建数据文件,而不是/etc/passwd这个文件,切记。l menu、add和delete是shell脚本文件。三课程设计需要知识的基本原理及功能简介变量定义、变量使用、循环控制结构、条件选择结构、用户交互、文件读写、文本内容分析以及linux重要命令的使用等。程序要包括四个文件,即me

4、nu,add,delete,passwd四个文件。passwd文件是用来保存用户信息;menu文件是主菜单,要求运行的时候能显示一个菜单供用户选择;add文件是用来增加信息;delete文件是用来删除信息。在主Shell脚本文件里(必须以 menu 命名)要有一个多操作选项的菜单以便用户从中选择。对于任务6和7,需要编写单独的Shell脚本文件(必须分别命名为add和delete)而且在主脚本menu文件中调用这些脚本文件。四设计步骤:1.功能图显示当前所有用户的记录显示当前所有用户(经过格式化和排序的)的记录的记录显示用户名和用户ID显示(经过格式化和排序的)用户名和用户ID查询并显示特定用

5、户的记录添加用户信息删除用户信息用户信息主菜单2.流程图主菜单你的选择功能实现回车退出2.2.1主菜单2.2.2 add模块2.2.3 delete模块主菜单是否继续删除进入delete界面输入ID是否存在是否删除进入主菜单NYYYN3.截图1) menu脚本执行后,大概应该呈现为下图所示的情况:假如,passwd文件中的内容如下所示:root:x:0:0:root:/root:/bin/bashlinux:x:500:500:linux:/home/linux:/bin/bashlianmin:x:503:500:lianmin:/home/lianmin:/bin/bash:x:800:8

6、00:liuxy:/home/:/bin/bashliuxianyu:x:801:801:lxy:/home/liuxianyu:/bin/bash2) 选择菜单1时,显示的结果如下图所示:3) 选择菜单2时,显示的结果如下图所示:4) 选择菜单3时,显示的结果如下图所示:5) 选择菜单4时,显示的结果如下图所示:6) 选择菜单5,并输入需要查询的用户名时,显示的结果如下图所示:7) 选择菜单6,显示的结果如下图所示:完成添加用户后,在调用菜单2应该能够看到新添加用户mycount的信息条目。8) 选择菜单7,经过用户ID来删除用户,显示的结果如下图所示:9) 选择菜单q时,显示的结果如下图所

7、示:五源代码1).源代码主要思路1. menu主菜单无效输入当用户做了选择且所选的操作完成之后,应再次显示主菜单以供用户做下一步选择。在以上等待用户做出选择的菜单中,如果用户偶然输入了一个代码而不是1、2、3、4、5、6、7、q或Q,就有信息提示“请按回车继续.”。等用户按了回车键之后,再次显示主菜单供用户做其它选择。查询用户是否存在,先判断是否输入,再判断用户名是否存在。while true do echo 请输入要查询的用户名: read answer echo $b $answer if (test -z $answer) then echo 你还没有输入 continue elif g

8、rep -i $answer $dataSource then echo break else echo 你输入的用户不存在,没有找到 $answer break fi done ; 自定义函数,判断passwd文件是否存在,如果文件不存在,会显示警告。CheckDataSourceFileExist()if -f $dataSource then#文件存在return 0;else#文件不存在clear;echo -n 警告 【$dataSource】 不存在!请确认!;read ;return 1;fi2Add文件该脚本实现与用户的交互式添加用户信息,包括需要添加用户的:用户名、用户密码、

9、用户ID、组ID、全名、用户家目录、登录shell类型。对于每一项信息需要进行单独的读取和必要验证。另外,我还加入了对于是否继续添加的判断,故添加了isContinue已辅助。对于用户创立的用户名的判断,先判断用户名是否为空,再对于首字母的判断,最后判断因此字符是不是字母和数字userName=;while -z $userName # 判断用户输入一个无效的用户名doecho -n 用户名:;read userName;if -z $userName thenecho 错误!用户名是不能为空的,请重新输入!;continue;fiif expr match $userName a-zA-Z0

10、-9a-zA-Z* -ne expr length $userName thenecho 错误!用户名的只能由非数字打头的字符和数字组成,请重新输入!;userName=;continue;fidone对于用户名密码的判断,判断密码是否为空,且密码长度必须为6位的大小写字母、数字和控制字符组成,然后判断两次输入的用户名和密码是否一样。while -z $passWord doecho -n 密码:;read passWord;if -z $passWord thenecho 错误!密码是不能为空的,请重新输入!;continue;fiif expr length $passWord -ne 6

11、 thenecho 密码长度为6位,请重新输入!;passWord=;continue;fiif expr match $passWord 0-9a-zA-Z* -ne expr length $passWord thenecho 密码由大小写字母、数字和控制字符组成,请重新输入!;passWord=;continue;fiecho -n 请在输入一次密码:;read passWordAgain;if $passWordAgain != $passWord thenecho 两次输入的密码不一样,请重新输入!;passWord=;continue;fidone对于用户UID输入处理,UID为数

12、字,一般非超级用户的ID大等于500,范围为50060000,且不为空。对于用户组GID处理,一般非超级用户的GID大等于500,范围为50060000,且不为空。用户的工作目录默认为“/home/用户名”。登录权限有bash,sh,csh,ksh能够供选择。3Detele文件delete脚本经过用户ID,找到passwd文件中对应用户ID的记录,并将其删除。同时要考虑到用户可能误操作,因此要在真正删除用户信息前,进行用户确认,如果用户不确认删除,那么就不能将用户信息记录从passwd中删除。这就需要一个临时文件tempFile进行辅助,将删除后的效果保存于该临时文件中,只有用户确认删除后,再

13、将临时文件tempFile内容写入到passwd文件。否者保持passwd内容不变。另外,我还加入了对于是否继续删除的判断,故isContinue已做辅助。2).源代码原码1menu主脚本文件代码#! /bin/bashdataSource=passwd;homePath=.;AddUsers=. Add.sh;DeleteUsers=. Delete.sh;#自定义函数,判断passwd文件是否存在CheckDataSourceFileExist()if -f $dataSource then#文件存在return 0;else#文件不存在clear;echo -n 警告 【$dataSou

14、rce】 不存在!请确认!;read ;return 1;fia=你的选择是:b=输入关键字是:clearwhile truedo CheckDataSourceFileExist; echo =信息主菜单= echo1.打印当前所有记录 echo2.打印当前所有记录(格式化后) echo3.打印用户名和用户ID echo4.打印(格式化了的)用户名和用户ID echo5.查询特定记录 echo6.增加新记录 echo7.删除记录? echoq.-退出 echo -e 你的选择是:(等待用户输入) echo read choice echo $a $choice case $choice in

15、1) CheckDataSourceFileExist;awk -F: print $1 OFS $2 OFS $3 OFS $4 OFS $5 OFS $6 OFS $7 $dataSource;2) CheckDataSourceFileExist;awk -F: print $1 t $2 t $3 t $4 t $5 t $6 t $7 $dataSource | sort;#此处对于用户名排序,t用于格式化,下同3) CheckDataSourceFileExist;awk -F: print $1 OFS $3 $dataSource;4) CheckDataSourceFileE

16、xist;awk -F: print $1 t $3 $dataSource | sort; 5) CheckDataSourceFileExist;#查询用户是否存在 while true do echo 请输入要查询的用户名: read answer echo $b $answer if (test -z $answer) then echo 你还没有输入 continue elif grep -i $answer $dataSource then echo break else echo 你输入的用户不存在,没有找到 $answer break fi done ; 6)$AddUsers

17、;#读取Add.sh文件 7)$DeleteUsers;#读取Delete.sh文件 q)exit; Q)exit; *)echo 无效的代码; esac echo 请按回车继续. read answerdone2Add脚本文件代码#!/bin/shisContinue=y;userName=;while $isContinue = y -o $isContinue = Y doecho 用户信息增加情况;echo =;echo 输入新用户的具体情况;#用户名处理,输入一致到字符串长度不为0为止userName=;while -z $userName # 判断用户输入一个无效的用户名doech

18、o -n 用户名:;read userName;if -z $userName thenecho 错误!用户名是不能为空的,请重新输入!;continue;fiif expr match $userName a-zA-Z0-9a-zA-Z* -ne expr length $userName thenecho 错误!用户名的只能由非数字打头的字符和数字组成,请重新输入!;userName=;continue;fidone#密码处理:1.验空,3.密码长度要6位,由大小写字母、数字和控制字符组成,2.验两次输入的一致性,passWord=;passWordAgain=;while -z $pas

19、sWord doecho -n 密码:;read passWord;if -z $passWord thenecho 错误!密码是不能为空的,请重新输入!;continue;fiif expr length $passWord -ne 6 thenecho 密码长度为6位,请重新输入!;passWord=;continue;fiif expr match $passWord 0-9a-zA-Z* -ne expr length $passWord thenecho 密码由大小写字母、数字和控制字符组成,请重新输入!;passWord=;continue;fiecho -n 请在输入一次密码:;

20、read passWordAgain;if $passWordAgain != $passWord thenecho 两次输入的密码不一样,请重新输入!;passWord=;continue;fidone#用户UID输入处理,UID为数字、一般非超级用户的ID大等于500uID=;while -z $uID doecho -n 用户ID:;read uID;if -z $uID thenecho 错误!用户UID是不能为空的,请重新输入!;continue;fiif expr match $uID 0-9* -ne expr length $uID thenecho 错误!用户的UID必须为数

21、字,请重新输入!;uID=;continue;fiif $uID -lt 500 -o $uID -gt 60000 thenecho 错误!一般非超级用户的ID范围为50060000,请重新输入!;uID=;continue;fidone#用户组GID处理gID=;while -z $gID doecho -n Group ID:;read gID;if -z $gID thenecho 错误!用户GID是不能为空的,请重新输入!;continue;fiif expr match $gID 0-9* -ne expr length $gID thenecho 错误!用户的GID必须为数字,请

22、重新输入!;gID=;continue;fiif $gID -lt 500 -o $gID -gt 60000 thenecho 错误!用户组的ID范围为50060000,请重新输入!;gID=;continue;fidoneecho -n 用户全名:;read note;#bash,sh,csh,kshshellVersion=;while -z $shellVersion doecho -n 登录SHELL(bash,sh,csh,ksh):;read shellVersion;if $shellVersion != bash -a $shellVersion != sh -a $shel

23、lVersion != csh -a $shellVersion != ksh thenecho 输入的Shell类型【$shellVersion】不在本系统支持范围内,请重新输入!;shellVersion=;fidoneecho -n 用户工作目录:;sudo mkdir /home/$userName;if $? -eq 0 thenecho $userName 成功创立!;fiuserInfo=$userName:$passWord:$uID:$gID:$note:$userName:$shellVersion;echo $userInfo $dataSource;if $? -eq

24、0 thenecho $userName用户信息添加成功!;elseecho $userName用户信息添加失败!;fiecho -n 是否继续添加其它用户?(y/n);read isContinue;done3Detele脚本文件代码#!/bin/shisContinue=y;userName=;while $isContinue = y -o $isContinue = Y dowhile $isContinue = y -o $isContinue = Y doecho -n 输入用户的名称:;read userName;if -z $userName thenecho 用户名不能为空,

25、请重新输入!;isContinue=Y;continue;fiCheckDataSourceFileExist;if $? -ne 1 thendeleteUser=$(awk -F : $1 = $userName print $0 $dataSource);if $deleteUser thenecho 目标帐号确认: $deleteUser;echo -n 是否删除该信息?(y/n);read isContinue;if -z $isContinue thenisContinue=N;fiif $isContinue = y -o $isContinue = Y thenCheckDat

26、aSourceFileExist;if $? -ne 1 thenrowID=$(grep -n $deleteUser $dataSource | awk -F : print $1); sed -e $rowID d $dataSource tempFile;cat tempFile $dataSource;rm tempFile;fiif $? -eq 0 thenecho 删除成功!;elseecho 系统错误,删除失败!;fiisContinue=N;fielseecho 你输入的 【$userName】 用户不存在!;isContinue=N;fifidoneif -n $user

27、Name thenecho -n 是否继续删除其它用户?(y/n);read isContinue;if -z $isContinue thenisContinue=N;fifidone4passwd文件root:x:0:0:root:/root:/bin/bashlinux:x:500:500:linux:/home/linux:/bin/bashlianmin:x:503:500:lianmin:/home/lianmin:/bin/bash:x:800:800:liuxy:/home/:/bin/bashliuxianyu:x:801:801:lxy:/home/liuxianyu:/b

28、in/bash六课程设计心得体会:本次课程设计一共进行了3周,对于期间的设计,我感触颇深。因为开始我对于linux这块的shell脚本编程不大感兴趣。可是由于老师的刻意强调,我开始查找各种资料。在参考网上的资料,以及老师给的资料,对于设计题目有了很大的帮助。可是对于直接修改pash路径执行shell文件的时候遇到了困难。开始对于格式化显示的理解不够深刻,加上没有排序,最后在同学的帮助下,运用“t”加上“sort”进行的第二步和第四步。开始设计的时候考虑的不够周全,最后发现应该在执行任意代码时都需要判断passwd文件是否存在。对于add和delete的思路多半参考文献4中的思路,对于用户输入的

29、判断还有不足之处。特别是做删除的时候,开始不知道怎么创立临时文件,经常会删除passwd里的所有文件。可是最后都解决了。本次设计让我体会到,做事情只要能沉下心来,对于不了解的东西,一样能够做的很好。当然,这中间也有多少是同学和指导老师的帮助。对于linux下shell文件的编写也有了重新的认识。七参考资料1 ubuntu. Shell编程基础. Ubuntu wiki主站. 2 ubuntu. Bind9安装设置指南. Ubuntu wiki主站. 3 W3cschool. PHP 教程. W3C. 4 Linux shell大作业. 百度文库. 百度.5 解析LINUX的passwd文件.幽幽灵夜.

展开阅读全文
部分上传会员的收益排行 01、路***(¥15400+),02、曲****(¥15300+),
03、wei****016(¥13200+),04、大***流(¥12600+),
05、Fis****915(¥4200+),06、h****i(¥4100+),
07、Q**(¥3400+),08、自******点(¥2400+),
09、h*****x(¥1400+),10、c****e(¥1100+),
11、be*****ha(¥800+),12、13********8(¥800+)。
相似文档                                   自信AI助手自信AI助手
搜索标签

当前位置:首页 > 学术论文 > 其他

移动网页_全站_页脚广告1

关于我们      便捷服务       自信AI       AI导航        获赠5币

©2010-2024 宁波自信网络信息技术有限公司  版权所有

客服电话:4008-655-100  投诉/维权电话:4009-655-100

gongan.png浙公网安备33021202000488号   

icp.png浙ICP备2021020529号-1  |  浙B2-20240490  

关注我们 :gzh.png    weibo.png    LOFTER.png 

客服