|
最近有朋友要我帮忙弄一下laravel的验证码登陆,所以稍稍研究了一下。本文主要介绍了Laravel5.2使用Captcha生成验证码(session巨坑),需要的朋友可以参考下,希望能帮助到大家。 首先,安装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都存储在其中,但是有点小麻烦,接下来本人介绍一种简单的方法,在你的laravelappHttpKernel.php 文件里的$middleware里加上以下代码: IlluminateFoundationHttpMiddlewareCheckForMaintenanceMode::class,
IlluminateCookieMiddlewareEncryptCookies::class,
IlluminateCookieMiddlewareAddQueuedCookiesToResponse::class,
IlluminateSessionMiddlewareStartSession::class,
IlluminateViewMiddlewareShareErrorsFromSession::class, 之后就可以放心的使用session了。这是在下的验证验证码的方式, public function login_data()
{
$userInput = Request::get('captcha');
if (Session::get('milkcaptcha') == $userInput) {
//用户输入验证码正确,验证你自己密码用户名
echo 1;
} else {
//用户输入验证码错误
echo 2;
}
}最后不得不吐槽一下laravel的官方文档,像这种坑都不提前说明,估计是担心开发者开发的太顺心了吧。 以上就是Laravel5.2使用Captcha生成验证码实现登录方法的详细内容,更多请关注php中文网其它相关文章! |