这是一个通过php生成的动态验证码图片的示例,重点是可以运行哦!下面先发下效果图:

php生成动态验证码gif图片

下面是php生成动态验证码需要用到的相关类和函数。

<"GIF89a";       /* GIF header 6 bytes    */  
  var $VER="GIFEncoder V2.06";   /* Encoder version      */  
  var $BUF=Array(); 
  var $LOP=0; 
  var $DIS=2; 
  var $COL=-1; 
  var $IMG=-1; 
  var $ERR=Array( 
    'ERR00'=>"Does not supported function for only one image!", 
    'ERR01'=>"Source is not a GIF image!", 
    'ERR02'=>"Unintelligible flag ", 
    'ERR03'=>"Could not make animation from animated GIF source", 
  ); 
  function GIFEncoder($GIF_src,$GIF_dly=100,$GIF_lop=0,$GIF_dis=0, $GIF_red=0,$GIF_grn=0,$GIF_blu=0,$GIF_mod='bin'){ 
    if(!is_array($GIF_src)&&!is_array($GIF_tim)){ 
      printf("%s: %s",$this->VER,$this->ERR['ERR00']); 
      exit(0); 
    }  
    $this->LOP=($GIF_lop>-1)"url"){ 
        $this->BUF[]=fread(fopen($GIF_src [$i],"rb"),filesize($GIF_src [$i])); 
      }elseif(strToLower($GIF_mod)=="bin"){ 
        $this->BUF [ ]=$GIF_src [ $i ]; 
      }else{ 
        printf("%s: %s(%s)!",$this->VER,$this->ERR [ 'ERR02' ],$GIF_mod); 
        exit(0); 
      }  
      if(substr($this->BUF[$i],0,6)!="GIF87a"&&substr($this->BUF [$i],0,6)!="GIF89a"){ 
        printf("%s: %d %s",$this->VER,$i,$this->ERR ['ERR01']); 
        exit(0); 
      }  
      for($j=(13+3*(2<<(ord($this->BUF[$i]{10})&0x07))),$k=TRUE;$k;$j++){ 
        switch($this->BUF [$i]{$j}){ 
          case "!":  
            if((substr($this->BUF[$i],($j+3),8))=="NETSCAPE"){ 
                printf("%s: %s(%s source)!",$this->VER,$this->ERR ['ERR03'],($i+1)); 
                exit(0); 
            }  
            break; 
          case ";":  
            $k=FALSE; 
          break; 
        }  
      }  
    }  
    GIFEncoder::GIFAddHeader(); 
    for($i=0,$count_buf=count($this->BUF);$i<$count_buf;$i++){ 
      GIFEncoder::GIFAddFrames($i,$GIF_dly[$i]); 
    }  
    GIFEncoder::GIFAddFooter(); 
  }  
  function GIFAddHeader(){ 
    $cmap=0; 
    if(ord($this->BUF[0]{10})&0x80){ 
      $cmap=3*(2<<(ord($this->BUF [0]{10})&0x07)); 
      $this->GIF.=substr($this->BUF [0],6,7); 
      $this->GIF.=substr($this->BUF [0],13,$cmap); 
      $this->GIF.="!\377\13NETSCAPE2.0\3\1".GIFEncoder::GIFWord($this->LOP)."\0"; 
    }  
  }  
  function GIFAddFrames($i,$d){ 
    $Locals_str=13+3*(2 <<(ord($this->BUF[$i]{10})&0x07)); 
    $Locals_end=strlen($this->BUF[$i])-$Locals_str-1; 
    $Locals_tmp=substr($this->BUF[$i],$Locals_str,$Locals_end); 
    $Global_len=2<<(ord($this->BUF [0]{10})&0x07); 
    $Locals_len=2<<(ord($this->BUF[$i]{10})&0x07); 
    $Global_rgb=substr($this->BUF[0],13,3*(2<<(ord($this->BUF[0]{10})&0x07))); 
    $Locals_rgb=substr($this->BUF[$i],13,3*(2<<(ord($this->BUF[$i]{10})&0x07))); 
    $Locals_ext="!\xF9\x04".chr(($this->DIS<<2)+0).chr(($d0)&0xFF).chr(($d8)&0xFF)."\x0\x0"; 
    if($this->COL>-1&&ord($this->BUF[$i]{10})&0x80){ 
      for($j=0;$j<(2<<(ord($this->BUF[$i]{10})&0x07));$j++){ 
        if(ord($Locals_rgb{3*$j+0})==($this->COL 0)&0xFF&&ord($Locals_rgb{3*$j+1})==($this->COL 8)&0xFF&&ord($Locals_rgb{3*$j+2})==($this->COL16)&0xFF){ 
          $Locals_ext="!\xF9\x04".chr(($this->DIS<<2)+1).chr(($d0)&0xFF).chr(($d8)&0xFF).chr($j)."\x0"; 
          break; 
        }  
      }  
    }  
    switch($Locals_tmp{0}){ 
      case "!":  
        $Locals_img=substr($Locals_tmp,8,10); 
        $Locals_tmp=substr($Locals_tmp,18,strlen($Locals_tmp)-18); 
        break; 
      case ",":  
        $Locals_img=substr($Locals_tmp,0,10); 
        $Locals_tmp=substr($Locals_tmp,10,strlen($Locals_tmp)-10); 
        break; 
    }  
    if(ord($this->BUF[$i]{10})&0x80&&$this->IMG>-1){ 
      if($Global_len==$Locals_len){ 
        if(GIFEncoder::GIFBlockCompare($Global_rgb,$Locals_rgb,$Global_len)){ 
          $this->GIF.=($Locals_ext.$Locals_img.$Locals_tmp); 
        }else{ 
          $byte=ord($Locals_img{9}); 
          $byte|=0x80; 
          $byte&=0xF8; 
          $byte|=(ord($this->BUF [0]{10})&0x07); 
          $Locals_img{9}=chr($byte); 
          $this->GIF.=($Locals_ext.$Locals_img.$Locals_rgb.$Locals_tmp); 
        }  
      }else{ 
        $byte=ord($Locals_img{9}); 
        $byte|=0x80; 
        $byte&=0xF8; 
        $byte|=(ord($this->BUF[$i]{10})&0x07); 
        $Locals_img {9}=chr($byte); 
        $this->GIF.=($Locals_ext.$Locals_img.$Locals_rgb.$Locals_tmp); 
      }  
    }else{ 
      $this->GIF.=($Locals_ext.$Locals_img.$Locals_tmp); 
    }  
    $this->IMG=1; 
  }  
  function GIFAddFooter(){ 
    $this->GIF.=";"; 
  }  
  function GIFBlockCompare($GlobalBlock,$LocalBlock,$Len){ 
    for($i=0;$i<$Len;$i++){ 
      if($GlobalBlock{3*$i+0}!=$LocalBlock{3*$i+0}||$GlobalBlock{3*$i+1}!=$LocalBlock{3*$i+1}||$GlobalBlock{3*$i+2}!=$LocalBlock{3*$i+2}){ 
        return(0); 
      }  
    }  
    return(1); 
  }  
  function GIFWord($int){ 
    return(chr($int&0xFF).chr(($int8)&0xFF)); 
  }  
  function GetAnimation(){ 
    return($this->GIF); 
  }  
} 

