Shell 脚本模拟 milter 实现黑白名单及关键词过滤

程序执行流程:
1. 开始接受邮件。
2. 检查发件人是否在黑名单内,如果是拒绝接受;否则继续
3. 检查发件人是否在白名单内,如果是接收邮件;否则继续
4. 对邮件进行关键字过滤,如果邮件中包含被过滤的关键词信息,则拒绝接收
   该邮件;否则,接收该邮件。

Usage: sh mailfilter.sh  [-r reject-addr] [-a add-addr][-k keywords]
###########################################################################
#/bin/bash;                                                                 
#当有邮件到达时,先拷贝一份用户分析处理
If_Mail()
{
  User=`whoami`;
  if test -s /var/spool/mail/$User;
  then
    `cp /var/spool/mail/$User /var/spool/mail/tmp`;
    return 1;
  else
    # echo ‘暂无邮件要处理‘;
    return 0;
  fi
}

#定位制定email行号
Locate()
{
   if [ -f "/var/spool/mail/tmp" ];
   then
     Get_String=`grep -n $1  /var/spool/mail/tmp|head -1`;
     #${varible%%string*}从右向左截取最后一个string后的字符串
     Get_N=${Get_String%%:*};
     #Get_Sting=`sed ‘$n,touch@localhost.localdomain‘ /var/spool/mail/tmp|head -1`;
     #echo $Get_Sting;
   else
     Get_N=0;
   fi
  return $Get_N;
}

Deal_Black_List()
{
  #此邮件判断在黑名单中
  Mail_Addr=$1;
  Locate $Mail_Addr;
  #$?显示最后命令的退出状态
  if test $? -eq 1;
  then
    echo "$Mail_Addr 已被列入黑名单,拒收此Email!!!";
    #清空文件
    `echo > /var/spool/mail/$User`;
    # 删除空白行
    ` sed -i ‘/^$/d‘ /var/spool/mail/$User`;
    `rm /var/spool/mail/tmp`;
    return 1;
  else
    return 0;
  fi
}

Deal_White_List()
{
  Email_Addr=$1;
  Locate $Email_Addr;
  #$?显示最后命令的退出状态
  if test $? -eq 1;
  then
    return 1;
  else
    return 0;
  fi
}

Filter_Keywords()
{
    if  [ -f "/var/spool/mail/tmp" ] && [ 0 -lt `grep -c $1 /var/spool/mail/tmp` ];
    then
      echo "含有过滤关键词$1,拒收此Email!!!";
      #清空文件
      `echo > /var/spool/mail/$User`;
      # 删除空白行
      `sed -i ‘/^$/d‘ /var/spool/mail/$User`;
      `rm /var/spool/mail/tmp`;
      return 1;
    else
      echo "邮件接受";
      return 0;
    fi
}

while getopts :r:a:k:h opt
do  
    case $opt in
        r)
            Black_Addr=$OPTARG;
            ;;
        a)
            White_Addr=$OPTARG;
        ;;
        k)
            Keywords=$OPTARG;
            ;;
        h)
            echo "Usage: sh mail.sh  [-r reject-addr] [-a add-addr]";
            exit 0;
            ;;
        *)
            echo "-$opt 参数输入错误!";
            exit 0;
            ;;
    esac
done

echo ‘邮件过滤系统启用‘;
Old_Hash=`md5sum /var/spool/mail/$USER|cut -d‘ ‘ -f1`;
New_Hash=`md5sum /var/spool/mail/$USER|cut -d‘ ‘ -f1`;
while :
do
  sleep 3;
  n=0;
  If_Mail;
  if test $? -eq 0;
  then
     #邮件为空
     continue;
  else
     New_Hash=`md5sum /var/spool/mail/$USER|cut -d‘ ‘ -f1`;
  fi
  #判断是否有新文件
  if [ "$Old_Hash" = "$New_Hash" ];
  then
    continue;
  else
    echo ‘新邮件到达,系统即将处理!‘;
    Old_Hash=`md5sum /var/spool/mail/$USER|cut -d‘ ‘ -f1`;  
  fi
#黑名单过滤  
  Deal_Black_List $Black_Addr;
  if test $? -eq 1;
  then
    continue;
  fi
#白名单过滤  
  Deal_White_List $White_Addr;
  if test $? -eq 1;
  then
    echo "$White_Addr的邮件已接收"
    continue;
  fi
#关键词过滤
  Filter_Keywords $Keywords;
done
###########################################################################

这是我的一次作业,第一次写shell脚本,不乏纰漏。望指正!

时间: 2024-09-29 02:32:07

Shell 脚本模拟 milter 实现黑白名单及关键词过滤的相关文章

自定义shell脚本快速搭建LNMP环境(Ubuntu16.04 LTS / PHP7.0)

