shell编程if及find查找作业

写一个脚本/root/bin/createuser.sh,实现如下功能:使用一个用户名做为参数,如果指定参数的用户存在,就显示其存在,否则添加之;显示添加的用户的id号等信息

[root@www sh.log]# cat createuser.sh 
#!/bin/bash
#author
#使用一个用户名作为参数,如果指定参数的用户存在,就显示其存在,否则添加,显示添加用户的id号等信息
read -p "username:" user
id $user &> /dev/null
if [ $? -eq 0 ];then
	echo  "$user already exist"
else
	useradd $user &> /dev/null
	echo "`id $user`"
fi
[root@www sh.log]# bash createuser.sh
username:wang
wang already exist
[root@www sh.log]# bash createuser.sh 
username:xiaodeng   
uid=1002(xiaodeng) gid=1002(xiaodeng) groups=1002(xiaodeng)

写一个脚本/root/bin/yesorno.sh,提示用户输入yes或no,并判断用户输入的是yes还是no,或是其它信息

[root@www sh.log]# cat yesorno.sh 
#!/bin/bash
#author:DYW
#提示用户输入yes或no,并判断用户输入的是yes还是no,或是其他信息
read -p "input yes or no please:" biu
piu=`echo "$biu" | tr "[a-z]" "[A-Z]"`
case $piu in
	Y|YES)
	echo "you select yes"
	;;
	N|NO)
	echo "you select no"
	;;
	*)
	echo "you select others"
	;;
esac

[root@www sh.log]# bash yesorno.sh 
input yes or no please:yES
you select yes
[root@www sh.log]# bash yesorno.sh 
input yes or no please:YEs
you select yes
[root@www sh.log]# bash yesorno.sh
input yes or no please:No
you select no
[root@www sh.log]# bash yesorno.sh
input yes or no please:12312
you select others

写一个脚本/root/bin/filetype.sh,判断用户输入文件路径,显示其文件类型(普通,目录,链接,其它文件类型)

[root@www sh.log]# bash filetype.sh 
input filename please:/sh.log/qiuhe.sh
The /sh.log/qiuhe.sh is ordinary file
[root@www sh.log]# cat filetype.sh 
#!/bin/bash
#suthor:DYW
#判断用户输入文件路径,显示其文件类型(普通,目录,链接,其他文件类型)
read -p "input filename please:" file
	if [ -z $file  ];then
		echo "Please enter a path"
	else 
		if [ -L $file ];then
			echo "The $file is Symbol file"
		elif [ -c $file ];then
			echo "The $file is char file"
		elif [ -d $file ];then
			echo "The $file is dir file"
		elif [ -b $file ];then
			echo "The $file is block file"
		elif [ -f $file ];then
			echo "The $file is ordinary file"
		elif [ -p $file ];then
			echo "The $file is pipe file"
		elif [ -S $file ];then
			echo "The $file is scoket file"
		else
			echo "Enter the correct file path"
		fi
	fi
[root@www sh.log]# bash filetype.sh 
input filename please:/wang/file1
The /wang/file1 is ordinary file
[root@www sh.log]# bash filetype.sh 
input filename please:/wang/jiaoben.sh
Enter the correct file path
[root@www sh.log]# bash filetype.sh 
input filename please:/wang/jiaoben1.sh
The /wang/jiaoben1.sh is ordinary file
[root@www sh.log]# bash filetype.sh 
input filename please:/usr/bin
The /usr/bin is dir file

写一个脚本/root/bin/checkint.sh,判断用户输入的参数,是否为正整数

[root@www sh.log]# cat cheskint.sh 
#!/bin/bash
#author:DYW
#判断用户输入的参数,是否为正整数
read -p "input a number please:" number
	if [ -z $number ];then
		echo "You must input a number!"
		exit
		else
			if let var=$number &>/dev/null;then
				if [ $? -eq 0 ];then
					if [ $number -lt 0 ];then
						echo "$number is Negative integer"
					elif [ $number -gt 0 ];then
						echo "$number is Positive integer"
					else
						echo "$number is 0"
					fi
				fi
			else
				echo "$number is not integer"
			fi
	fi
[root@www sh.log]# bash cheskint.sh 
input a number please:10
10 is Positive integer
[root@www sh.log]# bash cheskint.sh 
input a number please:-112  
-112 is Negative integer
[root@www sh.log]# bash cheskint.sh 
input a number please:0
0 is not integer
[root@www sh.log]# bash cheskint.sh 
input a number please:
You must input a number!
[root@www sh.log]# bash cheskint.sh 
input a number please:asdhiuadqwl
asdhiuadqwl is not integer

查找/var目录下属主为root,且属组为mail的所有文件

[root@www ~]# find /var -user root -group mail -ls
134321240    0 drwxrwxr-x   2 root     mail           46 Aug 12 18:30 /var/spool/mail

查找/var目录下不属于root、lp、gdm的所有文件