php生成动态验证码用法示例:

/*调用示例*/ 
session_start(); 
$checkCode=''; 
$chars='abcdefghjkmnpqrstuvwxyzABCDEFGHJKLMNPRSTUVWXYZ23456789'; 
for($i=0;$i<4;$i++){ 
  $checkCode.=substr($chars,mt_rand(0,strlen($chars)-1),1); 
} 
$_SESSION['code']=strtoupper($checkCode);// 记录session 
ImageCode($checkCode,60);// 显示GIF动画 

以上就是php如何生成动态验证码的实现方法,希望对大家的学习有所帮助。

华山资源网 Design By www.eoogi.com
广告合作:本站广告合作请联系QQ:858582 申请时备注:广告合作(否则不回)
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
华山资源网 Design By www.eoogi.com

《魔兽世界》大逃杀!60人新游玩模式《强袭风暴》3月21日上线

暴雪近日发布了《魔兽世界》10.2.6 更新内容,新游玩模式《强袭风暴》即将于3月21 日在亚服上线,届时玩家将前往阿拉希高地展开一场 60 人大逃杀对战。

艾泽拉斯的冒险者已经征服了艾泽拉斯的大地及遥远的彼岸。他们在对抗世界上最致命的敌人时展现出过人的手腕,并且成功阻止终结宇宙等级的威胁。当他们在为即将于《魔兽世界》资料片《地心之战》中来袭的萨拉塔斯势力做战斗准备时,他们还需要在熟悉的阿拉希高地面对一个全新的敌人──那就是彼此。在《巨龙崛起》10.2.6 更新的《强袭风暴》中,玩家将会进入一个全新的海盗主题大逃杀式限时活动,其中包含极高的风险和史诗级的奖励。

《强袭风暴》不是普通的战场,作为一个独立于主游戏之外的活动,玩家可以用大逃杀的风格来体验《魔兽世界》,不分职业、不分装备(除了你在赛局中捡到的),光是技巧和战略的强弱之分就能决定出谁才是能坚持到最后的赢家。本次活动将会开放单人和双人模式,玩家在加入海盗主题的预赛大厅区域前,可以从强袭风暴角色画面新增好友。游玩游戏将可以累计名望轨迹,《巨龙崛起》和《魔兽世界:巫妖王之怒 经典版》的玩家都可以获得奖励。