无为清净楼资源网 Design By www.qnjia.com

适用于自定义的验证码类!

<"329832983DSDSKDSLKQWEWQ2lkfDSFSDjfdsfdsjwlkfj93290KFDSKJFDSOIDSLK";
  public $bg_color = '#DCDCDC';
  public $font_size = 16;
  public $font = 'font.ttf';
  public $font_color = '#000000';
   
  //创建验证码饿字符创
  public function create_code(){
    $code = '';
    for( $i=0;$i<$this->code_len;$i++ ){
      $code .= $this->code_str[mt_rand(0, strlen($this->code_str)-1)];
  }
    return $this->code = $code;
  }
   
  //输出图像
  public function getImage(){
    $w = $this->width;
    $h = $this->height;
    $bg_color = $this->bg_color;
    $img = imagecreatetruecolor($w, $h);
    $bg_color = imagecolorallocate($img, 
  hexdec(substr($bg_color, 1,2)), hexdec(substr($bg_color, 3,2)), hexdec(substr($bg_color, 5,2)));
  imagefill($img, 0, 0, $bg_color);
    $this->img = $img;
    $this->create_font();
    $this->create_pix();
  $this->show_code();
  }
 
 
  //写入验证码
  public function create_font(){
    $this->create_code();
    $color = $this->font_color;
    $font_color = imagecolorallocate($this->img, hexdec(substr($color,1,2)), hexdec(substr($color, 3,2)), hexdec(substr($color,5,2)));
    $x = $this->width/$this->code_len;
    for( $i=0;$i<$this->code_len;$i++ ){
      $txt_color = imagecolorallocate($this->img, mt_rand(0,100), mt_rand(0, 150), mt_rand(0, 200));
      imagettftext($this->img, $this->font_size, mt_rand(-30, 30), $x*$i+mt_rand(3, 6), mt_rand($this->height/1.2, $this->height), $txt_color, $this->font , $this->code[$i]); 
      //imagestring($this->img, $this->font_size, $x*$i+mt_rand(3, 6),mt_rand(0, $this->height/4) , $this->code[$i], $font_color);
    }
    $this->font_color = $font_color;
  }
   
  //画干扰线
  public function create_pix(){
    $pix_color= $this->font_color;
    for($i=0;$i<100;$i++){
      imagesetpixel($this->img, mt_rand(0, $this->width),mt_rand(0, $this->height), $pix_color);
    }
    for($j=0;$j<4;$j++){
      imagesetthickness($this->img, mt_rand(1, 2));
      imageline($this->img, mt_rand(0, $this->width), mt_rand(0, $this->height), mt_rand(0, $this->width), mt_rand(0, $this->height), $pix_color);
    }
  }
   
  //得到验证码
  public function getCode(){
    return strtoupper($this->code);
  }
 
 
  //输出验证码
  private function show_code(){
    header("Content-type:image/png");
    imagepng($this->img);
    imagedestroy($this->img);
  }
}

我们再来看一例代码:

生成图片类型验证码,验证码包含数字和大写字母,session中存放md5加密后的验证码

<"Don't support image type!");
		}
		//将验证码信息保存到session中,md5加密
		if(!isset($_SESSION)){
  		session_start();
		} 
		$_SESSION[$this->sessionKey] = md5($this->captcha);
		
    imagedestroy($this->image); 
	}
	
	function __destruct() {
		unset($this->width, $this->height, $this->codeNum,$this->captcha);
	}
}

例三:

