zoukankan      html  css  js  c++  java
  • shell简单管理iptables脚本 枯木

    #!/bin/bash
    while [ "1" == "1" ]
    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(输完ACL后要记得保存和查看)"
    echo "(6) iptables status"
    echo "(7) iptables ACL list"
    echo "(0) exit"
    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
                 service iptables save
              elif [ "${aclnum}" == "2" ]
                 then
                 read ip
                 iptables -A INPUT -p tcp --dport ${IP}  -j ACCEPT
                 service iptables save
              elif [ "${aclnum}" == "3" ]
                 then
                 read ip port
                 iptables -A INPUT -p tcp -s ${ip} --dport ${port} -j ACCEPT
                 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
                 service iptables save
              elif [ "${aclnum}" == "2" ]
                 then
                 read port
                 iptables -D INPUT -p tcp --dport ${port}  -j ACCEPT
                 service iptables save
              elif [ "${aclnum}" == "3" ]
                 then
                 read ip port
                 iptables -D INPUT -p tcp -s ${ip} --dport ${port} -j ACCEPT
                 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
    


  • 相关阅读:
    [连载]《C#通讯(串口和网络)框架的设计与实现》-1.通讯框架介绍
    [连载]《C#通讯(串口和网络)框架的设计与实现》- 0.前言
    [注意]SerialPort操作PCI-1621D多串口卡,出现异常"参数不正确"
    [发布]SuperIO v2.2.5 集成OPC服务端和OPC客户端
    【发布】工业串口和网络软件通讯平台(SuperIO v2.2.4)
    【工业串口和网络软件通讯平台(SuperIO)教程】九.重写通讯接口函数,实现特殊通讯方式
    【工业串口和网络软件通讯平台(SuperIO)教程】八.SuperIO通讯机制与设备驱动对接的说明
    【工业串口和网络软件通讯平台(SuperIO)教程】七.二次开发服务驱动
    【工业串口和网络软件通讯平台(SuperIO)教程】六.二次开发导出数据驱动
    【工业串口和网络软件通讯平台(SuperIO)教程】五.二次开发图形显示界面
  • 原文地址:https://www.cnblogs.com/kumulinux/p/2808756.html
Copyright © 2011-2022 走看看