原文:http://www.right.com.cn/forum/thread-124429-1-1.html

原理:1. snort做入侵检测是很好,但是太大太复杂,我们需要轻量化的操作。当对方进行SSH 端口的穷举攻击的时候,dropbear会在系统log中记录下特定信息如:

Login attempt for nonexistent user

Bad password attempt for

通过后台crontab当特定时间段内检测到一定频率的攻击,则将此IP所有数据包全部DROP忽略。

2. 安装:

1)复制脚本DropBrute.sh 到任意目录如 /etc/ 下,授予执行权限如0755. 在crontab(LUCI WEB -->system - scheduled task)中加入一行,每隔一段时间执行:

*/10 * * * * /etc/DropBrute.sh 2>&1 >> /tmp/DropBrute.log

关于如何配置定期任务cron: http://en.wikipedia.org/wiki/Cron

本例是10分钟执行一次扫描log

3. 脚本配置:

见脚本中说明,如看不懂英文请补习英语。

20170321更新:

a)好久以来一直以为这个代码能好好的干活,不过最近调试其它脚本时发现iptables里并没有DropBrute该有的Drop IP,这很不科学,所以仔细看了代码,发现当中有几个需要修改的地方:

1、today=`date -'%a %b %d`

2、日志中记录登陆失败的表达首字母为大写,如Login\Bad

b)还有一点要注意的:要把下面三行添加到/etc/firewall.user里面去

iptables -N DropBrute

iptables -I input_rule -i br-wan -p tcp --dport 22 -j DropBrute

iptables -I input_rule -i br-wan -p tcp --dport 22 -m state --state NEW -m limit --limit 6/min --limit-burst 6 -j ACCEPT

(下面主修改后的正确代码,修改的地方就不说明了)

#!/bin/sh

#

# DropBrute.sh @20130516

#

# minimalist OpenWRT/dropbear ssh brute force attack banning script

#

# Installation steps:

#

# 1) Optionally edit the variables in the header of this script to customise

#    for your environment

#

# 2) Insert a reference for this rule in your firewall script before you

#    accept ssh, something like:

#

#    iptables -N DropBrute

#    iptables -I input_rule -i br-wan -p tcp --dport 22 -j DropBrute

#    iptables -I input_rule -i br-wan -p tcp --dport 22 -m state --state NEW -m limit --limit 6/min --limit-burst 6 -j ACCEPT

#

# 3) Run the script periodically out of cron:

#

#    echo '*/10 * * * * /usr/sbin/DropBrute.sh 2>&1 >> /tmp/DropBrute.log' >> /etc/crontabs/root

#

# 4) If cron is not enabled, you'll also need to run the following:

#

#    /etc/init.d/cron enable && /etc/init.d/cron start

#

#

# To whitelist hosts or networks, simply add a manual entry to the lease

# file with a leasetime of -1.  This can be done with the following syntax:

#

#    echo -1 192.168.1.0/24 >> /tmp/DropBrute.leases

#

# A static, or non-expiring blacklist of a host or network can also be

# added, just use a lease time of 0.  This can be done with the following syntax:

#

#    echo 0 1.2.3.0/24 >> /tmp/DropBrute.leases

# How many bad attempts before banning. Only the log entries from the

# current day are checked.

allowedAttempts=5

# How long IPs are banned for after the current day ends.

# default is 1 days

secondsToBan=$((7*60*60*24))

# the "lease" file - defaults to /tmp which does not persist across reboots

leaseFile=/tmp/DropBrute.leases

# This is the iptables chain that drop commands will go into.

# you will need to put a reference in your firewall rules for this

iptChain=DropBrute

# the IP Tables drop rule

iptDropRule='-j DROP'

# the IP Tables whitelist rule

iptWhiteRule='-j RETURN'

# You can put default leasefile entries in the following space.

# Syntax is simply "leasetime _space_ IP_or_network".  A leasetime of -1 is a

# whitelist entry, and a leastime of 0 is a permanent blacklist entry.