[root@www ~]# find /var/ -not \( -user root -o -user lp -o -user gdm \) -ls
134686482    0 drwx------   2 tss      tss             6 Nov 21  2015 /var/lib/tpm
443945    0 drwx------   2 postfix  root           24 Aug  9 06:23 /var/lib/postfix
   833    4 -rw-------   1 postfix  postfix        33 Aug  9 17:41 /var/lib/postfix/master.lock
134914400    0 -rw-rw----   1 wang     mail            0 Aug 11 13:02 /var/spool/mail/wang
134974157    0 -rw-rw----   1 laowang  mail            0 Aug 12 10:10 /var/spool/mail/laowang
134993654    0 -rw-rw----   1 xiaodeng mail            0 Aug 12 18:30 /var/spool/mail/xiaodeng
134924704    0 drwx------   2 postfix  root            6 Jun 10  2014 /var/spool/postfix/active
202230254    0 drwx------   2 postfix  root            6 Jun 10  2014 /var/spool/postfix/bounce
443946    0 drwx------   2 postfix  root            6 Jun 10  2014 /var/spool/postfix/corrupt
67719609    0 drwx------   2 postfix  root            6 Jun 10  2014 /var/spool/postfix/defer
134924705    0 drwx------   2 postfix  root            6 Jun 10  2014 /var/spool/postfix/deferred
202230255    0 drwx------   2 postfix  root            6 Jun 10  2014 /var/spool/postfix/flush
443947    0 drwx------   2 postfix  root            6 Jun 10  2014 /var/spool/postfix/hold
        6 Jun 10  2014 /var/spool/postfix/trace
   ...

查找/var目录下最近一周内其内容修改过,同时属主不为root,也不是postfix的文件

[root@www ~]# find /var/ \( -not \( -user root -o -user postfix \) -mtime -7 \) -ls
134914400    0 -rw-rw----   1 wang     mail            0 Aug 11 13:02 /var/spool/mail/wang
134974157    0 -rw-rw----   1 laowang  mail            0 Aug 12 10:10 /var/spool/mail/laowang
134993654    0 -rw-rw----   1 xiaodeng mail            0 Aug 12 18:30 /var/spool/mail/xiaodeng
134993684    0 -rw-rw----   1 gdm      mail            0 Aug 12 23:03 /var/spool/mail/gdm
[root@www ~]# stat /var/spool/mail/wang 
  File: ‘/var/spool/mail/wang’
  Size: 0         	Blocks: 0          IO Block: 4096   regular empty file
Device: fd00h/64768d	Inode: 134914400   Links: 1
Access: (0660/-rw-rw----)  Uid: ( 1000/    wang)   Gid: (   12/    mail)
Context: unconfined_u:object_r:mail_spool_t:s0
Access: 2016-08-11 13:02:38.126781165 +0800
Modify: 2016-08-11 13:02:38.126781165 +0800
Change: 2016-08-11 13:02:38.126781165 +0800
 Birth: -

查找当前系统上没有属主或属组,且最近一个周内曾被访问过的文件

[root@www ~]# find / \( -nouser -o -nogroup \) -atime -7

查找/etc目录下大于1M且类型为普通文件的所有文件

[root@www ~]# find /etc/ \( -size +1M -o -type f \) -ls
134320258    4 -rw-r--r--   1 root     root          541 Aug  9 05:48 /etc/fstab
134320259    0 -rw-------   1 root     root            0 Aug  9 05:48 /etc/crypttab
134993652    4 -rw-r--r--   1 root     root           81 Aug 12 20:25 /etc/resolv.conf
   151    4 -rw-r--r--   1 root     root         1690 Dec  9  2015 /etc/pki/rpm-gpg/RPM-GPG-KEY-CentOS-7
   152    4 -rw-r--r--   1 root     root         1004 Dec  9  2015 /etc/pki/rpm-gpg/RPM-GPG-KEY-CentOS-Debug-7
   153    4 -rw-r--r--   1 root     root         1690 Dec  9  2015 /etc/pki/rpm-gpg/RPM-GPG-KEY-CentOS-Testing-7
67355015    4 -rw-r--r--   1 root     root         2388 Jun 29  2015 /etc/pki/tls/certs/Makefile
67355016    4 -rwxr-xr-x   1 root     root          610 Jun 29  2015 /etc/pki/tls/certs/make-dummy-cert
67355017    4 -rwxr-xr-x   1 root     root          829 Jun 29  2015 /etc/pki/tls/certs/renew-dummy-cert
134484404    8 -rwxr-xr-x   1 root     root         5178 Jun 29  2015 /etc/pki/tls/misc/CA
134484405    4 -rwxr-xr-x   1 root     root          119 Jun 29  2015 /etc/pki/tls/misc/c_hash
134484406    4 -rwxr-xr-x   1 root     root          152 Jun 29  2015 /etc/pki/tls/misc/c_info
134484407    4 -rwxr-xr-x   1 root     root          112 Jun 29  2015 /etc/pki/tls/misc/c_issuer
.....
[root@www ~]# stat /etc/hostname
  File: ‘/etc/hostname’
  Size: 22        	Blocks: 8          IO Block: 4096   regular file
