常用的防止恶意注册就是利用验证码来实现了,在用户提交注册信息时我随机生成一个图形验证码,这样只有人能识别了,当然简单的验证码机器是机以识别的,所以复杂点的好。
今天我们来研究下PHP验证码,我们通过简单的数字验证码来实现,首先来写一个生成验证码的代码:
- <?php
- //随机生成一个4位数的数字验证码
- $num=”"; for($i=0;$i<4;$i++){ $num .= rand(0,9); }
- //4位验证码也可以用rand(1000,9999)直接生成
- //将生成的验证码写入session,备验证页面使用
- Session_start(); $_SESSION["Checknum"] = $num;
- //创建图片,定义颜色值 Header(“Content-type: image/PNG”);
- srand((double)microtime()*1000000);
- $im = imagecreate(60,20);
- $black = ImageColorAllocate($im, 0,0,0);
- $gray = ImageColorAllocate($im, 200,200,200);
- imagefill($im,0,0,$gray);
- //随机绘制两条虚线,起干扰作用
- $style = array($black, $black, $black, $black, $black, $gray, $gray, $gray, $gray, $gray);
- imagesetstyle($im, $style);
- $y1=rand(0,20); $y2=rand(0,20); $y3=rand(0,20); $y4=rand(0,20);
- imageline($im, 0, $y1, 60, $y3, IMG_COLOR_STYLED);
- imageline($im, 0, $y2, 60, $y4, IMG_COLOR_STYLED)
- //在画布上随机生成大量黑点,起干扰作用;
- for($i=0;$i<80;$i++) {
- imagesetpixel($im, rand(0,60), rand(0,20), $black); }
- //将四个数字随机显示在画布上,字符的水平间距和位置都按一定波动范围随机生成
- $strx=rand(3,8);
- for($i=0;$i<4;$i++){
- $strpos=rand(1,6); imagestring($im,5,$strx,$strpos, substr($num,$i,1), $black); $strx+=rand(8,12);
- }
- ImagePNG($im); ImageDestroy($im);
- ?>
在reg.php页面我们写一个表单:(此处省去了其他的HTML代码),代码如下:
- <tr>
- <td>验证码 :</td>
- <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>
- </tr>
- <tr> <td colspan=’2′><input type=”submit” value=”注册”/></td>
- <td>验证码 :</td>
- </tr>
因为我们是用post提交的,所以我们用$_POST来获取(在接受页面做验证码的验证:post.php页面)代码如下:
- Session_start();
- //back_alert()验证码输入错误的时候,弹出错误信息
- function back_alert($yzm){
- echo “<script type=’text/javascript’>alert(‘$yzm’);history.back();</script>”;
- }
- //禁止恶意调用(禁止直接在浏览器打开post.php页面)
- if($_POST["yzm"]==null){
- back_alert(‘你都木有输入验证码,有木有???’); }
- // 禁止恶意注册
- if(!($_POST["yzm"]==$_SESSION["Checknum"])){
- back_alert(‘验证码不正确’);
- } echo $_POST["yzm"];
波比源码 – 精品源码模版分享 | www.bobi11.com
1. 本站所有资源来源于用户上传和网络,如有侵权请邮件联系站长!
2. 分享目的仅供大家学习和交流,您必须在下载后24小时内删除!
3. 不得使用于非法商业用途,不得违反国家法律。否则后果自负!
4. 本站提供的源码、模板、插件等等其他资源,都不包含技术服务请大家谅解!
5. 如有链接无法下载、失效或广告,请联系管理员处理!
6. 本站资源售价只是赞助,收取费用仅维持本站的日常运营所需!
7. 本站源码并不保证全部能正常使用,仅供有技术基础的人学习研究,请谨慎下载
8. 如遇到加密压缩包,请使用WINRAR解压,如遇到无法解压的请联系管理员!
波比源码 » php利用验证码防止恶意注册学习笔记
波比源码 » php利用验证码防止恶意注册学习笔记
Thank you for great content. Hello Administ. Onwin , Onwin Giriş , Onwin Güncel Giriş , Onwin Yeni Adres , onwin
Thank you for great article. Hello Administ . Metropol Halı Karaca Halı Öztekin ve Selçuklu Halı Cami Halısı ve Cami Halıları Türkiye’nin En Büyük Cami Halısı Fabrikasıyız…