Maison >développement back-end >tutoriel php >Analyse des fichiers et de l'utilisation de la bibliothèque de codes de vérification du framework CodeIgniter

Analyse des fichiers et de l'utilisation de la bibliothèque de codes de vérification du framework CodeIgniter

不言
不言original
2018-06-14 14:02:251857parcourir

Cet article présente principalement le fichier de bibliothèque de classes de code de vérification du cadre CodeIgniter et son utilisation, et analyse la définition et l'utilisation spécifique du fichier de bibliothèque de classes de code de vérification du cadre CodeIgniter sous forme d'exemples. Il a une certaine valeur de référence. référez-vous à lui.

Les exemples de cet article décrivent les fichiers et l'utilisation de la bibliothèque de codes de vérification du framework CodeIgniter. J'aimerais le partager avec vous pour votre référence. Les détails sont les suivants :

Après avoir lutté pendant quatre ou cinq heures, la bibliothèque de codes de vérification CI a finalement été développée avec succès.

Veuillez consulter le code source ci-dessous :

Créez le fichier Authcode.php dans application/libraries, le code est le suivant :

<?php
class Authcode
{
 var $CI;
 var $fontPath;//字体路径
 var $image;
 var $charLen   = 4; //生成几位验证码
 var $arrChr   = array();//验证码字符
 var $width    = 83; //图片宽
 var $height   = 24; //图片高
 var $bgcolor   = "#ffffff"; //背景色
 var $showNoisePix  = true; //生成杂点
 var $noiseNumPix  = 80; //生成杂点数量
 var $showNoiseLine  = true; //生成杂线
 var $noiseNumLine  = 2; //生成杂线数量
 var $showBorder  = true; //边框,当杂点、线一起作用的时候,边框容易受干扰
 var $borderColor  = "#000000";
 function Authcode()
 {
  $this->CI = & get_instance();
  $this->fontPath = realpath(dirname(__FILE__) . &#39;/fonts/&#39;); //字体文件
  //$this->arrChr   = array_merge(range(1, 9) , range(&#39;A&#39;, &#39;Z&#39;));//数字字母验证码
  //$this->arrChr   = range(&#39;A&#39;, &#39;Z&#39;);//纯字母验证码
  $this->arrChr = range(0, 9);//纯数字验证码
 }
 /**
  * 显示验证码
  *
  */
 function show()
 {
  $this->image = imageCreate($this->width, $this->height);
  $this->back = $this->getColor($this->bgcolor);
  imageFilledRectangle($this->image, 0, 0, $this->width, $this->height, $this->back);
  $size = $this->width / $this->charLen - 4;
  if ($size > $this->height) {
   $size = $this->height;
  }
  $left = ($this->width - $this->charLen * ($size + $size / 10)) / $size + 5;
  $code = &#39;&#39;;
  for($i = 0; $i < $this->charLen; $i ++) {
   $randKey = rand(0, count($this->arrChr) - 1);
   $randText = $this->arrChr[$randKey];
   $code .= $randText;
   $textColor = imageColorAllocate($this->image, rand(0, 100), rand(0, 100), rand(0, 100));
   $font = $this->fontPath . &#39;/&#39; . rand(1, 5) . ".ttf";
   $randsize = rand($size - $size / 10, $size + $size / 10);
   $location = $left + ($i * $size + $size / 10);
   @imagettftext($this->image, $randsize, rand(- 18, 18), $location, rand($size - $size / 10, $size + $size / 10) + 2, $textColor, $font, $randText);
  }
  if ($this->showNoisePix == true) {
   $this->setNoisePix();
  }
  if ($this->showNoiseLine == true) {
   $this->setNoiseLine();
  }
  if ($this->showBorder == true) {
   $this->borderColor = $this->getColor($this->borderColor);
   imageRectangle($this->image, 0, 0, $this->width - 1, $this->height - 1, $this->borderColor);
  }
  $this->CI->session->set_userdata(&#39;auth_code&#39;, $code);
  ob_clean();
  header("Content-type: image/jpeg");
  imagejpeg($this->image);
  imagedestroy($this->image);
 }
 /**
  * 显示验证码的JS调用
  *
  */
 function showScript()
 {
  //显示验证码
  echo "var img_src = &#39;/imgauthcode/show/?&#39;;\n";
  echo "document.writeln(&#39;<img id=\"img_authcode\" src=\"&#39; + img_src + Math.random() + &#39;\" style=\"cursor:hand;\" onclick=\"this.src=img_src + Math.random();\" alt=\"点击更换图片\">&#39;);";
 }
 /**
  * 检查验证码是否正确
  *
  * @param string $auth_code
  * @return bool
  */
 function check($auth_code = null)
 {
  return ($this->CI->session->userdata(&#39;auth_code&#39;) && $auth_code) ? ($this->CI->session->userdata(&#39;auth_code&#39;) === $auth_code) : false;
 }
 function getColor($color)
 {
  $color = eregi_replace("^#", "", $color);
  $r = $color[0] . $color[1];
  $r = hexdec($r);
  $b = $color[2] . $color[3];
  $b = hexdec($b);
  $g = $color[4] . $color[5];
  $g = hexdec($g);
  $color = imagecolorallocate($this->image, $r, $b, $g);
  return $color;
 }
 function setNoisePix()
 {
  for($i = 0; $i < $this->noiseNumPix; $i ++) {
   $randColor = imageColorAllocate($this->image, rand(0, 255), rand(0, 255), rand(0, 255));
   imageSetPixel($this->image, rand(0, $this->width), rand(0, $this->height), $randColor);
  }
 }
 function setNoiseLine()
 {
  for($i = 0; $i < $this->noiseNumLine; $i ++) {
   $randColor = imageColorAllocate($this->image, rand(0, 255), rand(0, 255), rand(0, 255));
   imageline($this->image, rand(1, $this->width), rand(1, $this->height), rand(1, $this->width), rand(1, $this->height), $randColor);
  }
 }
}

Fin du code Authcode.php

Dans Controller, il existe une classe admin, qui a deux méthodes :

Class Admin extends CI_Controller{
 function __construct()
 {
  parent::__construct();
  $this->load->library(&#39;Authcode&#39;);
 }
function captcha(){
  if($_POST){
    if ($this->authcode->check($this->input->post(&#39;gd_pic&#39;))) {
    echo "right";
   } else {
    echo &#39;验证码不正确,请重新输入&#39;;
   }
  }else{
   $this->load->view(&#39;demo&#39;);
  }
 }
 function show_captcha(){ //此方法用于显示验证码图片,归一个view中的img的src调用
  $this->authcode->show();
 }
}

Ce qui suit est Créez un demo.php dans la vue, le code est le suivant :

<?php echo form_open(&#39;c=admin&m=captcha&#39;);?>
<input type="text" name="gd_pic" />
<img src="<?php echo base_url(&#39;?c=admin&m=show_captcha&#39;);?>" ><br>
<input type="submit" name="submit" value="验证" />
<?php echo form_close();?>

Tout est terminé et c'est OK. fonctionne enfin normalement.

Ce qui précède représente l'intégralité du contenu de cet article. J'espère qu'il sera utile à l'étude de chacun. Pour plus de contenu connexe, veuillez faire attention au site Web PHP chinois !

Recommandations associées :

À propos de l'analyse de validation de formulaire du framework CI

Comment résoudre les erreurs 404 dans Nginx et le framework CI

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn