亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

基于PHP實現(xiàn)用戶注冊登錄功能

 更新時間:2016年10月14日 15:21:01   作者:xiaoxiaozi  
本課程通過使用PHP及Web前端技術(shù)實現(xiàn)一個網(wǎng)站注冊登錄入口頁面,學(xué)習(xí)并實踐PHP編程等,有興趣的同學(xué)可以參考一下。

本文介紹的是基于PHP實現(xiàn)用戶注冊登錄功能,本項目分為四部分內(nèi)容:1前端頁面制作,2驗證碼制作,3實現(xiàn)注冊登陸,4功能完善。具體情況可以往下看。

驗證碼制作

一、實驗簡介

本次實驗將會帶領(lǐng)大家使用面向?qū)ο蟮乃枷敕庋b一個驗證碼類。并在注冊和登陸界面展示使用。通過本次實驗的學(xué)習(xí),你將會領(lǐng)悟到 PHP 的 OOP 思想,以及 GD 庫的使用,驗證碼生成。

1.1 涉及到的知識點

  • PHP
  • GD庫
  • OOP編程

1.2 開發(fā)工具

sublime,一個方便快速的文本編輯器。點擊桌面左下角: 應(yīng)用程序菜單/開發(fā)/sublime

二、封裝驗證碼類

2.1 建立目錄以及準(zhǔn)備字體

在 web 目錄下建立一個 admin 目錄作為我們的后臺目錄,存放后臺代碼文件。在 admin 下建立一個 fonts 目錄,用于存放制作驗證碼所需字體。

在 admin 下新建一個 Captcha.php 文件,這就是我們需要編輯的驗證碼類文件。

當(dāng)前目錄層次結(jié)構(gòu):

編輯 Captcha.php 文件:

<?php 
/**
* Captcha class
*/
class Captcha
{
  
  function __construct()
  {
    # code...
  }
}

添加該類的私有屬性和構(gòu)造方法:

<?php 
/**
* Captcha class
*/
class Captcha
{
  private $codeNum;  //驗證碼位數(shù)
  private $width;  //驗證碼圖片寬度
  private $height;  //驗證碼圖片高度
  private $img;  //圖像資源句柄
  private $lineFlag;  //是否生成干擾線條
  private $piexFlag;  //是否生成干擾點
  private $fontSize;  //字體大小
  private $code;  //驗證碼字符
  private $string;  //生成驗證碼的字符集
  private $font;  //字體
  function __construct($codeNum = 4,$height = 50,$width = 150,$fontSize = 20,$lineFlag = true,$piexFlag = true)
  {
    $this->string = 'qwertyupmkjnhbgvfcdsxa123456789';  //去除一些相近的字符
    $this->codeNum = $codeNum;
    $this->height = $height;
    $this->width = $width;
    $this->lineFlag = $lineFlag;
    $this->piexFlag = $piexFlag;
    $this->font = dirname(__FILE__).'/fonts/consola.ttf';
    $this->fontSize = $fontSize;
  }
}

字體文件可通過以下命令下載到 fonts 目錄:

$ wget http://labfile.oss.aliyuncs.com/courses/587/consola.ttf

接下來開始編寫具體的方法:

創(chuàng)建圖像資源句柄

//創(chuàng)建圖像資源  
public function createImage(){
    $this->img = imagecreate($this->width, $this->height);  //創(chuàng)建圖像資源
    imagecolorallocate($this->img,mt_rand(0,100),mt_rand(0,100),mt_rand(0,100));  //填充圖像背景(使用淺色)
  }

用到的相關(guān)函數(shù)

  • imagecreate:新建一個基于調(diào)色板的圖像
  • imagecolorallocate:為一幅圖像分配顏色
  • mt_rand:生成更好的隨機數(shù)

創(chuàng)建驗證碼字符串并輸出到圖像

//創(chuàng)建驗證碼  
public function createCode(){
    $strlen = strlen($this->string)-1;
    for ($i=0; $i < $this->codeNum; $i++) { 
      $this->code .= $this->string[mt_rand(0,$strlen)];  //從字符集中隨機取出四個字符拼接
    }
     $_SESSION['code'] = $this->code;  //加入 session 中
  
   //計算每個字符間距
    $diff = $this->width/$this->codeNum;
    for ($i=0; $i < $this->codeNum; $i++) { 
          //為每個字符生成顏色(使用深色)
     $txtColor = imagecolorallocate($this->img,mt_rand(100,255),mt_rand(100,255),mt_rand(100,255));
     //寫入圖像
      imagettftext($this->img, $this->fontSize, mt_rand(-30,30), $diff*$i+mt_rand(3,8), mt_rand(20,$this->height-10), $txtColor, $this->font, $this->code[$i]);
    }
  }

用到的相關(guān)函數(shù)

  • imagecreate:新建一個基于調(diào)色板的圖像
  • imagecolorallocate:為一幅圖像分配顏色
  • mt_rand:生成更好的隨機數(shù)

創(chuàng)建驗證碼字符串并輸出到圖像

//創(chuàng)建驗證碼  
public function createCode(){
    $strlen = strlen($this->string)-1;
    for ($i=0; $i < $this->codeNum; $i++) { 
      $this->code .= $this->string[mt_rand(0,$strlen)];  //從字符集中隨機取出四個字符拼接
    }
     $_SESSION['code'] = $this->code;  //加入 session 中
  
   //計算每個字符間距
    $diff = $this->width/$this->codeNum;
    for ($i=0; $i < $this->codeNum; $i++) { 
          //為每個字符生成顏色(使用深色)
     $txtColor = imagecolorallocate($this->img,mt_rand(100,255),mt_rand(100,255),mt_rand(100,255));
     //寫入圖像
      imagettftext($this->img, $this->fontSize, mt_rand(-30,30), $diff*$i+mt_rand(3,8), mt_rand(20,$this->height-10), $txtColor, $this->font, $this->code[$i]);
    }
  }

用到的相關(guān)函數(shù):

  • imagettftext:用 TrueType 字體向圖像寫入文本

創(chuàng)建干擾線條

//創(chuàng)建干擾線條(默認(rèn)四條)
public function createLines(){
    for ($i=0; $i < 4; $i++) { 
      $color = imagecolorallocate($this->img,mt_rand(0,155),mt_rand(0,155),mt_rand(0,155));  //使用淺色
      imageline($this->img,mt_rand(0,$this->width),mt_rand(0,$this->height),mt_rand(0,$this->width),mt_rand(0,$this->height),$color); 
    }
  }

用到的相關(guān)函數(shù):

  • imageline:畫一條線段

創(chuàng)建干擾點

//創(chuàng)建干擾點 (默認(rèn)一百個點)
public function createPiex(){
    for ($i=0; $i < 100; $i++) { 
      $color = imagecolorallocate($this->img,mt_rand(0,255),mt_rand(0,255),mt_rand(0,255));
      imagesetpixel($this->img,mt_rand(0,$this->width),mt_rand(0,$this->height),$color);
    }
  }

使用的相關(guān)函數(shù):

  • imagesetpixel:畫一個單一像素

對外輸出圖像:
   

 public function show()
  {
    $this->createImage();
    $this->createCode();
    if ($this->lineFlag) {  //是否創(chuàng)建干擾線條
      $this->createLines();
    }
    if ($this->piexFlag) {  //是否創(chuàng)建干擾點
      $this->createPiex();
    }
    header('Content-type:image/png');  //請求頁面的內(nèi)容是png格式的圖像
    imagepng($this->img);  //以png格式輸出圖像
    imagedestroy($this->img);  //清除圖像資源,釋放內(nèi)存
  }

用到的相關(guān)函數(shù):

  • imagepng:以 PNG 格式將圖像輸出到瀏覽器或文件
  • imagedestroy:銷毀一圖像

對外提供驗證碼:

public function getCode(){
    return $this->code;
  }