[ -f $leaseFile ] || cat <<__EOF__>>$leaseFile

-1 192.168.0.0/24

-1 192.168.1.0/24

__EOF__

# End of user customizable variables (unless you know better )

ipt='/usr/sbin/iptables'

[ `date +'%s'` -lt 1320000000 ] && echo System date not set, aborting. && exit -1

$ipt -N $iptChain >&/dev/null

today=`date +'%a %b %d'`

now=`date +'%s'`

nowPlus=$((now + secondsToBan))

echo Running DropBrute on `date` \($now\)

# find new badIPs

for badIP in `logread|egrep "^$today"|fgrep dropbear|egrep 'Login attempt for nonexistent user'\|'Bad password attempt for'|sed 's/^.*from //'|sed 's/:.*$//'|sort -u` ; do

  found=`logread|egrep "^$today"|fgrep dropbear|egrep 'Login attempt for nonexistent user'\|'Bad password attempt for'|sed 's/^.*from //'|sed 's/:.*$//'|fgrep $badIP|wc -l`

  if [ $found -gt $allowedAttempts ] ; then

    if [ `egrep \ $badIP\$ $leaseFile|wc -l` -gt 0 ] ; then

       [ `egrep \ $badIP\$ $leaseFile|cut -f1 -d\ ` -gt 0 ] && sed -i 's/^.* '$badIP\$/$nowPlus\ $badIP\/ $leaseFile

    else

       echo $nowPlus $badIP >> $leaseFile

    fi

  fi

done

# now parse the leaseFile

while read lease ; do

  leaseTime=`echo $lease|cut -f1 -d\ `

  leaseIP=`echo $lease|cut -f2 -d\ `

  if [ $leaseTime -lt 0 ] ; then

    if [ `$ipt -S $leaseChain|egrep \ $leaseIP/32\ \|\ $leaseIP\ |fgrep -- "$iptWhiteRule"| wc -l` -lt 1 ] ; then

      echo Adding new whitelist rule for $leaseIP

      $ipt -I $iptChain -s $leaseIP $iptWhiteRule

    fi

  elif [ $leaseTime -ge 1 -a $now -gt $leaseTime ] ; then

    echo Expiring lease for $leaseIP

    $ipt -D $iptChain -s $leaseIP $iptDropRule

    sed -i /$leaseIP/d $leaseFile

  elif [ $leaseTime -ge 0 -a `$ipt -S $leaseChain|egrep \ $leaseIP/32\ \|\ $leaseIP\ |wc -l` -lt 1 ] ; then

    echo Adding new rule for $leaseIP

    $ipt -A $iptChain -s $leaseIP $iptDropRule

  fi

done < $leaseFile

