shell脚本管理员通过输入防火墙端口码查看端口的打开或关闭
时间: 2024-01-22 08:20:17 浏览: 75
您可以使用以下的 Shell 脚本来查看端口的打开或关闭状态:
```bash
#!/bin/bash
# 获取输入的端口号
read -p "请输入要查询的端口号:" port
# 检查端口是否被打开
netstat -an | grep $port > /dev/null
if [ $? -eq 0 ]; then
echo "端口 $port 已经打开"
else
echo "端口 $port 没有打开"
fi
```
该脚本会先让管理员输入要查询的端口号,然后使用 `netstat` 命令来检查该端口是否被打开。如果端口已经被打开,则输出 `端口 $port 已经打开`;如果端口没有被打开,则输出 `端口 $port 没有打开`。
相关问题
shell脚本中,管理员输入“端口号”及“on/off”操作,系统根据管理员的输入,开启或关闭指定的端口号
好的,您可以使用以下代码实现:
```bash
#!/bin/bash
# 获取管理员输入的端口号和操作(on/off)
read -p "请输入端口号:" port
read -p "请输入操作(on/off):" action
# 判断操作是否合法
if [ $action != "on" ] && [ $action != "off" ]
then
echo "操作不合法,只能输入 on 或 off"
exit 1
fi
# 开启或关闭指定的端口号
if [ $action == "on" ]
then
firewall-cmd --zone=public --add-port=$port/tcp --permanent
firewall-cmd --reload
echo "端口号 $port 已开启"
else
firewall-cmd --zone=public --remove-port=$port/tcp --permanent
firewall-cmd --reload
echo "端口号 $port 已关闭"
fi
```
其中,`firewall-cmd` 是 CentOS/RHEL 中的防火墙管理工具,如果您使用的是其他操作系统或防火墙管理工具,需要修改相应的命令。此外,为了方便起见,上述代码没有进行输入合法性的检查,实际使用时需要根据具体情况进行修改。
linux利用shell编程配置防火墙要求为当管理选择该选项后,系统允许管理员输入“端口号”及“on/off”操作,系统根据管理员的输入,开启或关闭指定的端口号。
以下是一个示例脚本,可以实现管理员输入端口号和开关状态,根据输入来配置防火墙:
```bash
#!/bin/bash
# 定义函数,用于开启指定端口号
function enable_port {
firewall-cmd --zone=public --add-port=$1/tcp --permanent
firewall-cmd --reload
echo "端口 $1 已开启"
}
# 定义函数,用于关闭指定端口号
function disable_port {
firewall-cmd --zone=public --remove-port=$1/tcp --permanent
firewall-cmd --reload
echo "端口 $1 已关闭"
}
# 等待管理员输入端口号和开关状态
read -p "请输入端口号:" port
read -p "请输入 on 或 off:" status
# 根据管理员输入调用不同的函数
if [ "$status" == "on" ]; then
enable_port $port
elif [ "$status" == "off" ]; then
disable_port $port
else
echo "无效的输入,只能输入 on 或 off"
fi
```
管理员可以运行该脚本并按照提示输入端口号和开关状态,脚本会自动配置防火墙。需要注意的是,该脚本需要以管理员身份运行。
阅读全文