完整代碼如下:
<?php 
/**
* Captcha class
*/
class Captcha
{
  private $codeNum;
  private $width;
  private $height;
  private $img;
  private $lineFlag;
  private $piexFlag;
  private $fontSize;
  private $code;
  private $string;
  private $font;
  function __construct($codeNum = 4,$height = 50,$width = 150,$fontSize = 20,$lineFlag = true,$piexFlag = true)
  {
    $this->string = 'qwertyupmkjnhbgvfcdsxa123456789';
    $this->codeNum = $codeNum;
    $this->height = $height;
    $this->width = $width;
    $this->lineFlag = $lineFlag;
    $this->piexFlag = $piexFlag;
    $this->font = dirname(__FILE__).'/fonts/consola.ttf';
    $this->fontSize = $fontSize;
  }

  public function createImage(){
    $this->img = imagecreate($this->width, $this->height);
    imagecolorallocate($this->img,mt_rand(0,100),mt_rand(0,100),mt_rand(0,100));
  }

  public function createCode(){
    $strlen = strlen($this->string)-1;
    for ($i=0; $i < $this->codeNum; $i++) { 
      $this->code .= $this->string[mt_rand(0,$strlen)];
    }
    $_SESSION['code'] = $this->code;
    $diff = $this->width/$this->codeNum;
    for ($i=0; $i < $this->codeNum; $i++) { 
      $txtColor = imagecolorallocate($this->img,mt_rand(100,255),mt_rand(100,255),mt_rand(100,255));
      imagettftext($this->img, $this->fontSize, mt_rand(-30,30), $diff*$i+mt_rand(3,8), mt_rand(20,$this->height-10), $txtColor, $this->font, $this->code[$i]);
    }
  }

  public function createLines(){
    for ($i=0; $i < 4; $i++) { 
      $color = imagecolorallocate($this->img,mt_rand(0,155),mt_rand(0,155),mt_rand(0,155));
      imageline($this->img,mt_rand(0,$this->width),mt_rand(0,$this->height),mt_rand(0,$this->width),mt_rand(0,$this->height),$color); 
    }
  }

  public function createPiexs(){
    for ($i=0; $i < 100; $i++) { 
      $color = imagecolorallocate($this->img,mt_rand(0,255),mt_rand(0,255),mt_rand(0,255));
      imagesetpixel($this->img,mt_rand(0,$this->width),mt_rand(0,$this->height),$color);
    }
  }

  public function show()
  {
    $this->createImage();
    $this->createCode();
    if ($this->lineFlag) {
      $this->createLines();
    }
    if ($this->piexFlag) {
      $this->createPiexs();
    }
    header('Content-type:image/png');
    imagepng($this->img);
    imagedestroy($this->img);
  }

  public function getCode(){
    return $this->code;
  }
}

以上就是驗證碼類的全部代碼??雌饋泶_實挺簡單的,不過用的圖像處理函數(shù)比較多,上面相關(guān)的函數(shù)我也做了必要的鏈接和用途說明。這些函數(shù)也不用死記硬背,遇到不清楚的,隨時查閱 PHP 官方文檔,最重要的是還有中文文檔。

2.2 使用驗證碼

既然已經(jīng)封裝完畢,那就可以開始使用了。這里為了方便,直接在 Captcha 類的下方調(diào)用該類:

session_start(); //開啟session
$captcha = new Captcha();  //實例化驗證碼類(可自定義參數(shù))
$captcha->show();  //調(diào)用輸出

三、前端展示

后端已經(jīng)準(zhǔn)備好了驗證碼,前端界面就可以展示了,修改 index.php 中的注冊與登陸表單的驗證碼部分:

<div class="form-group">
 <div class="col-sm-12">
   <img src="admin/Captcha.php" alt="" id="codeimg" onclick="javascript:this.src = 'admin/Captcha.php?'+Math.random();">
   <span>Click to Switch</span>
 </div>
</div>

img 標(biāo)簽添加了點擊事件的 js 代碼,這樣就可以實現(xiàn)點擊更換驗證碼的功能!

效果圖:


