PHP生成加减算法方式的验证码实例

这是在网上找的一个demo,我加入了一部分代码。可以使用。

这里需要说明一下,我们调用这个验证码类应该在一个单独的控制器方法中使用。

生成的图片的算法是用代码生成的,然后把计算值存入session中。

验证的时候是获取用户的输入值,然后取出服务端的值进行对比

<?php
namespace mobile\components;
/**
 * @author fenghuo
 *
 * 改造的加减法验证类
 * 使用示例 VerifyCode::get(1,2);
 * 验证示例 VerifyCode::check($code);
 */
class VerifyCode
{
  /**
   * php验证码
   */
  public static function get($one,$two,$prefix = '', $font_size = 28)
  {
    //文件头...
    ob_get_clean();
    header("Content-type: image/png;charset=utf-8;");
    //创建真彩色白纸
    $width      = $font_size*5;
    $height      = $font_size+1;
    $im        = @imagecreatetruecolor($width, $height) or die("建立图像失败");
    //获取背景颜色
    $background_color = imagecolorallocate($im, 255, 255, 255);
    //填充背景颜色
    imagefill($im, 0, 0, $background_color);
    //获取边框颜色
    $border_color   = imagecolorallocate($im, 200, 200, 200);
    //画矩形,边框颜色200,200,200
    imagerectangle($im,0,0,$width - 1, $height - 1,$border_color);
    //逐行炫耀背景,全屏用1或0
    for($i = 2;$i < $height - 2;$i++) {
      //获取随机淡色
      $line_color = imagecolorallocate($im, rand(200,255), rand(200,255), rand(200,255));
      //画线
      imageline($im, 2, $i, $width - 1, $i, $line_color);
    }
    //设置印上去的文字
    $firstNum = $one;
    $secondNum = $two;
    $actionStr = $firstNum > $secondNum ? '-' : '+';
    //获取第1个随机文字
    $imstr[0]["s"] = $firstNum;
    $imstr[0]["x"] = rand(2, 5);
    $imstr[0]["y"] = rand(1, 4);
    //获取第2个随机文字
    $imstr[1]["s"] = $actionStr;
    $imstr[1]["x"] = $imstr[0]["x"] + $font_size - 1 + rand(0, 1);
    $imstr[1]["y"] = rand(1,5);
    //获取第3个随机文字
    $imstr[2]["s"] = $secondNum;
    $imstr[2]["x"] = $imstr[1]["x"] + $font_size - 1 + rand(0, 1);
    $imstr[2]["y"] = rand(1, 5);
    //获取第3个随机文字
    $imstr[3]["s"] = '=';
    $imstr[3]["x"] = $imstr[2]["x"] + $font_size - 1 + rand(0, 1);
    $imstr[3]["y"] = 3;
    //获取第3个随机文字
    $imstr[4]["s"] = '?';
    $imstr[4]["x"] = $imstr[3]["x"] + $font_size - 1 + rand(0, 1);
    $imstr[4]["y"] = 3;
    //文字
    $text = '';
    //写入随机字串
    for($i = 0; $i < 5; $i++) {
      //获取随机较深颜色
      $text_color = imagecolorallocate($im, rand(50, 180), rand(50, 180), rand(50, 180));
      $text .= $imstr[$i]["s"];
      //画文字
      imagechar($im, $font_size, $imstr[$i]["x"], $imstr[$i]["y"], $imstr[$i]["s"], $text_color);
    }
    session_start();
    $_SESSION[$prefix.'verifycode'] = $firstNum > $secondNum ? ($firstNum - $secondNum) : ($firstNum + $secondNum);
    //显示图片
    ImagePng($im);
    //销毁图片
    ImageDestroy($im);
  }
  public static function check($code)
  {
    if(trim($_SESSION[$prefix.'verifycode']) == trim($code)) {
      return true;
    } else {
      return false;
    }
  }
} 

以上这篇PHP生成加减算法方式的验证码实例就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持我们。

您可能感兴趣的文章:

  • php实现加减法验证码代码
  • php 生成唯一id的几种解决方法
(0)

