真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

怎么在Laravel5.2中利用Captcha實(shí)現(xiàn)一個(gè)驗(yàn)證碼登錄功能-創(chuàng)新互聯(lián)

今天就跟大家聊聊有關(guān)怎么在Laravel5.2中利用Captcha實(shí)現(xiàn)一個(gè)驗(yàn)證碼登錄功能,可能很多人都不太了解,為了讓大家更加了解,小編給大家總結(jié)了以下內(nèi)容,希望大家根據(jù)這篇文章可以有所收獲。

為東昌府等地區(qū)用戶提供了全套網(wǎng)頁(yè)設(shè)計(jì)制作服務(wù),及東昌府網(wǎng)站建設(shè)行業(yè)解決方案。主營(yíng)業(yè)務(wù)為網(wǎng)站制作、網(wǎng)站設(shè)計(jì)、東昌府網(wǎng)站設(shè)計(jì),以傳統(tǒng)方式定制建設(shè)網(wǎng)站,并提供域名空間備案等一條龍服務(wù),秉承以專業(yè)、用心的態(tài)度為用戶提供真誠(chéng)的服務(wù)。我們深信只要達(dá)到每一位用戶的要求,就會(huì)得到認(rèn)可,從而選擇與我們長(zhǎng)期合作。這樣,我們也可以走得更遠(yuǎn)!

首先,安裝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ù)或者是中間件了。之后就可以放肆的寫你的代碼了。

php:(具體的路由啥的在下就不做太多的贅述了,只寫關(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)用:

  如果你以為這樣就完事了的話,那你真的是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;
  }
}

看完上述內(nèi)容,你們對(duì)怎么在Laravel5.2中利用Captcha實(shí)現(xiàn)一個(gè)驗(yàn)證碼登錄功能有進(jìn)一步的了解嗎?如果還想了解更多知識(shí)或者相關(guān)內(nèi)容,請(qǐng)關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,感謝大家的支持。


本文標(biāo)題:怎么在Laravel5.2中利用Captcha實(shí)現(xiàn)一個(gè)驗(yàn)證碼登錄功能-創(chuàng)新互聯(lián)
新聞來(lái)源:http://weahome.cn/article/pjsco.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部