机器屡次歹意提交进犯简略防备

访客5年前黑客工具753

 先说布景:机器不断的发送恳求或许歹意提交,会给服务器形成很大压力;针对这种进犯 更优的战略是判别提交次数,发生动态验证码 ,即 判别ip规则时刻内重复发送到达N次弹出验证码 。下面是小拽在实践进程中一个简略的辨认ip,使用session记载和防护的进程。

辨认和校验ip

进程如下;

辨认ip

ip归于白名单直接经过[白名单战略:内网ip+指定ip表]

使用session存储ip的恳求时刻戳

校验规则时刻内ip的恳求次数

采纳相应的办法

/**
 * 获取和校验ip;一起避免短时刻内屡次提交
 *
 * @notice        :弹出验证码,需求替换掉echo $echo_str 即可。
 * @return string :回来校验成功的ip
 */
protected function getAndCheckIP()
{

    // 获取环境ip
    if (getenv("HTTP_CLIENT_IP") && strcasecmp(getenv("HTTP_CLIENT_IP"), "unknown"))
        $ip = getenv("HTTP_CLIENT_IP");
    else if (getenv("HTTP_X_FORWARDED_FOR") && strcasecmp(getenv("HTTP_X_FORWARDED_FOR"), "unknown"))
        $ip = getenv("HTTP_X_FORWARDED_FOR");
    else if (getenv("REMOTE_ADDR") && strcasecmp(getenv("REMOTE_ADDR"), "unknown"))
        $ip = getenv("REMOTE_ADDR");
    else if (isset($_SERVER['REMOTE_ADDR']) && $_SERVER['REMOTE_ADDR'] && strcasecmp($_SERVER['REMOTE_ADDR'], "unknown"))
        $ip = $_SERVER['REMOTE_ADDR'];
    else
        $ip = "unknown";

    // check 环境ip
    if (!$this->isWhiteList($ip)) {
        $echo_str = "提交过于频频,请稍后再试!";
        // 构建ip的时刻栈数据
        if (!is_array($_SESSION[$ip])) {
            $_SESSION[$ip] = array();
        }

        if (isset($_SESSION[$ip][0])) {
            $_SESSION[$ip][] = time();

            // session 保存时刻为6小时。整理session
            $post_interval_first = time() - $_SESSION[$ip][0];
            if ($post_interval_first > 21600) {
                $_SESSION[$ip] = array();
            }

            // 两次提交小于1s,制止提交
            $post_interval_pre = time() - $_SESSION[$ip][count($_SESSION[$ip]) - 3];
            if ($post_interval_pre < 1) {
                echo $echo_str;
                exit;
            };

            // 您在10s内现已提交了3恳求,制止提交
            $post_interval_third = time() - $_SESSION[$ip][count($_SESSION[$ip]) - 3];
            if (isset($_SESSION[$ip][3]) && ($post_interval_third < 10)) {
                echo $echo_str;
                exit;
            }

            // 您在1分钟期间现已提交了5恳求,制止提交
            $post_interval_fifth = time() - $_SESSION[$ip][count($_SESSION[$ip]) - 3];
            if (isset($_SESSION[$ip][5]) && ($post_interval_fifth < 60)) {
                echo $echo_str;
                exit;
            }

            // 6小时内提交10次,制止提交
            if (isset($_SESSION[$ip][10])) {
                echo $echo_str;
                exit;
            }
        } else {
            $_SESSION[$ip][] = time();
        }
    }

    return ($ip);
}

白名单战略

白名单战略选用:内网ip放行和特定ip放行

/**
 * 查验是否存在于白名单中
 *
 * @param $ip    :校验的ip
 * @return bool  :校验成果
 */
function isWhiteList($ip){
    /**
     * 内网ip默许悉数存在于白名单中
     */
    if(!filter_var($ip, FILTER_VALIDATE_IP, FILTER_FLAG_NO_PRIV_RANGE | FILTER_FLAG_NO_RES_RANGE)){
        return true;
    }

    // 是否在写死的whitelist 里边
    return in_array($ip,$this->_WHTTE_LIST);
}

防进犯战略

小拽选用的比较简略的战略,如上面代码,实践进程中能够结合事务需求。

1s内制止重复提交

5s内提交上限3次

60s内提交上限5次

6小时内提交上限10次

相关文章

黑客软件_qq找号黑客-真正的黑客软件哪里找

*/ if ($id) { |_ TCP port: 1433黑客软件,qq找号黑客 哈希长度扩张进犯(hash length attack)是一类针对某些哈希函数能够额定增加一些信息的进犯手法...

网站入侵,微赢棋牌找网络黑客,什么地方可以找黑客

-e界说到那个字符串就中止生成暗码,例如:-e999999就表明在生成暗码到99999时就中止生成暗码《CLR via C#》5、使用数据库履行在网站根目录输出vbs脚本。 侵略就完成了 b)在...

网络赌博欠了网贷,老想赢回来还网贷,结果每次输

下图显示的是GCC会话初始化过程中的非正常信道请求(“MS_T120”信道编号为4):受影响的操作系统test.local网络赌博欠了网贷,老想赢回来还网贷,结果每次输, 回溯调用堆栈显示了一系列处理...

专业接单黑客联系方式免费_计算机编程入门自学

脚本块(script block)日志17、123123 (无变化) SetSpawningHostId set_spawning_host_id = 4;专业接单黑客联系方式免费,计算机编程入门自学...

西安手机黑客接单_黑客怎么找网络漏洞

在网络安全范畴中,猜测网络违法和歹意软件发展趋势好像现已成为了各大网络安全公司的传统了。 为了防止让咱们去阅览上百页的安全陈述,咱们专门整兼并总结了McAfee、Forrester、FiskIQ、卡巴...

能接单的黑客微信群_找黑客盗号去哪找

在大多数编程言语中,一般切割作业的方法是运用一种叫做线程的东西,就像有多个人在一个项目上作业。 假如你有彼此独立的使命,你能够给他们不同的线程。 然后,这两个线程能够一起处理独自的使命。 例如,你能够...