PHP生成图片验证码(simple)
php新手,写了一个web登录界面,除了用户名,密码,感觉有个验证码会比较cool一点,便根据参考书的简单介绍,写了一个image.php来生成简单的图片验证码,颇有感慨,分享一下。
1. 图片验证码生成步骤:
(1)产生随机字符串(假设只需6位),使用session进行保存,以便验证;
<?php
$string = "abcdefghijklmnopqrstuvwxyz0123456789";
$str = "";
for($i=;$i<;$i++){
$pos = rand(,);
$str .= $string{$pos};
}
session_start();
$_SESSION['img_number'] = $str;
(2)创建一张简单的图片(80X20),设置背景色,文本色,再加一些干扰线,干扰素;
$img_handle = Imagecreate(, ); //图片大小80X20
$back_color = ImageColorAllocate($img_handle, , , ); //背景颜色(白色)
$txt_color = ImageColorAllocate($img_handle, ,, ); //文本颜色(黑色) //加入干扰线
for($i=;$i<;$i++)
{
$line = ImageColorAllocate($img_handle,rand(,),rand(,),rand(,));
Imageline($img_handle, rand(,), rand(,), rand(,),rand(,), $line);
}
//加入干扰象素
for($i=;$i<;$i++)
{
$randcolor = ImageColorallocate($img_handle,rand(,),rand(,),rand(,));
Imagesetpixel($img_handle, rand()% , rand()% , $randcolor);
}
(3)填充图片背景色,再将产生的随机字符串填充图片;
Imagefill($img_handle, , , $back_color); //填充图片背景色
ImageString($img_handle, , , , $str, $txt_color);//水平填充一行字符串
(4)清空输出缓存区,再生成验证码图片,并显示图片。
ob_clean(); // ob_clean()清空输出缓存区
header("Content-type: image/png"); //生成验证码图片
Imagepng($img_handle);//显示图片
?>
2. 图片验证码的引用
在form表单中添加验证码图片,src=“image.php” 就是根据上面步骤用于产生验证码图片的php,为了增加效果,添加了js刷新验证码的功能,可以参考。
<form id="form1" name="form1" method="post" action="post.php">
<input type="text" name="code" />
<img src="data:image.php" id = "refresh" title="刷新验证码" align="absmiddle" onclick="document.getElementById('refresh').src='image.php' ">
<font color="#ffffff">点击图片刷新</font>
<input type="submit" value="登录"/>
</form>
3. 验证码的验证
在post.php中使用第一步保存字符串的session与用户输入的验证码进行匹配。
<?php
session_start();
if($_POST['code'] == $_SESSION['img_number']){
echo "验证码正确";
}else{
echo "验证码错误";
}
?>
4. 效果展示:
生成的验证码图片: 
在登录框中的效果:

4. 遗留问题探讨
(1)生成验证码图片,并显示图片前,为何要使用ob_clean()清空输出缓存区 ??
鉴于本人对于PHP不太熟悉,可参考 :http://www.php.net/manual/zh/function.ob-clean.php
(2)填充进图片的字体有没有办法设置大小??
ImageString这个函数使用的是内置字体,只能换成imagettftext()函数。可参考:http://us3.php.net/manual/zh/function.imagettftext.php
欢迎讨论,请轻喷~
PHP生成图片验证码(simple)的更多相关文章
- PHP生成图片验证码demo【OOP面向对象版本】
下面是我今天下午用PHP写的一个生成图片验证码demo,仅供参考. 这个demo总共分为4个文件,具体代码如下: 1.code.html中的代码: <!doctype html> < ...
- python 全栈开发,Day85(Git补充,随机生成图片验证码)
昨日内容回顾 第一部分:django相关 1.django请求生命周期 1. 当用户在浏览器中输入url时,浏览器会生成请求头和请求体发给服务端 请求头和请求体中会包含浏览器的动作(action),这 ...
- net生成图片验证码--转自Lisliefor
目前,机器识别验证码已经相当强大了,比较常见的避免被机器识别的方法,就是将验证码的字符串连到一起,这样就加大的识别的难度,毕竟机器没有人工智能.我找了很多的.net生成图片验证码的例子,后来经过一些修 ...
- python PIL图像处理-生成图片验证码
生成效果如图: 代码 from PIL import Image,ImageDraw,ImageFont,ImageFilter import random # 打开一个jpg图像文件: im = I ...
- 在.net core web项目中生成图片验证码
第1步:添加SkiaSharp包引用 Install-Package SkiaSharp 第2步:编写生成图片验证码的代码 using SkiaSharp; //在类文件头部添加引用 public I ...
- 【转载】Asp.Net生成图片验证码工具类
在Asp.Net应用程序中,很多时候登陆页面以及其他安全重要操作的页面需要输入验证码,本文提供一个生成验证码图片的工具类,该工具类通过随机数生成验证码文本后,再通过C#中的图片处理类位图类,字体类,一 ...
- js依赖mui.css生成图片验证码
js依赖mui.css生成图片验证码 相关css和js引入路径 https://cdnjs.cloudflare.com/ajax/libs/mui/3.7.1/css/mui.css https:/ ...
- (七)利用servlet生成图片验证码
总结: 验证码就是一张图,然后往这张图上写入随机的字符(数字字母等). 1.1 编写html页面 <!DOCTYPE html> <html> <head> < ...
- PIL实现图片框架以及生成图片验证码
1. PIL的基本概念 PIL:即Python Imaging Library,是Python平台事实上的图像处理标准库. PIL中涉及通道(bands)和模式(mode)这两个重要概念. (1)通道 ...
随机推荐
- js正则表达式和replace
javascript中replace与正则表达式 replace()最简单的算是能力就是简单的字符替换.示例代码如下: <script language="javascript&quo ...
- libpcap文件格式分析
第一部分:PCAP包文件格式 一 基本格式: 文件头 数据包头数据报数据包头数据报...... 二.文件头: 文件头结构体 sturct pcap_file_header { DWOR ...
- ASP.NET MVC 4使用Bundle的打包压缩JS/CSS
打包(Bundling)及压缩(Minification)指的是将多个js文件或css文件打包成单一文件并压缩的做法,如此可减少浏览器需下载多个文件案才能完成网页显示的延迟感,同时通过移除JS/CSS ...
- ASP.NET MVC 基于角色的权限控制系统的示例教程
上一次在 .NET MVC 用户权限管理示例教程中讲解了ASP.NET MVC 通过AuthorizeAttribute类的OnAuthorization方法讲解了粗粒度控制权限的方法,接下来讲解基于 ...
- TOP 10开源的推荐系统简介
最近这两年推荐系统特别火,本文搜集整理了一些比较好的开源推荐系统,即有轻量级的适用于做研究的SVDFeature.LibMF.LibFM等,也有重量级的适用于工业系统的 Mahout.Oryx.Eas ...
- subline快捷键
折叠所有代码: 按ctrl+k,再按ctrl+1 展开所有代码: 按ctrl+k,再按ctrl+j 折叠此处代码: ctrl+shift+[ 展开此处代码: ctrl+shift+]
- SQL with PL/SQL
DDL commands --> create user / table / view / sequence alter DML --> data manipulation languag ...
- grub2的使用
1,添加win 启动项 edit file: /boot/grub2/grub.cfg 插入这几行: menuentry 'Windows XXX' { set root=(hd0,) chainlo ...
- Xlistview的values下的界面
<!-- 下拉刷新,上拉加载更多 --> <string name="xlistview_header_hint_normal">下拉刷新</s ...
- LOGISTIC REGRESSION
In logistic regression we learn a family of functions