• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    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('/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;
      }
    }

    最后不得不吐槽一下laravel的官方文档,像这种坑都不提前说明,估计是担心开发者开发的太顺心了吧。

    总结

    以上所述是小编给大家介绍的Laravel5.2使用Captcha生成验证码实现登录(session巨坑),希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对脚本之家网站的支持!

    您可能感兴趣的文章:
    • 用Laravel Sms实现laravel短信验证码的发送的实现
    • laravel中短信发送验证码的实现方法
    • Laravel下生成验证码的类
    • 使用 laravel sms 构建短信验证码发送校验功能
    • laravel5.4生成验证码的代码
    • laravel5.4生成验证码的实例讲解
    • Laravel8 使用图形验证码做登录功能的实现
    上一篇:PHP根据手机号判断运营商(详细介绍附代码)
    下一篇:PHP排序算法系列之桶排序详解
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯

    时间:9:00-21:00 (节假日不休)

    地址:江苏信息产业基地11号楼四层

    《增值电信业务经营许可证》 苏B2-20120278

    Laravel5.2使用Captcha生成验证码实现登录(session巨坑) Laravel5.2,使用,Captcha,生成,