PHP 生成验证码

本文介绍了一种使用PHP生成验证码的方法,并详细展示了如何通过PHP脚本创建包含随机字母和数字的验证码图像。此外,还介绍了如何利用Memcache进行IP地址监测及限制,确保网站的安全性。
这个是在user.php下的一个action:

function scode(){
//include_once( __DIR__.'/include.php' );
Header("Content-type: image/gif");
$border = 1; //是否要边框 1要:0不要
$how = 4; //验证码位数
$w = $how*15; //图片宽度
$h = 20; //图片高度
$fontsize = 5; //字体大小
$alpha = "abcdefghijkmnopqrstuvwxyz"; //验证码内容1:字母
$number = "023456789"; //验证码内容2:数字
$randcode = ""; //验证码字符串初始化
srand((double)microtime()*1000000); //初始化随机数种子
$im = ImageCreate($w, $h); //创建验证图片
$bgcolor = ImageColorAllocate($im, 255, 255, 255); //设置背景颜色
ImageFill($im, 0, 0, $bgcolor); //填充背景色
if($border)
{
$black = ImageColorAllocate($im, 0, 0, 0); //设置边框颜色
ImageRectangle($im, 0, 0, $w-1, $h-1, $black);//绘制边框
}
for($i=0; $i<$how; $i++)
{
$alpha_or_number = mt_rand(0, 1); //字母还是数字
//   $alpha_or_number = 0;
$str = $alpha_or_number ? $alpha : $number;
$which = mt_rand(0, strlen($str)-1); //取哪个字符
if ( $which == 0 || $which=='o' || $which == "O") {
$i--;
continue;
}
$code = substr($str, $which, 1); //取字符
$j = !$i ? 4 : $j+15; //绘字符位置
$color3 = ImageColorAllocate($im, mt_rand(0,100), mt_rand(0,100), mt_rand(0,100)); //字符随即颜色
ImageChar($im, $fontsize, $j, 3, $code, $color3); //绘字符
$randcode .= $code; //逐位加入验证码字符串
}
for($i=0; $i<$how*40; $i++)//绘背景干扰点
{
$color2 = ImageColorAllocate($im, mt_rand(100,200), mt_rand(100,200), mt_rand(100,200)); //干扰点颜色
ImageSetPixel($im, mt_rand(0,$w), mt_rand(0,$h), $color2); //干扰点
}
//把验证码字符串写入session
// if(!session_id())session_start();
XSession::set('security_code', $randcode);
XSession::set('security_code_time', time());
//$_SESSION['randcode'] = $randcode;
// $_SESSION['randcode_time'] = time();
Imagegif($im);
ImageDestroy($im);
}


访问某个页面时的action中植入如下代码:
$flag = check_ip();
$msg = '';
if(!$flag&&isset($_REQUEST['scode'])&&isset($_SESSION['security_code']) ){
$scode = $_REQUEST['scode'];
if((time()-XSession::get('security_code_time'))>180){
$msg = '验证码超时';
$flag = false;
}
if(!$scode or $scode!=XSession::get('security_code')){
$msg = '验证码输入错误';
$flag = false;
}else{
allow_ip();
$flag=true;
}
}
if(!$flag){
if(isset($_REQUEST['wid'])){
$k = 'wid';
$v = $_REQUEST['wid'];
}elseif(isset($_REQUEST['wname'])){
$k = 'wname';
$v = $_REQUEST['wname'];
}
echo '';
echo $msg;
echo ' 请输入验证码: PHP <wbr>生成验证码换一张? ';
echo '';
exit(0);
}
PHP <wbr>生成验证码

关于IP地址的监测:
function check_ip(){
    $mmc=memcache_init();
    
    if($mmc==false)
        echo "mc init failed\n";
    else
    {
        $ip = $_SERVER["REMOTE_ADDR"];
        if (in_array($ip,array('124.205.90.159'))) {
        return true;
        }
        $key = dechex(ip2long($ip));
        if($v = memcache_get($mmc,$key)){
            if($v>10){
return false;
            }
            memcache_set($mmc,$key,$v+1);
        }else{
            memcache_set($mmc,$key,1,0,60);
        }
    }
    return true;
}
function allow_ip(){
$mmc=memcache_init();
if($mmc==false)
echo "mc init failed\n";
else
{
$ip = $_SERVER["REMOTE_ADDR"];
$key = dechex(ip2long($ip));
memcache_set($mmc,$key,1,0,60);
}
return false;
}




<?php $show_title="$MSG_LOGIN - $OJ_NAME"; ?> <?php include("template/$OJ_TEMPLATE/header.php");?> <div class="ui error message" id="error" hidden></div> <div class="ui middle aligned center aligned grid" style="height: 500px;" > <div class="row"> <div class="column" style="max-width: 450px"> <h2 class="ui image header"> <div class="content" style="margin-bottom: 10px; "> <?php echo $MSG_LOGIN ?> </div> </h2> <form class="ui large form" id="login" action="login.php" method="post" role="form" class="form-horizontal" onSubmit="return jsMd5();" > <div class="ui existing segment"> <div class="field"> <div class="ui left icon input"> <i class="user icon"></i> <input name="user_id" placeholder="<?php echo $MSG_USER_ID ?>" type="text" id="username"> </div> </div> <div class="field"> <div class="ui left icon input"> <i class="lock icon"></i> <input name="password" placeholder="<?php echo $MSG_PASSWORD ?>" type="password" id="password"> </div> </div> <?php if($OJ_VCODE){?> <div class="field"> <div class="ui left icon input"> <i class="lock icon"></i> <input name="vcode" placeholder="<?php echo $MSG_VCODE ?>" type="text" autocomplete=off > <img id="vcode-img" onclick="this.src='vcode.php?'+Math.random()" height="30px"> </div> </div> <?php }?> <button name="submit" type="submit" class="ui fluid large submit button" ><?php echo $MSG_LOGIN ?></button> 1,1 Top </div> <?php }?> <button name="submit" type="submit" class="ui fluid large submit button" ><?php echo $MSG_LOGIN ?></button> </div> <div class="ui error message"></div> </form> <div class="ui message"> <?php if ($OJ_REGISTER){ ?> <a href="registerpage.php"><?php echo $MSG_REGISTER ?></a> &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; <?php } ?> </div> </div> </div> </div> <script src="<?php echo $OJ_CDN_URL?>include/md5-min.js"></script> <script> function jsMd5(){ if($("input[name=password]").val()=="") return false; $("input[name=password]").val(hex_md5($("input[name=password]").val())); return true; } </script> <?php if ($OJ_VCODE) { ?> <script> $(document).ready(function () { $("#vcode-img").attr("src", "vcode.php?" + Math.random()); }) </script> <?php } ?> <?php include("template/$OJ_TEMPLATE/footer.php");?>
03-27
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值