相关推荐

  • php实现加减法验证码代码

    复制代码 代码如下: <?php/*图片验证码文件,加减计算方式*/ class ImageCode{ private $Jiashu  = 0;        //加数或者减数 private $JianShu = 0;        //被加数或者被减数 private $YunSuan = '';       //运算符 private $DeShu   = 0;        //得数 private $String  = '';       //字符串样式 private $Img; 

  • php 生成唯一id的几种解决方法

    网上查了下,有很多的方法 1.md5(time() . mt_rand(1,1000000)); 这种方法有一定的概率会出现重复 2.php内置函数uniqid() uniqid() 函数基于以微秒计的当前时间,生成一个唯一的 ID. w3school参考手册有一句话:"由于基于系统时间,通过该函数生成的 ID 不是最佳的.如需生成绝对唯一的 ID,请使用 md5() 函数". 下面方法返回结果类似:5DDB650F-4389-F4A9-A100-501EF1348872 functi

  • PHP生成加减算法方式的验证码实例

    这是在网上找的一个demo,我加入了一部分代码.可以使用. 这里需要说明一下,我们调用这个验证码类应该在一个单独的控制器方法中使用. 生成的图片的算法是用代码生成的,然后把计算值存入session中. 验证的时候是获取用户的输入值,然后取出服务端的值进行对比 <?php namespace mobile\components; /** * @author fenghuo * * 改造的加减法验证类 * 使用示例 VerifyCode::get(1,2); * 验证示例 VerifyCode::c

  • PHP实现RSA加解密算法示例(生成密钥位数为1024位的方法)

    大家可以先到http://web.chacuo.net/netrsakeypair这个网站,在线生成公钥和私钥 RSA非对称加密算法,如果是公钥加密,就得用私钥解密,反过来也一样,私钥加密的就用公钥解密,以下是相关实现函数 /** * RSA私钥加密 * @param string $private_key 私钥 * @param string $data 要加密的字符串 * @return string $encrypted 返回加密后的字符串 * @author mosishu */ fun

  • 详细分析JAVA加解密算法

    加解密算法分析 日常开发中,无论你是使用什么语言,都应该遇到过使用加解密的使用场景,比如接口数据需要加密传给前端保证数据传输的安全:HTTPS使用证书的方式首先进行非对称加密,将客户端的私匙传递给服务端,然后双方后面的通信都使用该私匙进行对称加密传输:使用MD5进行文件一致性校验,等等很多的场景都使用到了加解密技术. 很多时候我们对于什么时候要使用什么样的加解密方式是很懵的.因为可用的加解密方案实在是太多,大家对加解密技术的类型可能不是很清楚,今天这篇文章就来梳理一下目前主流的加解密技术,本篇文

  • C语言实现大整数加减运算详解

    前言 我们知道,在数学中,数值的大小是没有上限的,但是在计算机中,由于字长的限制,计算机所能表示的范围是有限的,当我们对比较小的数进行运算时,如:1234+5678,这样的数值并没有超出计算机的表示范围,所以可以运算.但是当我们在实际的应用中进行大量的数据处理时,会发现参与运算的数往往超过计算机的基本数据类型的表示范围,比如说,在天文学上,如果一个星球距离我们为100万光年,那么我们将其化简为公里,或者是米的时候,我们会发现这是一个很大的数.这样计算机将无法对其进行直接计算. 可能我们认为实际应

  • 数据库 日期加减处理

    在实际的处理中,还有一种比较另类的日期加减处理,就是在指定的日期中,加上(或者减去)多个日期部分,比如将2005年3月11日,加上1年3个月11天2小时.对于这种日期的加减处理,DATEADD函数的力量就显得有点不够. 要实现多个日期部分的加减处理,最主要的就是把要加减的日期字符分解,然后根据分解的结果在指定日期的对应日期部分加上相应的值,其难点在于如何分解日期字符,以及判断分解后的日期字符属于哪个日期部分.要顺利地分解出日期字符的话,首先要规定日期加减的日期字符的格式,可以这样定义: y-m-

  • Java对日期Date类进行加减运算、年份加减月份加减、时间差等等

    实现代码一: import java.text.SimpleDateFormat; import java.util.Calendar; import java.util.Date; public class DateTestUtil { public static void main(String[] args) throws Exception { SimpleDateFormat sdf=new SimpleDateFormat("yyyyMMdd"); String str=&

  • Java实现DES加解密算法解析

    本文实例讲述了Java实现DES加解密算法解析.分享给大家供大家参考,具体如下: 简介: 数据加密算法(Data Encryption Algorithm,DEA)是一种对称加密算法,很可能是使用最广泛的密钥系统,特别是在保护金融数据的安全中,最初开发的DEA是嵌入硬件中的.通常,自动取款机(Automated Teller Machine,ATM)都使用DEA.它出自IBM的研究工作,IBM也曾对它拥有几年的专利权,但是在1983年已到期后,处于公有范围中,允许在特定条件下可以免除专利使用费而

  • vue中子组件向父组件传递数据的实例代码(实现加减功能)

    这里讲解一下子组件向父组件传递值的常用方式. 这里通过一个加减法的实例向大家说明一下,这个的原理. 如下图所示: 当没有任何操作的时候父组件的值是 0 当点击加号以后父组件的值是 1 当点击减号以后父组件的值是减一变成 0 具体代码我直接贴出来,刚出炉的代码. <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta name=&qu

  • Vue入门之数量加减运算操作示例

    本文实例讲述了Vue入门之数量加减运算操作.分享给大家供大家参考,具体如下: 效果图: HTML: <div class="count3"> <ul> <li v-for="(key,idx) in liList" :key="key.id"> {{key.id}},{{idx}} <template> <button class="cut" @click="cu

  • java 随机生成6位短信验证码实例代码

    生成6位随机数字其实很简单,只需一行代码,具体如下: String verifyCode = String.valueOf(new Random().nextInt(899999) + 100000); 具体实现发送短信验证码功能,以注册为例,其实现代码如下: 这里需要用到第三方短信验证码接口,这里用到的是乐信短信验证码接口,乐信接口API文档说明(http://www.lx598.com/apitext.html),乐信java调用短信验证码接口 demo(http://www.lx598.c

随机推荐