php表单验证,防垃圾机器人刷表单

最近在看php核心技术与开发实践,里面的这段放垃圾机器人刷表单的程序分享一下,自己写了一个简单的表单提交

    /**
     * 模拟机器人来发表微博评论
     */
    define('SECRET', '67%$#ap28');
    
    function m_token() {
        $str = mt_rand(1000, 9999);
        $str2 = dechex($_SERVER['REQUEST_TIME'] - $str);
        return $str . substr(md5($str . SECRET), 0, 10) . $str2;
    }
    
    function v_token($str, $delay = 3) {
        $rs = substr($str, 0, 4); 
        $middle = substr($str, 0, 14);
        $rs2 = substr($str, 14, 8); 
        return ($middle == $rs.substr(md5($rs.SECRET), 0, 10)) &&  
            ($_SERVER['REQUEST_TIME'] - hexdec($rs2) - $rs < $delay);
    }
    
    ?>
    <html>
    <meta charset="utf-8">
    <head>
    <title>提交验证</title>
    </head>
    <body>
        <form action="" method="post">
            <input name="user" value="" />
            <input type="submit" name="submit" value="提交" />
            <input type="hidden" name="token" value="<?php echo m_token();?>" />
        </form>
    </body>
    </html>


上面这段代码也可以用作防止csrf攻击。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值