如何用shell判断ip是否合法
4个回答
展开全部
#!/bin/bash
# Test an IP address for validity:
# Usage:
# valid_ip IP_ADDRESS
# if [[ $? -eq 0 ]]; then echo good; else echo bad; fi
# OR
# if valid_ip IP_ADDRESS; then echo good; else echo bad; fi
#
function valid_ip()
{
local ip=$1
local stat=1
if [[ $ip =~ ^[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}$ ]]; then
OIFS=$IFS
IFS='.'
ip=($ip)
IFS=$OIFS
[[ ${ip[0]} -le 255 && ${ip[1]} -le 255 \
&& ${ip[2]} -le 255 && ${ip[3]} -le 255 ]]
stat=$?
fi
return $stat
}
# If run directly, execute some tests.
if [[ "$(basename $0 .sh)" == 'valid_ip' ]]; then
ips='
4.2.2.2
a.b.c.d
192.168.1.1
0.0.0.0
255.255.255.255
255.255.255.256
192.168.0.1
192.168.0
1234.123.123.123
'
for ip in $ips
do
if valid_ip $ip; then stat='good'; else stat='bad'; fi
printf "%-20s: %s\n" "$ip" "$stat"
done
fi
试试这个
快又稳
2024-10-28 广告
2024-10-28 广告
在Linux环境下配置基于域名的虚拟主机,需安装Apache或Nginx等Web服务器,并编辑配置文件。以Apache为例,需创建虚拟主机配置文件,指定域名、文档根目录等,然后启用该配置文件并重启Apache服务。同样,Nginx也需在相应...
点击进入详情页
本回答由快又稳提供
展开全部
#/bin/bash
echo -n "请输入IP地址 : "
read ip
ip1=`echo $ip|cut -d . -f 1`
ip2=`echo $ip|cut -d . -f 2`
ip3=`echo $ip|cut -d . -f 3`
ip4=`echo $ip|cut -d . -f 4`
a=`echo $ip|grep "\."`
if [[ -z "$ip1" ]];then
echo "ip error"
exit 8
fi
if [[ ! -z "$ip1" ]] && [ $ip1 -lt 255 ];then
if [[ ! -z "$ip2" ]] && [ $ip2 -lt 255 ] ;then
if [[ ! -z "$ip3" ]] && [ $ip3 -lt 255 ] ;then
if [[ ! -z "$ip4" ]] && [ $ip4 -lt 255 ] && [ $ip4 -ne 0 ] && [ $ip4 -ne 255 ];then
echo "ip ok"
else
echo "ip error"
fi
else
echo "ip error"
fi
else
echo "ip error"
fi
else
echo "ip error"
fi
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询