php利用验证码防止恶意注册学习笔记

常用的防止恶意注册就是利用验证码来实现了,在用户提交注册信息时我随机生成一个图形验证码,这样只有人能识别了,当然简单的验证码机器是机以识别的,所以复杂点的好。

今天我们来研究下PHP验证码,我们通过简单的数字验证码来实现,首先来写一个生成验证码的代码

  1. <?PHP 
  2. //随机生成一个4位数的数字验证 
  3. $num=”;     for($i=0;$i<4;$i++){     $num .= rand(0,9);     } 
  4. //4位验证码也可以用rand(1000,9999)直接生成 
  5. //将生成的验证码写入session,备验证页面使用 
  6. Session_start();     $_SESSION[Checknum] = $num
  7. //创建图片,定义颜色值     Header(“Content-type: image/PNG”); 
  8. srand((double)microtime()*1000000); 
  9. $im = imagecreate(60,20); 
  10. $black = ImageColorAllocate($im, 0,0); 
  11. $gray = ImageColorAllocate($im, 200,200,200); 
  12. imagefill($im,$gray); 
  13. //随机绘制两条虚线,起干扰作用 
  14. $style = array($black$black$gray$gray); 
  15. imagesetstyle($im$style); 
  16. $y1=rand(0,20);     $y2=rand(0,20);     $y3=rand(0,20);     $y4=rand(0,20); 
  17. imageline($im$y1, 60, $y3, IMG_COLOR_STYLED); 
  18. imageline($im$y2$y4, IMG_COLOR_STYLED) 
  19. //在画布上随机生成大量黑点,起干扰作用; 
  20. for($i=0;$i<80;$i++)     { 
  21. imagesetpixel($im, rand(0,60),20), $black);     } 
  22. //将四个数字随机显示在画布上,字符的水平间距和位置都按一定波动范围随机生成 
  23. $strx=rand(3,8); 
  24. for($i=0;$i<4;$i++){ 
  25. $strpos=rand(1,6);     imagestring($im,5,$strx,$strpossubstr($num,$i,1), $black);     $strx+=rand(8,12); 
  26. ImagePNG($im);     ImageDestroy($im); 
  27. ?> 

在reg.PHP页面我们写一个表单:(此处省去了其他的HTML代码),代码如下:

  1. <tr> 
  2. <td>验证码 :</td> 
  3. <td><input type=”text” name=”yzm”style=”width:60px;height:20px;” /><img src=”code.PHP” onclick=”javascript:this.src=’code.PHP?’+Math.random();”></img></td> 
  4. </tr> 
  5. <tr>    <td colspan=’2′><input type=”submit” value=”注册/></td> 
  6. <td>验证码 :</td> 
  7. </tr> 

因为我们是用post提交的,所以我们用$_POST来获取(在接受页面做验证码的验证:post.PHP页面代码如下:

  1. Session_start(); 
  2. //back_alert()验证码输入错误的时候,弹出错误信息 
  3. function back_alert($yzm){ 
  4. echo “<script type=’text/javascript’>alert(‘$yzm’);history.back();</script>”; 
  5. //禁止恶意调用禁止直接在浏览器打开post.PHP页面 
  6. if($_POST[yzm]==null){ 
  7. back_alert(‘你都木有输入验证码,有木有???’);  } 
  8. // 禁止恶意注册 
  9. if(!($_POST[yzm]==$_SESSION[Checknum])){ 
  10. back_alert(‘验证码不正确’); 
  11. echo $_POST[yzm]; 

相关文章

统一支付是JSAPI/NATIVE/APP各种支付场景下生成支付订单,返...
统一支付是JSAPI/NATIVE/APP各种支付场景下生成支付订单,返...
前言 之前做了微信登录,所以总结一下微信授权登录并获取用户...
FastAdmin是我第一个接触的后台管理系统框架。FastAdmin是一...
之前公司需要一个内部的通讯软件,就叫我做一个。通讯软件嘛...
统一支付是JSAPI/NATIVE/APP各种支付场景下生成支付订单,返...