最近有朋友要我幫忙弄一下laravel的驗證碼登陸,所以稍稍研究了一下。(本人都快忘了咋使用laravel了)
首先,安裝laravel就不用在下贅述了吧,我的版本是5.2.45(注:laravel5.2.6以上的版本中間件可以自動加載),這還是挺重要的。
安裝完成之后,你需要使用composer來加載你的Captcha,具體方法就是在你的composer.json中的require數組中加上 gregwar/captcha : 1.* 這行代碼。然后嘞,就在你的項目根目錄下使用cmd來運行composer update這行代碼。這樣一來的話,就算是安裝上這個庫或者是中間件了。之后就可以放肆的寫你的代碼了。
php:(具體的路由啥的在下就不做太多的贅述了,只寫關鍵代碼)
html' target='_blank'>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= quot;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;}
最后不得不吐槽一下laravel的官方文檔,像這種坑都不提前說明,估計是擔心開發者開發的太順心了吧。
總結
以上所述是小編給大家介紹的Laravel5.2使用Captcha生成驗證碼實現登錄(session巨坑),希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對php 的支持!
您可能感興趣的文章:PHP排序算法系列之桶排序的詳解
PHP排序算法系列之歸并排序詳解_php技巧
PHP排序算法系列之直接選擇排序的詳解
以上就是Laravel5.2使用Captcha生成驗證碼實現登錄的詳細內容,PHP教程
鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。
新聞熱點
疑難解答