Device: fd00h/64768d	Inode: 134974153   Links: 1
Access: (0644/-rw-r--r--)  Uid: (    0/    root)   Gid: (    0/    root)
Context: system_u:object_r:hostname_etc_t:s0
Access: 2016-08-11 07:51:46.178807313 +0800
Modify: 2016-08-09 05:56:51.103010237 +0800
Change: 2016-08-09 05:56:51.103010237 +0800
 Birth: -

查找/etc目录下所有用户都没有写权限的文件

[root@www ~]# find /etc/ -not -perm /222 -ls 
67305775  196 -r--r--r--   1 root     root       198453 Aug  9 05:50 /etc/pki/ca-trust/extracted/java/cacerts
134417508  352 -r--r--r--   1 root     root       359773 Aug  9 05:50 /etc/pki/ca-trust/extracted/openssl/ca-bundle.trust.crt
201627950  264 -r--r--r--   1 root     root       266702 Aug  9 05:50 /etc/pki/ca-trust/extracted/pem/tls-ca-bundle.pem
201627951  216 -r--r--r--   1 root     root       217510 Aug  9 05:50 /etc/pki/ca-trust/extracted/pem/email-ca-bundle.pem
201627952  208 -r--r--r--   1 root     root       211626 Aug  9 05:50 /etc/pki/ca-trust/extracted/pem/objsign-ca-bundle.pem
...

查找/etc目录下至少有一类用户没有执行权限的文件

[root@www ~]# find /etc/ -not -perm -111 -ls 
134751833    4 -rw-r--r--   1 root     root          936 Mar  6  2015 /etc/mke2fs.conf
134974150    4 -rw-r--r--   1 root     root           37 Aug  9 05:56 /etc/vconsole.conf
134974152    4 -rw-r--r--   1 root     root           19 Aug  9 05:56 /etc/locale.conf
134974153    4 -rw-r--r--   1 root     root           22 Aug  9 05:56 /etc/hostname
134679689    4 -rw-r--r--   1 root     root          163 Aug  9 05:49 /etc/.updated
134914398   12 -rw-r--r--   1 root     root        12288 Aug  9 06:23 /etc/aliases.db
...

查找/etc/init.d目录下,所有用户都有执行权限,且其它用户有写权限的文件

[root@www ~]# find /etc/init.d/ -perm -113 -ls
67830539    0 ---x--x-wx   1 root     root            0 Aug 13 02:40 /etc/init.d/file1
...

原创文章,作者:DYW,如若转载,请注明出处:http://www.178linux.com/36055

(1)
DYWDYW
上一篇 2016-08-16
下一篇 2016-08-16

相关推荐

  • 开篇

    正式开始学习的第一天,了解LINUX,爱上LINUX。希望在往后的日子里越战越勇!!

    Linux干货 2017-07-11
  • N25期第一周作业

    计算机的组成与功能  一台能正常工作的计算机有硬件和软件组成,计算机的硬件就好比人的躯体,计算机的软件就好比人的思想,人的思想控制指挥人的躯体,计算机有了软件才能进行工作。 硬件大致由CPU,内存,输入输出设备,存储设备组成,各个部件的主要作用流程是:由输入设备(例如:键盘)输入数据, 数据暂时出入内存, 而后由内存传到CPU(CPU又由运算器+控…

    Linux干货 2016-12-05
  • Linux 目录配置

    Linux 目录配置 Linux目录配置标准:FHS 因为利用Linux来开发产品或distributions的团队/公司与个人实在太多了,如果每个人都用自己的想法来配置文件放置的目录,那么将可能造成很多管理上的困扰。所以/后来就有所谓的Filesystem Hierarchy Standard (FHS)标准出炉了。 根据FHS(http://www.pa…

    Linux干货 2017-03-26
  • Linux网络相关概念及bash脚本编程练习

    马哥教育网络班第23期+第八周课堂练习 Linux网络相关概念及bash脚本编程练习 习题: 1.请描述网桥、集线器、二层交换机、三层交换机、路由器的功能、使用场景与区别 (1)网桥: 橋接器(英语:network bridge),又称网桥,一種網路裝置,負責網路橋接(network bridging)之用。 橋接器将网络的多个网段在数据链路层(O…

    Linux干货 2016-11-15
  • 网卡路由配置信息及偷懒用法

            对于初学Linux的人来说,配置网卡无疑是比较晕的,各种的配置文件,字段、命令等让人眼花撩乱。所以这一章主要给大多数还在网卡配置路由配置的同学们解惑一、网卡配置基本概念        …

    Linux干货 2017-05-08
  • 磁盘管理(1)

    1、磁盘结构(机械硬盘) (1)磁盘构成: 磁臂(机械手臂):连接并固定磁头 马达(电机):可以转动盘片,让磁臂上的磁头可以在盘片上读写数据 扇区:最小的物理存储单位,每个扇区为512bytes 磁头:可以读写数据 盘片:主要记录数据 柱面:将扇区组成一个圆就是柱面,柱面是分区的最小单位 (2)磁盘接口 并口:IDE  SCSI&nbsp…

    Linux干货 2016-08-30