主頁(yè) > 知識(shí)庫(kù) > Laravel5.2使用Captcha生成驗(yàn)證碼實(shí)現(xiàn)登錄(session巨坑)

Laravel5.2使用Captcha生成驗(yàn)證碼實(shí)現(xiàn)登錄(session巨坑)

熱門(mén)標(biāo)簽:400電話辦理福州市 400電話申請(qǐng)方法收費(fèi) 深圳外呼系統(tǒng)收費(fèi) 江蘇外呼電銷(xiāo)機(jī)器人報(bào)價(jià) 專(zhuān)業(yè)電話機(jī)器人批發(fā)商 長(zhǎng)沙crm外呼系統(tǒng)業(yè)務(wù) 南寧高頻外呼回?fù)芟到y(tǒng)哪家好 電話機(jī)器人危險(xiǎn)嗎 離石地圖標(biāo)注

最近有朋友要我?guī)兔ε幌耹aravel的驗(yàn)證碼登陸,所以稍稍研究了一下。(本人都快忘了咋使用laravel了)

首先,安裝laravel就不用在下贅述了吧,我的版本是5.2.45(注:laravel5.2.6以上的版本中間件可以自動(dòng)加載),這還是挺重要的。

安裝完成之后,你需要使用composer來(lái)加載你的Captcha,具體方法就是在你的composer.json中的require數(shù)組中加上"gregwar/captcha":"1.*"這行代碼。然后嘞,就在你的項(xiàng)目根目錄下使用cmd來(lái)運(yùn)行composer update這行代碼。這樣一來(lái)的話,就算是安裝上這個(gè)庫(kù)或者是中間件了。之后就可以放肆的寫(xiě)你的代碼了。

php:(具體的路由啥的在下就不做太多的贅述了,只寫(xiě)關(guān)鍵代碼)

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

blade模板的調(diào)用:

img src="{{url('/captcha/1')}}" alt="" onclick="this.src='{{url('/captcha')}}/'+Math.random()" width="100" height="40" border="0">

  如果你以為這樣就完事了的話,那你真的是too yang too simple了。在你驗(yàn)證的時(shí)候你會(huì)發(fā)現(xiàn)怎么樣都是錯(cuò)誤。

是不是很酸爽。因?yàn)樵趌aravel5.2中,所有的session都是不能跨控制器、方法的,如果跨的話,session會(huì)重新生成,默認(rèn)session的傳遞需要經(jīng)過(guò)中間件。不要急,接下來(lái)的方法就是解決之道。目前本人所知有兩種解決方案,其一就是自己建一個(gè)中間件,然后把所有的session都存儲(chǔ)在其中,但是有點(diǎn)小麻煩,接下來(lái)本人介紹一種簡(jiǎn)單的方法,在你的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了。這是在下的驗(yàn)證驗(yàn)證碼的方式,

public function login_data()
{
  $userInput = \Request::get('captcha');
  if (Session::get('milkcaptcha') == $userInput) {
    //用戶輸入驗(yàn)證碼正確,驗(yàn)證你自己密碼用戶名
    echo 1;
  } else {
    //用戶輸入驗(yàn)證碼錯(cuò)誤
    echo 2;
  }
}

最后不得不吐槽一下laravel的官方文檔,像這種坑都不提前說(shuō)明,估計(jì)是擔(dān)心開(kāi)發(fā)者開(kāi)發(fā)的太順心了吧。

總結(jié)

以上所述是小編給大家介紹的Laravel5.2使用Captcha生成驗(yàn)證碼實(shí)現(xiàn)登錄(session巨坑),希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!

您可能感興趣的文章:
  • 用Laravel Sms實(shí)現(xiàn)laravel短信驗(yàn)證碼的發(fā)送的實(shí)現(xiàn)
  • laravel中短信發(fā)送驗(yàn)證碼的實(shí)現(xiàn)方法
  • Laravel下生成驗(yàn)證碼的類(lèi)
  • 使用 laravel sms 構(gòu)建短信驗(yàn)證碼發(fā)送校驗(yàn)功能
  • laravel5.4生成驗(yàn)證碼的代碼
  • laravel5.4生成驗(yàn)證碼的實(shí)例講解
  • Laravel8 使用圖形驗(yàn)證碼做登錄功能的實(shí)現(xiàn)

標(biāo)簽:濱州 曲靖 太原 南京 株洲 白酒營(yíng)銷(xiāo) 興安盟 南昌

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《Laravel5.2使用Captcha生成驗(yàn)證碼實(shí)現(xiàn)登錄(session巨坑)》,本文關(guān)鍵詞  Laravel5.2,使用,Captcha,生成,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《Laravel5.2使用Captcha生成驗(yàn)證碼實(shí)現(xiàn)登錄(session巨坑)》相關(guān)的同類(lèi)信息!
  • 本頁(yè)收集關(guān)于Laravel5.2使用Captcha生成驗(yàn)證碼實(shí)現(xiàn)登錄(session巨坑)的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章