循环shell脚本模拟 apt install app, 把需要的app写在apps.txt即可. 一.lnmp_install.sh (需要有可执行权限) #!/bin/bash #Program function : Lnmp基础环境搭建,基于PHP7.0/MySQL5.7,并安装自定义软件 for app in $(cat apps.txt) do comment=${app:0:1} if [ -n ${app} ] then if [[ ${comment} == "#" ]

使用shell脚本简单模拟对特定文件同时读写操作

使用shell脚本简单模拟对特定文件同时读写操作文件内容的格式:field1    ,       field2    , field3    ,       field4以,为分隔符,但是存在空格. 脚本用法如下: ./check_write_read.sh 10 输出结果: Thu Apr 27 19:59:44 CST 2017:Read operation finished 670 Thu Apr 27 19:59:44 CST 2017:Write operation finished

Linux shell脚本编程详解及应用实例

什么是shell脚本? 1.shell脚本:是一种解释型语言,不需要提前进行编译,只需将代码转化成中间代码,边解释边运行,执行效率稍逊于编译型语言,跨平台性好.而编译型语言则需要提前进行编译转化为二进制文件,靠近底层硬件执行效率高,可移植性差. 2.shell的首行严格来说使用shebang机制:由#和!构成的字符序列,在类unix系统中程序的载入器将其后的内容,当做解释器的指令,并将载有shebang文件路径作为解释器的参数,且予以调用. shell及其他解释型语言的一般格式?  #!/bin

DDoS攻防战(三):ip黑白名单防火墙frdev的原理与实现

汤之盘铭曰 苟日新 日日新 又日新 康诰曰 作新民   诗曰 周虽旧邦 其命维新   是故 君子无所不用其极  ——礼记·大学 在上一篇文章<DDoS攻防战 (二) :CC攻击工具实现与防御理论>中,笔者阐述了一个防御状态机,它可用来抵御来自应用层的DDoS攻击,但是该状态机依赖一个能应对大量条目快速增删的ip黑白名单防火墙,我们目前并没有发现很好的开源实现以供我们使用. ·实现方案选择: 硬件实现或者软件实现? 在面对诸如大量畸形包这样的攻击时,硬件实现将会是非常好的选择,这是因为在进行此类

(转自张戈博客)Linux系统防CC攻击自动拉黑IP增强版Shell脚本

(转自张戈博客) 前天没事写了一个防CC攻击的Shell脚本,没想到这么快就要用上了,原因是因为360网站卫士的缓存黑名单突然无法过滤后台,导致WordPress无法登录!虽然,可以通过修改本地hosts文件来解决这个问题,但是还是想暂时取消CDN加速和防护来测试下服务器的性能优化及安全防护. 前天写的Shell脚本是加入到crontab计划任务执行的,每5分钟执行一次,今天实际测试了下,可还是可以用的,但是感觉5分钟时间有点过长,无法做到严密防护.于是稍微改进了下代码,现在简单的分享下! 一.

shell脚本练习题

求出数字1~100的累加和: 要求数字的累加,可以使用循环来完成,如下代码: #!/bin/bash sum=0 str="" #for i in {1..100} for ((i=1 ; i<=100 ; ++i)) do     str+="${i}+"     let sum+=i done echo "${str%+}=${sum}" 运行脚本: 另外一种可以用递归的方式: #!/bin/bash read num  sum=0 s

Shell脚本编程30分钟入门

什么是Shell脚本 示例 看个例子吧: #!/bin/sh cd ~ mkdir shell_tut cd shell_tut for ((i=0; i<10; i++)); do touch test_$i.txt done 示例解释 第1行:指定脚本解释器,这里是用/bin/sh做解释器的 第2行:切换到当前用户的home目录 第3行:创建一个目录shell_tut 第4行:切换到shell_tut目录 第5行:循环条件,一共循环10次 第6行:创建一个test_1…10.txt文件 第7

Windows下搭建Openvpn使用用户名和密码验证方式如何引用shell脚本

网上找了很多资料关于Openvpn使用用户名和密码验证方式的大都是在linux环境下搭建的.其实在windows下搭建可以参考linux的情况,可以找到很多资料,主要遇到的问题是如何引用那个checkpw.sh的shell脚本.这里记下自己的经验. 为了引用此脚本,看了网上一个博客后有了点idea.首先安装Cygwin,Cygwin是一个在windows平台上运行的类UNIX模拟环境.之后写一个bat文件,如script.bat: C:/cygwin64/bin/bash.exe  C:/che

正则与shell脚本

Day01 计算机组成硬件-->内核[驱动]-->shell或图形-->人 汽车shellbash--宝马tcsh--吉利#cat /etc/shells bash-completion[rhel7] 命令和路径选项 /etc/profile 环境变量和启动程序/etc/bashrc  函数和别名/root/.bash_profile/root/.bashrc #vim /etc/profileHISTSIZE=1000    命令历史的条目echo "test" 标