<""){
  //第一步:创建图像背景
  $this->createImage();
  //第二步:设置干扰元素
  $this->setDisturbColor();
  //第三步:向图像中随机画出文本
  $this->outputText($fontFace);
  //第四步:输出图像
  $this->outputImage();
 }
 
 //通过调用该方法获取随机创建的验证码字符串
 function getCheckCode(){
  return $this->checkCode;
 }
 private function createImage(){
  //创建图像资源
  $this->image=imagecreatetruecolor($this->width, $this->height);
  //随机背景色
  $backColor=imagecolorallocate($this->image, rand(225, 255), rand(225,255), rand(225, 255));
  //为背景添充颜色
  imagefill($this->image, 0, 0, $backColor);
  //设置边框颜色
  $border=imagecolorallocate($this->image, 0, 0, 0);
  //画出矩形边框
  imagerectangle($this->image, 0, 0, $this->width-1, $this->height-1, $border);
 }
 private function setDisturbColor(){
  for($i=0; $i<$this->disturbColorNum; $i++){
  $color=imagecolorallocate($this->image, rand(0, 255), rand(0, 255), rand(0, 255));
  imagesetpixel($this->image, rand(1, $this->width-2), rand(1, $this->height-2), $color);
  }
  for($i=0; $i<10; $i++){
  $color=imagecolorallocate($this->image, rand(200, 255), rand(200, 255), rand(200, 255));
  imagearc($this->image, rand(-10, $this->width), rand(-10, $this->height), rand(30, 300), rand(20, 200), 55, 44, $color);
  }
 }
 private function createCheckCode(){

//这里主要产生随机码,从2开始是为了区分1和l
  $code="23456789abcdefghijkmnpqrstuvwxyzABCDEFGHIJKMNPQRSTUVWXYZ";
  $string='';
  for($i=0; $i < $this->codeNum; $i++){
  $char=$code{rand(0, strlen($code)-1)};
  $string.=$char;
  }
  return $string;
 }
 private function outputText($fontFace=""){
  for($i=0; $i<$this->codeNum; $i++){
  $fontcolor=imagecolorallocate($this->image, rand(0, 128), rand(0, 128), rand(0, 128));
  if($fontFace==""){
   $fontsize=rand(3, 5);
   $x=floor($this->width/$this->codeNum)*$i+3;
   $y=rand(0, $this->height-15);
   imagechar($this->image,$fontsize, $x, $y, $this->checkCode{$i},$fontcolor);
  }else{
   $fontsize=rand(12, 16);
   $x=floor(($this->width-8)/$this->codeNum)*$i+8;
   $y=rand($fontSize+5, $this->height);
   imagettftext($this->image,$fontsize,rand(-30, 30),$x,$y ,$fontcolor, $fontFace, $this->checkCode{$i});
  }
  }
 }
 private function outputImage() {
  if(imagetypes() & IMG_GIF){
  header("Content-Type:image/gif");
  imagepng($this->image);
  }else if(imagetypes() & IMG_JPG){
  header("Content-Type:image/jpeg");
  imagepng($this->image);
  }else if(imagetypes() & IMG_PNG){
  header("Content-Type:image/png");
  imagepng($this->image);
  }else if(imagetypes() & IMG_WBMP){
  header("Content-Type:image/vnd.wap.wbmp");
  imagepng($this->image);
  }else{
  die("PHP不支持图像创建");
  }
 }
 function __destruct(){
  imagedestroy($this->image);
 }
 }
 

使用如下:

测试,调用验证码类
code.php

<"validationcode.class.php";
$code=new ValidationCode(80, 20, 4);
$code->showImage();  //输出到页面中供 注册或登录使用
$_SESSION["code"]=$code->getCheckCode(); //将验证码保存到服务器中

标签:
PHP图片验证码类,php,图片验证码,php生成验证码图片

无为清净楼资源网 Design By www.qnjia.com
广告合作:本站广告合作请联系QQ:858582 申请时备注:广告合作(否则不回)
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
无为清净楼资源网 Design By www.qnjia.com

稳了!魔兽国服回归的3条重磅消息!官宣时间再确认!

昨天有一位朋友在大神群里分享,自己亚服账号被封号之后居然弹出了国服的封号信息对话框。

这里面让他访问的是一个国服的战网网址,com.cn和后面的zh都非常明白地表明这就是国服战网。

而他在复制这个网址并且进行登录之后,确实是网易的网址,也就是我们熟悉的停服之后国服发布的暴雪游戏产品运营到期开放退款的说明。这是一件比较奇怪的事情,因为以前都没有出现这样的情况,现在突然提示跳转到国服战网的网址,是不是说明了简体中文客户端已经开始进行更新了呢?