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. ubuntu 软件安装的几种方法

    说明:由于图形化界面方法(如Add/Remove... 和Synaptic Package Manageer)比较简单,所以这里主要总结在终端通过命令行方式进行的软件包安装.卸载和删除的方法. 一.U ...

  2. Masonry使用案列详解

    案例一: 要求:无论在什么尺寸的设备上(包括横竖屏切换),红色view都居中显示.

  3. UDPsocket编程

    socket编程UDP模式, package com.wtd.socket.udp; import java.io.IOException; import java.net.DatagramPacke ...

  4. nginx日志切割

    脚本完成后将其存入 Nginx 安装目录的 sbin 中,取名为 cut-log.sh,之后使用 crontab -e 新增一个定时任务,在其中增加执行这个脚本: #!/bin/bash ## 零点执 ...

  5. bzoj 2301 莫比乌斯反演

    对于给出的n个询问,每次求有多少个数对(x,y),满足a≤x≤b,c≤y≤d,且gcd(x,y) = k,gcd(x,y)函数为x和y的最大公约数. 这里题目意思很明显 对于要求的f[n] = sig ...

  6. mysql一次添加多条记录

    inisert into tabale (name,pwd) values ("jom","123"),("tom","123&q ...

  7. Linux内核-链表

    linux内核链表的定义(定义了双向链表,不含数据域) 定义在 /linux-source-3.13.0/include/linux/types.h 头文件中. struct list_head { ...

  8. 2016 - 1 -19 初学HTML5 第一天

    1.HTML COMMANDS MHTL commands called elements.Usually, an element has a start tag and an end tag e.g ...

  9. 《View Programming Guide for iOS》之frame、bounds和center之间的关系

    The frame property contains the frame rectangle, which specifies the size and location of the view i ...

  10. Storyboard的使用以及使用多个Storyboard的方法

    一, storyboard用起来很是方便.在开发中很有可能是多个人创建了多个storyboard.但最后,总是要把所有的storyboard“合并”在一起.总结一下自己的想法,不知道有没有其他的方式“ ...