• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    Shell实现的iptables管理脚本分享

    以前的脚本是用save模式,现在把命令附加到一个文件里面,这样的话,可以方便的二次修改什么的
    脚本基本是这样的,大家可以跟自己的情况再次修改~  增加功能什么的。

    复制代码 代码如下:

    #!/bin/bash
    while true
    do
    clear
    echo "----------------------menu----------------------"
    echo "(1) service iptables restart"
    echo "(2) iptables add"
    echo "(3) iptables delete"
    echo "(4) iptables stop"
    echo "(5) iptables save(不推荐使用这种模式)"
    echo "(6) iptables status"
    echo "(7) iptables ACL list"
    echo "(0) exit"
    echo "会在当前的目录下生成一个fw.sh文件"
    echo "-------------------------------------------------"
    echo -n "enter you chose[0-7]:"
    read num
    if [ ${num} -lt 0 -o ${num} -gt 7 ]
        then
          echo "this is not between 0-7"
    else
       if [ "${num}" == "1" ]
          then
          service iptables restart
    else
       if [ "${num}" == "2" ]
    #######################################################
           then
              while [ "1" == "1" ]
              do
              clear
              echo "----------------------add ACL----------------------"
              echo "(1) 针对源IP放行添加"
              echo "(2) 针对服务器端口放行添加"
              echo "(3) 针对有端口和服务的ACL添加(这里要参数IP和端口 例如 0/0 80)"
              echo "(4) 自定义添加"
              echo "(5) 退回上一级"
              echo "-------------------------------------------------"
              echo -n "enter you chose[0-4]:"
              read aclnum
              if [ "${aclnum}" == "1" ]
                 then
                 read ip
                 iptables -A INPUT -s ${ip} -p tcp --dport 22 -j ACCEPT
             echo "iptables -A INPUT -s ${ip} -p tcp --dport 22 -j ACCEPT" >>fw.sh
    #            service iptables save
              elif [ "${aclnum}" == "2" ]
                 then
                 rad ip
                 iptables -A INPUT -p tcp --dport ${IP}  -j ACCEPT
             echo "iptables -A INPUT -p tcp --dport ${IP}  -j ACCEPT" >>fw.sh
    #            service iptables save
              elif [ "${aclnum}" == "3" ]
                 then
                 read ip port
                 iptables -A INPUT -p tcp -s ${ip} --dport ${port} -j ACCEPT
                 echo "iptables -A INPUT -p tcp -s ${ip} --dport ${port} -j ACCEPT" >>fw.sh
    #            service iptables save
              elif [ "${aclnum}" == "4" ]
                 then
                 read addacl
                 `${addacl}`
                 service iptables save
              else
                 break
              fi
              echo -n "是否想继续添加: [y/n]:"
              read contine
              if [ "${contine}" == "n" -o "${contine}" == "N" ]
                 then
                 break
                 fi
              done
    #######################################################
    else
       if [ "${num}" == "3" ]
              then
              while [ "1" == "1" ]
              do
              clear
              echo "---------------------delete ACL----------------------"
              echo "(1) 针对源ip删除"
              echo "(2) 针对端口删除"
              echo "(3) 针对有端口和服务的ACL删除"
              echo "(4) 自定义删除"
              echo "(5) 退回上一级"
              echo "-------------------------------------------------"
              echo -n "enter you chose[0-5]:"
              read aclnum
              if [ "${aclnum}" == "1" ]
                 then
                 read ip
                 iptables -D INPUT -s ${ip} -p tcp --dport 22 -j ACCEPT
                 echo "iptables -D INPUT -s ${ip} -p tcp --dport 22 -j ACCEPT" >>fw.sh
    #            service iptables save
              elif [ "${aclnum}" == "2" ]
                 then
                 read port
                 iptables -D INPUT -p tcp --dport ${port}  -j ACCEPT
                 echo "iptables -D INPUT -p tcp --dport ${port}  -j ACCEPT" >>fw.sh
    #            service iptables save
              elif [ "${aclnum}" == "3" ]
                 then
                 read ip port
                 iptables -D INPUT -p tcp -s ${ip} --dport ${port} -j ACCEPT
             echo "iptables -D INPUT -p tcp -s ${ip} --dport ${port} -j ACCEPT" >>fw.sh
    #            service iptables save
              elif [ "${aclnum}" == "4" ]
                 then
                 read deleteacl
                 `${deleteacl}`
                 service iptables save
              else
                 break
              fi
              echo -n "是否想继续添加: [y/n]:"
              read contine
              if [ "${contine}" == "n" -o "${contine}" == "N" ]
                 then
                 break
                 fi
              done
    ###################################################################
    else
       if [ "${num}" == "4" ]
           then
           echo -e "`service iptables stop` "
    else
       if [ "${num}" == "5" ]
           then
           echo -e "`service iptables save`"
    else
       if [ "${num}" == "6" ]
           then
           echo -e "`service iptables status`"
    else
       if [ "${num}" == "7" ]
           then
             while [ "1" == "1" ]
           do
           clear
           echo "---------------------list ACL----------------------"
           echo "(1) 查看当前正在使用的规则集"
           echo "(2) 查看每个策略或每条规则、每条链的简单流量统计"
           echo "(3) 查看NAT表"
           echo "(4) 自定义查看"
           echo "(5) 退回上一级"
           echo "-------------------------------------------------"
           echo -n "enter you chose[0-5]:"
           read aclnum
           if [ "${aclnum}" == "1" ]
              then
              iptables -L
           elif [ "${aclnum}" == "2" ]
              then
              iptables -L -n -v
           elif [ "${aclnum}" == "3" ]
              then
              iptables -L -t nat
           elif [ "${aclnum}" == "4" ]
              then
              read listacl
              `${listacl}`
           else
            break
             fi
           echo -n "是否想继续添加: [y/n]:"
              read contine
              if [ "${contine}" == "n" -o "${contine}" == "N" ]
                 then
                 break
              fi
           done
    ################################################
    else   
       exit
    fi
      fi
        fi
         fi
          fi
           fi
            fi
             fi
    echo -n "Do you contine [y/n]:"
    read contine
    if [ "${contine}" == "n" -o "${contine}" == "N" ]
       then
       exit
    fi
    done

    您可能感兴趣的文章:
    • Shell监控iptables运行状态
    • Shell脚本实现监控iptables规则是否被修改
    • Shell脚本实现监控iptables运行状态
    • Shell脚本配合iptables屏蔽来自某个国家的IP访问
    • CentOS 7 下使用 iptables
    上一篇:Shell脚本实现分析apache日志中ip所在的地区
    下一篇:Shell脚本实现防止国外ip访问服务器
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯 版权所有

    《增值电信业务经营许可证》 苏ICP备15040257号-8

    Shell实现的iptables管理脚本分享 Shell,实现,的,iptables,管理,