四、完善

到目前為止,我們的驗證碼模塊基本就完成了。學(xué)習(xí)到這里,大家應(yīng)該對面向?qū)ο缶幊逃辛诉M一步的理解。也領(lǐng)悟到了一絲 OOP 思想。OOP 的三大特征:封裝,繼承,多態(tài)。我們這里只用到了一點封裝的思想。大家可以繼續(xù)完善和改進這個驗證碼類,設(shè)計出更加完美的類。這個實驗也告訴我們,PHP 的函數(shù)很多,不要死記硬背,多看官方文檔。

相關(guān)文章

  • yii2局部關(guān)閉(開啟)csrf的驗證的實例代碼

    yii2局部關(guān)閉(開啟)csrf的驗證的實例代碼

    本篇文章主要介紹了yii2局部關(guān)閉(開啟)csrf的驗證的實例代碼。小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-07-07
  • php實現(xiàn)圖片縮略圖的方法

    php實現(xiàn)圖片縮略圖的方法

    本文使用php實現(xiàn)的圖片縮略圖,支持jpg,jpeg,gif,png,bmp圖片格式,支持按原圖片的比例進行縮放,可以選擇在圖片縮放的過程中是否需要對圖片進行裁切,加入了圖片質(zhì)量控制,可以實現(xiàn)縮略圖片質(zhì)量最高化,需要的朋友可以參考下本段代碼
    2016-03-03
  • mac環(huán)境中使用brew安裝php5.5.15

    mac環(huán)境中使用brew安裝php5.5.15

    MAC本來就自帶了 php,但是很多擴展沒有安裝,所以選擇了重新安裝php并升級到最新版,下面說說安裝步驟,希望對大家有所幫助
    2014-08-08
  • Linux平臺中使用PHP把word轉(zhuǎn)pdf的實現(xiàn)方法

    Linux平臺中使用PHP把word轉(zhuǎn)pdf的實現(xiàn)方法

    下面小編就為大家?guī)硪黄狶inux平臺中使用PHP把word轉(zhuǎn)pdf的實現(xiàn)方法。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-11-11
  • laravel-admin 在列表頁添加自定義按鈕的例子

    laravel-admin 在列表頁添加自定義按鈕的例子

    今天小編就為大家分享一篇laravel-admin 在列表頁添加自定義按鈕的例子,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-09-09
  • laravel利用中間件做防非法登錄和權(quán)限控制示例

    laravel利用中間件做防非法登錄和權(quán)限控制示例

    今天小編就為大家分享一篇laravel利用中間件做防非法登錄和權(quán)限控制示例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-10-10
  • PHP中模糊查詢并關(guān)聯(lián)三個select框

    PHP中模糊查詢并關(guān)聯(lián)三個select框

    這篇文章主要介紹了PHP中模糊查詢并關(guān)聯(lián)三個select框,需要的朋友可以參考下
    2017-06-06
  • PHP微信開發(fā)之查詢城市天氣

    PHP微信開發(fā)之查詢城市天氣

    這篇文章主要為大家詳細介紹了PHP微信開發(fā)之簡單實現(xiàn)查詢城市天氣的相關(guān)資料,感興趣的小伙伴們可以參考一下
    2016-06-06
  • PHP5.4起內(nèi)置web服務(wù)器使用方法

    PHP5.4起內(nèi)置web服務(wù)器使用方法

    這篇文章主要為大家詳細介紹了PHP5.4內(nèi)置web服務(wù)器,內(nèi)置的Web服務(wù)器只是提供開發(fā)測試使用,不推薦使用中生產(chǎn)環(huán)境中,具體內(nèi)容請閱讀下文
    2016-08-08
  • Yii框架響應(yīng)組件用法實例分析

    Yii框架響應(yīng)組件用法實例分析

    這篇文章主要介紹了Yii框架響應(yīng)組件用法,結(jié)合實例形式分析了Yii響應(yīng)組件的原理及常見使用技巧,需要的朋友可以參考下
    2019-09-09

最新評論