最近有朋友要我帮忙弄一下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教程
郑重声明:本文版权归原作者所有,转载文章仅为传播更多信息之目的,如作者信息标记有误,请第一时间联系我们修改或删除,多谢。
新闻热点
疑难解答