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)的更多相关文章

  1. PHP生成图片验证码demo【OOP面向对象版本】

    下面是我今天下午用PHP写的一个生成图片验证码demo,仅供参考. 这个demo总共分为4个文件,具体代码如下: 1.code.html中的代码: <!doctype html> < ...

  2. python 全栈开发,Day85(Git补充,随机生成图片验证码)

    昨日内容回顾 第一部分:django相关 1.django请求生命周期 1. 当用户在浏览器中输入url时,浏览器会生成请求头和请求体发给服务端 请求头和请求体中会包含浏览器的动作(action),这 ...

  3. net生成图片验证码--转自Lisliefor

    目前,机器识别验证码已经相当强大了,比较常见的避免被机器识别的方法,就是将验证码的字符串连到一起,这样就加大的识别的难度,毕竟机器没有人工智能.我找了很多的.net生成图片验证码的例子,后来经过一些修 ...

  4. python PIL图像处理-生成图片验证码

    生成效果如图: 代码 from PIL import Image,ImageDraw,ImageFont,ImageFilter import random # 打开一个jpg图像文件: im = I ...

  5. 在.net core web项目中生成图片验证码

    第1步:添加SkiaSharp包引用 Install-Package SkiaSharp 第2步:编写生成图片验证码的代码 using SkiaSharp; //在类文件头部添加引用 public I ...

  6. 【转载】Asp.Net生成图片验证码工具类

    在Asp.Net应用程序中,很多时候登陆页面以及其他安全重要操作的页面需要输入验证码,本文提供一个生成验证码图片的工具类,该工具类通过随机数生成验证码文本后,再通过C#中的图片处理类位图类,字体类,一 ...

  7. js依赖mui.css生成图片验证码

    js依赖mui.css生成图片验证码 相关css和js引入路径 https://cdnjs.cloudflare.com/ajax/libs/mui/3.7.1/css/mui.css https:/ ...

  8. (七)利用servlet生成图片验证码

    总结: 验证码就是一张图,然后往这张图上写入随机的字符(数字字母等). 1.1 编写html页面 <!DOCTYPE html> <html> <head> < ...

  9. PIL实现图片框架以及生成图片验证码

    1. PIL的基本概念 PIL:即Python Imaging Library,是Python平台事实上的图像处理标准库. PIL中涉及通道(bands)和模式(mode)这两个重要概念. (1)通道 ...

随机推荐

  1. discuz 同步登录问题

    最近一直在搞discuz论坛的二次开发,发现在论坛登录或退出的时候应用却没有同步登录或同步退出,这下子麻烦了,后来查看,原来没有产生js的同步代码,查找原因,发现$_G['setting']['all ...

  2. mysql启动报错

    查看报错日志: 131023 15:02:59 [ERROR] Can't start server: Bind on TCP/IP port: No such file or directory13 ...

  3. S1:对象与JSON

    JSON全称为JavaScript对象表示法(JavaScript Object Notation). JSON是JavaScript中对象的字面量,是对象的表示方法,通过使用JSON,可以减少中间变 ...

  4. Div层的展开与收缩的代码

    <html> <head> <title>div展开收缩代码</title> <style> * { margin:0; padding:0 ...

  5. POJ 1202 Family 概率,DP,高精 难度:2

    http://poj.org/problem?id=1202 难度集中在输出格式上,因为输出格式所以是高精度 递推式: 血缘肯定只有从双亲传到儿子的,所以,设f,m为双亲,son为儿子,p[i][j] ...

  6. hdu 4610 Cards

    http://acm.hdu.edu.cn/showproblem.php?pid=4610 先求出每个数的得分情况,分数和得分状态,(1<<4)种状态 按分数从大到小排序 然后每种状态取 ...

  7. 文件浏览器及数码相框 -2.3.2-freetype_arm-1

    交叉编译:tar xjf freetype-2.4.10.tar.bz2 ./configure --host=arm-linuxmakemake DESTDIR=$PWD/tmp install f ...

  8. iis7.5 设置伪静态

    1)首先新建一个应用程序池,名称任意,比如:nettest,托管管道模式先暂时设置为集成模式,等下面的一系列设置完成之后再设置成经典模式: 2)部署好站点,并将此站点的应用程序池设置为nettest; ...

  9. shell变量的使用

    转载请标明http://www.cnblogs.com/winifred-tang94/ shell环境中变量有三种类型: a.  环境变量:可以在shell脚本中直接利用“$环境变量名称”的形式引用 ...

  10. Android获取手机设备识别码(IMEI)和手机号码

    最近看了下获取手机设备ID和手机信息以及SIM的信息例子,主要还是借鉴别人的,现在自己写一下,算是巩固加深了,也希望能给大家一个参考 必要的条件还是一部真机,SIM卡或者UIM卡. 首先,在Andro ...