Shell脚本应用(for、while循环语句和case分支语句)
1、for:读取不同的变量值,逐个执行同一组命令,直到取值完毕退出,变量值以空格分隔
语法:
for 变量值 in 取值列表
do
命令序列
done
2、while:重复测试某个条件,成立则执行,进入下一个循环,直到条件不成立为止
语法:
while 【条件测试 】
do
命令
添加更改测试条件语句
done
例:批量添加用户(stu1~stu20)
prefix=“stu”
i=1
while 【 $i -le 20 】
do
useradd ${prefix}$i
echo “123456” | passwd --stdin ${prefix}$i &> /dev/null
let i++
done
while条件为true:代表永远为真,死循环,必须使用exit或break命令才结束循环
必须进行递增,避免死循环:方法:
Let i++ let i=i+1 i=`expr i+1`
3、case:针对变量的不同取值,分别执行不同的命令序列
语法:
case 变量值 in
模式1)
命令序列1
;;
模式2)
命令序列2
;;
……
*)
默认命令序列
esac
取值时,中括号【】,代表任选其一 ,横杠 - ,代表取值范围,竖杠 | ,代表或者
Shell脚本(for、while和case语句的应用示例)
一、for循环语句
1、根据姓名列表批量添加用户
步骤:首先创建一个姓名列表 vim /root/users.txt 然后创建脚本vim uaddfor.sh批量添加用户
授权并执行后查看用户是否已创建
2、根据ip地址列表检查主机状态
步骤:首先创建一个ip地址列表文件 vim /root/padds.txt 然后创建脚本vim chkhosts.sh
授权并执行
二、while循环语句
1、批量添加规律编号的用户
步骤:创建vim uaddwhile.sh脚本
授权并执行后查看用户是否已创建
2、猜价格游戏
步骤:创建脚本vim pricegame.sh
授权并执行
三、case分支语句
1、检查用户输入的字符类型
步骤:创建脚本vim hitkey.sh
授权并执行
2、编写系统服务脚本
步骤:编写脚本 vim myprog
授权并执行
四、实验案例
1、编写getarp.sh脚本文件
(1)通过arping命令发送ARP请求,根据反馈结果记录MAC地址。
(2)将网段地址(如192.168.4.)赋值给变量NADD,作为检测地址的前缀。
(3)使用while循环语句,重复检测目标并记录MAC地址,主机地址从1-254。
脚本如下:
[root@localhost ~]# vi getarp.sh
#!/bin/bash
# 1. 定义网段地址、MAC列表文件
NADD="192.168.4."
FILE="/etc/ethers"
# 2. 发送ARP请求,并记录反馈结果
[ -f $FILE ] && /bin/cp -f $FILE $FILE.old //备份原有文件
HADD=1 //定义起始扫描地址
while [ $HADD -lt 128 ]
do
arping -c 2 -w 1 ${NADD}${HADD} &> /dev/null
if [ $? -eq 0 ] ; then
arp -n | grep ${NADD}${HADD} | awk '{print $1,$3}' >> $FILE
fi
let HADD++
done
[root@localhost ~]# chmod +x getarp.sh
[root@localhost ~]# ./getarp.sh //执行检测程序
[root@localhost ~]# cat /etc/ethers //确认记录结果
192.168.4.12 00:0C:29:C3:F8:51
192.168.4.110 00:50:56:C0:00:01
…… //省略部分内容
2、编写scanhost.sh脚本
(1)有很多方法可以检测一个主机是否开启匿名FTP服务,这里采取以wget下载工具访问FTP根目录的方式,若能够成功列表,则视为匿名FTP已开启,否则视为关闭。
(2)通过awk命令过滤出/etc/ethers文件中的所有IP地址,赋值给变量TARGET。
(3)使用for循环语句,读取TARGET变量中的IP地址,重复探测FTP开启情况。
脚本如下:
[root@localhost ~]# vi scanhost.sh
#!/bin/bash
TARGET=$(awk '{print $1}' /etc/ethers)
echo "以下主机已开放匿名FTP服务:"
for IP in $TARGET
do
wget ftp://$IP/ &> /dev/null
if [ $? -eq 0 ] ; then
echo $IP
rm -rf index.html //删除测试产生的临时文件
fi
done
[root@localhost ~]# chmod +x scanhost.sh
[root@localhost ~]# ./scanhost.sh //执行脚本,确认扫描结果
以下主机已开放匿名FTP服务:
192.168.4.110
192.168.4.129