您好,登錄后才能下訂單哦!
今天就跟大家聊聊有關怎么在Laravel5.2中利用Captcha實現一個驗證碼登錄功能,可能很多人都不太了解,為了讓大家更加了解,小編給大家總結了以下內容,希望大家根據這篇文章可以有所收獲。
首先,安裝laravel就不用在下贅述了吧,我的版本是5.2.45(注:laravel5.2.6以上的版本中間件可以自動加載),這還是挺重要的。
安裝完成之后,你需要使用composer來加載你的Captcha,具體方法就是在你的composer.json中的require數組中加上"gregwar/captcha":"1.*"這行代碼。然后嘞,就在你的項目根目錄下使用cmd來運行composer update這行代碼。這樣一來的話,就算是安裝上這個庫或者是中間件了。之后就可以放肆的寫你的代碼了。
php:(具體的路由啥的在下就不做太多的贅述了,只寫關鍵代碼)
public function captcha($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(); }
blade模板的調用:
<img src="{{url('/captcha/1')}}" alt="" onclick="this.src='{{url('/captcha')}}/'+Math.random()" width="100" height="40" border="0">
如果你以為這樣就完事了的話,那你真的是too yang too simple了。在你驗證的時候你會發現怎么樣都是錯誤。
是不是很酸爽。因為在laravel5.2中,所有的session都是不能跨控制器、方法的,如果跨的話,session會重新生成,默認session的傳遞需要經過中間件。不要急,接下來的方法就是解決之道。目前本人所知有兩種解決方案,其一就是自己建一個中間件,然后把所有的session都存儲在其中,但是有點小麻煩,接下來本人介紹一種簡單的方法,在你的laravel\app\Http\Kernel.php 文件里的$middleware里加上以下代碼:
\Illuminate\Foundation\Http\Middleware\CheckForMaintenanceMode::class, \Illuminate\Cookie\Middleware\EncryptCookies::class, \Illuminate\Cookie\Middleware\AddQueuedCookiesToResponse::class, \Illuminate\Session\Middleware\StartSession::class, \Illuminate\View\Middleware\ShareErrorsFromSession::class,
之后就可以放心的使用session了。這是在下的驗證驗證碼的方式,
public function login_data() { $userInput = \Request::get('captcha'); if (Session::get('milkcaptcha') == $userInput) { //用戶輸入驗證碼正確,驗證你自己密碼用戶名 echo 1; } else { //用戶輸入驗證碼錯誤 echo 2; } }
看完上述內容,你們對怎么在Laravel5.2中利用Captcha實現一個驗證碼登錄功能有進一步的了解嗎?如果還想了解更多知識或者相關內容,請關注億速云行業資訊頻道,感謝大家的支持。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。