openwrt中防暴力破解shell的脚本的更多相关文章

  1. centos7防暴力破解五种方法

    什么是暴力破解,简单来说就是对一个服务器进行无数次尝试登陆,并用不同的密码进行登陆直到可以登陆成功.暴力破解的基本步骤可以分为以下几步: 1. 找到对应的linux服务器    Ip地址 2.扫描端口 ...

  2. fail2ban的使用以及防暴力破解与邮件预警

    fail2ban可以监视你的系统日志,然后匹配日志的错误信息(正则式匹配)执行相应的屏蔽动作(一般情况下是防火墙),而且可以发送e-mail通知系统管理员! fail2ban运行机制:简单来说其功能就 ...

  3. openssh安装、设置指定端口号、免密码登录、变量传递、防暴力破解

    首先确保机器挂在好光盘镜像,然后查看软件包信息 [root@xuegod63 ~]# df -hFilesystem      Size  Used Avail Use% Mounted on/dev ...

  4. WordPress防暴力破解:安全插件和用.htpasswd保护WordPress控制面板

    正在用Wordpress的博主们一定知道最近全球兴起的一波黑客锁定Wordpress暴力破解控制面板密码的风波了,据CloudFlare执行长Matthew Prince所说,所谓的暴力密码攻击是输入 ...

  5. fail2ban 防暴力破解总结

    公司服务器安全问题一直是个令人头疼的问题,许多运维的小伙伴一直在用脚本来监控服务器登录状态,然而脚本编写比较麻烦,今天就给大家推荐一款小而精致的防暴力破解工具 fail2ban ,他可以监控系统日志, ...

  6. Centos6.4 安装fail2ban防暴力破解

    Centos6.4 安装fail2ban防暴力破解 一. 安装 curl -O https://codeload.github.com/fail2ban/fail2ban/tar.gz/0.9.0 m ...

  7. Odoo14 防暴力破解登录密码

    1 # Odoo14 防暴力破解登录密码 2 # 主要工具:redis 3 # 实现思路:限制每个用户24小时内登录失败次数.连续超过5次失败后,需要等待一定时间后才能再次尝试登录 4 # 配置:在你 ...

  8. [典型漏洞分享]YS的防暴力破解设计存在缺陷

    YS使用的防暴力破解机制存在缺陷,该缺陷可被用于暴力破解其它用户密码[高] 问题描述: YS在用户登录页面设置了验证码机制,当用户输入密码错误次数达到3次时,再次登录需要验证码以防止攻击者进行暴力破解 ...

  9. 【Linux系统】防暴力破解

    在日志文件/var/log/secure 中可以看到涉及到安全方面的日志,可以查看是否有人尝试暴力破解及是否成功,对于肉鸡行为有一定帮助 思路基本上都是加强密码的复杂度,增加iptables配置黑名单 ...

随机推荐

  1. JIT和AOT编译详解

    JIT和AOT编译介绍 JIT - Just-In-Time             实时编译,即时编译 通常所说的JIT的优势是Profile-Based Optimization,也就是边跑边优化 ...

  2. WAV和PCM的关系和区别

    什么是WAV和PCM? WAV:wav是一种无损的音频文件格式,WAV符合 PIFF(Resource Interchange File Format)规范.所有的WAV都有一个文件头,这个文件头音频 ...

  3. python类型强转&二级容器

    Number 类型强转 int :         ---->>>   float,  bool,  complex,  str Float :        ---->> ...

  4. visual studio 版本管理从tfs迁移到svn

    1.首先要解除解决方案的tfs绑定 清除(删除)项目下的所有版本控制文件,这些文件有:*.vssscc,*.vspscc 删除这些版本控制文件比较简单,搜索这些后缀的文件,删除即可. 修改项目的解决方 ...

  5. python学习笔记之一

    1.可以自己运行,也可以被import后调用 if __name__ == '__main__' main() 2.可变参数,关键字参数,命名关键字参数 可变参数和关键字参数 def f1(a, b, ...

  6. 关于Vue实例的生命周期created和mounted的区别

    什么是生命周期 Vue实例有一个完整的生命周期,也就是从开始创建.初始化数据.编译模板.挂载Dom.渲染→更新→渲染.卸载等一系列过程,我们称这是Vue的生命周期.通俗说就是Vue实例从创建到销毁的过 ...

  7. 【Unix网络编程】chapter7套接字选项

    7.1 概述 有很多方法来获取和设置影响套接字的选项: getsockopt和setsockopt函数 fcntl函数 ioctl函数 7.2 getsockopt和setsockopt函数 7.3 ...

  8. mysql的DATE_FORMAT参数格式

    mysql有个字段是DATETIME类型,要实现可以按月统计,该怎么写sql语句?select month(f1) from tt group by month(f1)or select DATE_F ...

  9. Json1:使用gson解析、生成json

    Json解析: 1.json第三方解析包:json-lib.gson.jackson.fastjson等2.Google-gson只兼容jdk1.5版本以上:JSON-lib分别支持1.4和1.53. ...

  10. 用户禁止cookie后,如何继续使用session

    (1)如果用户禁止cookie,服务器仍会将sessionId以cookie的方式发送给浏览器,但是,浏览器不再保存这个cookie(即sessionId)了. (2)如果想继续使用session,需 ...