laravel5.4生成驗證碼

總結:本篇博客介紹使用gregwar/captcha實現驗證碼的具體操作步驟,以及可能遇到的問題和解決辦法。

博客第一作者,尊重原創

原文地址:http://www.cnblogs.com/zbokett/p/7287235.html


操作步驟:

1, 在laravel5.4項目根目錄下找到 composer.json 這個文件,

 

添加  "gregwar/captcha": "dev-master"  和  "Gregwar\\Captcha\\": "vendor/Captcha/"  到composer.json文件中,如下圖所示,

接下來,在項目根目錄執行composer update,然後再執行composer dump-autoload 命令。

第二種方法:

添加

"gregwar/captcha": "1.*"  到composer.json這個文件中,如下圖所示。

2. 然後打開命令行,找到項目的根目錄,運行composer update,

可以看到這個擴展庫已經下載好了,

 

 3.接下來,就可以正常使用驗證碼了,

先定義路由:

接下來,介紹兩種顯示驗證碼的情況,

一:直接在網頁上輸出驗證碼圖片

 

在控制層裏新建一個codeController.php, 1 <?php  2 namespace App\Http\Controllers;

 3 
 4 use App\Http\Requests;
 5 use App\Http\Controllers\Controller;
 6 
 7 use Illuminate\Http\Request;
 8 
 9 //引用對應的命名空間
10 use Gregwar\Captcha\CaptchaBuilder;
11 use Session;
12 class CodeController extends Controller{
13     public function captcha($temp)
14     {  
15         $builder = new CaptchaBuilder();
16         $builder->build(150,32);
       //獲取驗證碼內容
17         $phrase = $builder->getPhrase();

18         //把內容存入session
19         Session::flash('milkcaptcha', $phrase); //存儲驗證碼
20         ob_clean(); //清除緩存
21         return response($builder->output())->header('Content-type','image/jpeg'); //把驗證碼數據以jpeg圖片的格式輸出
22     }
23 
24 }

 

然後在瀏覽器裏訪問之前定義好的路由,直接訪問這個方法,就能看到輸出的驗證碼了

 

第二種方法:在表單裏顯示驗證碼,把上面該文件路徑寫到<img>標籤的src屬性中,

顯示如下:

 

這裏有兩個問題需要注意,照着下面的方法去直接輸出驗證碼,你會發現驗證碼顯示不出來,反而是一堆亂碼,

public function code($tmp)
{
//生成驗證碼圖片的Builder對象,配置相應屬性
$builder = new CaptchaBuilder;
//可以設置圖片寬高及字體
$builder->build($width = 100, $height = 40, $font = null);
//獲取驗證碼的內容
$phrase = $builder->getPhrase();
//把內容存入session
Session::flash('milkcaptcha', $phrase);
//生成圖片
header("Cache-Control: no-cache, must-revalidate");//清除緩存
header('Content-Type: image/jpeg');
$builder->output();
}

輸出一下$phrase,發現驗證碼內容已經獲取到了,是圖片生成部分出的問題,

// header("Cache-Control: no-cache, must-revalidate"); 這行代碼的作用是清除緩存,防止出現驗證碼不能刷新或顯示不出來的情況,
但是並沒有起作用,改用 ob_clean(); 去清除瀏覽器緩存。

 然後是 

header('Content-Type: image/jpeg');
$builder->output();

這兩句話的問題,

$builder->output();
返回的只是驗證碼圖片的一些信息,並不是一張圖片,所以當把它直接輸出時,出來的並不是一張圖片,

只有這樣寫

$builder->output()->header('Content-type','image/jpeg')

直接輸出的時候,纔會以圖片的形式直接輸出驗證碼。

當把它放到<img>的src屬性中,<img>標籤會自動以圖片的格式輸出它,也就是說

header('Content-type','image/jpeg')

這時候這句話是沒必要的,所以不管是

$builder->output())->header('Content-type','image/jpeg')

這樣寫,還是

header('Content-Type: image/jpeg');
$builder->output();

這樣寫,結果都會顯示驗證碼圖片。

發佈了43 篇原創文章 · 獲贊 98 · 訪問量 5萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章