laravel5.5+使用mews/captcha扩展包实现验证码功能流程步骤
Laravel  /  管理员 发布于 3年前   1894
mews/captcha验证码扩展作为一个laravel框架中的常用扩展,非常方便的在你的网站上加上验证码功能。
git:
https://github.com/mewebstudio/captcha
git镜像:
https://gitcode.net/mirrors/mewebstudio/captcha
进入步骤:
1、通过 composer 安装验证码包
composer require mews/captcha
2、配置
在 config/app.php 中 找到 aliases 数组加入以下代码
'Captcha' => Mews\Captcha\CaptchaServiceProvider::class,
3、生成配置文件
在 Composer 里执行以下命令,如果弹出选项,选择到 config,
我的 config 的 tag 是 11,输入 11 后回车,然后就会在 config 文件夹里生成配置文件;
配置文件里的 length 是生成验证码多少位。
php artisan vendor:publish
4、控制器生成验证码
public function codes()
{
return response()->json([
'code' => \captcha_src() //返回前端图像验证码
]);
}
5、验证码验证
if(!captcha_check($params['code'])){
return Response()->json(['code' => 201, 'msg' => '验证码有误']);
}
6、前端调用使用验证码
<img src="{{captcha_src()}}">
ps:
如果是用的 vue.js 可以这样
/*html部分*/
<img class="codeImg" :src="urlCode" style="cursor: pointer" @click="getCode">
/*js部分*/
<script>
new Vue({
el: '.main',
data: {
urlCode:"",
},
created(){
this.getCode();
},
methods: {
getCode(){
let domain = document.domain;
$.get('http://'+domain+'/getCode',(res)=>{
this.urlCode =res.code;
})
},
goLogin(){
document.onkeyup = (event) => {
let e = event || window.event;
if(e && e.keyCode==13){
//执行登录
}
};
},
}
})
</script>
问题:
1.很多情况下验证码只显示了一半,如何调整?
答:自定义配置验证码样式
return app('captcha')->create('zongscan', true)
config/captcha 参数配置:
'zongscan' => [
'length' => 4,
'width' => 100,
'height' => 38,
'quality' => 90,
'lines' => 6,
'bgImage' => false,
'bgColor' => '#ecf2f4',
'fontColors' => ['#2c3e50', '#c0392b', '#16a085', '#c0392b', '#8e44ad', '#303f9f', '#f57c00', '#795548'],
'contrast' => -5,
]
122 在
学历:一种延缓就业设计,生活需求下的权衡之选中评论 工作几年后,报名考研了,到现在还没认真学习备考,迷茫中。作为一名北漂互联网打工人..123 在
Clash for Windows作者删库跑路了,github已404中评论 按理说只要你在国内,所有的流量进出都在监控范围内,不管你怎么隐藏也没用,想搞你分..原梓番博客 在
在Laravel框架中使用模型Model分表最简单的方法中评论 好久好久都没看友情链接申请了,今天刚看,已经添加。..博主 在
佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 @1111老铁这个不行了,可以看看近期评论的其他文章..1111 在
佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 网站不能打开,博主百忙中能否发个APP下载链接,佛跳墙或极光..
Copyright·© 2019 侯体宗版权所有·
粤ICP备20027696号