首頁 >後端開發 >php教程 >Laravel5.2使用Captcha產生驗證碼實作登入

Laravel5.2使用Captcha產生驗證碼實作登入

jacklove
jacklove原創
2018-07-03 17:57:051956瀏覽

這篇文章主要介紹了Laravel5.2使用Captcha產生驗證碼(session巨坑),需要的朋友可以參考下

最近有朋友要我幫忙弄一下laravel的驗證碼登陸,所以稍稍研究了一下。 (我自己都快忘了咋使用laravel了)

首先,安裝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(&#39;/captcha/1&#39;)}}" alt="" onclick="this.src=&#39;{{url(&#39;/captcha&#39;)}}/&#39;+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(&#39;captcha&#39;);
  if (Session::get(&#39;milkcaptcha&#39;) == $userInput) {
    //用户输入验证码正确,验证你自己密码用户名
    echo 1;
  } else {
    //用户输入验证码错误
    echo 2;
  }
}

#最後不得不吐槽一下laravel的官方文檔,像這種坑都不提前說明,估計是擔心開發者開發的太順心了吧。

總結

以上所述是小編給大家介紹的Laravel5.2使用Captcha產生驗證碼實作登入(session巨坑) ,希望對大家有幫助,如果大家有任何疑問請給我留言,小編會及時回覆大家的。在此也非常感謝大家對php中文網的支持!

您可能感興趣的文章:

PHP排序演算法系列之桶排序的詳解

PHP排序演算法系列之歸併排序詳解_php技巧

PHP排序演算法系列之直接選擇排序的詳解

#

以上是Laravel5.2使用Captcha產生驗證碼實作登入的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn