laravel后台验证关于验证码

1.进行验证码的依赖安装
进入packagist网站进行依赖的下载
进入后搜索captcha,会有如下显示
在这里插入图片描述
我们使用第二个,点进去,查看里面的内容
在这里插入图片描述
这里会要求我们的php版本在7.2以上
在这里插入图片描述
这里我们通过命令行进行安装
安装成功后会有如下显示
在这里插入图片描述
接着我们进行使用
在这里插入图片描述
如上图所示
<1>首先需要在app.php中注册验证码程序
在providers中编写
在这里插入图片描述
<2>设置别名,如图所示
在这里插入图片描述
<3>定义自己的配置
在命令行里面进行配置
php artisan vender:publish

2.在视图中进行验证码的编写

验证码:<input type="text" name="captcha" value="" placeholder="验证码"/>
      <img src="{{captcha_src()}}"/><br/>

其中,captcha_src()引入的是随机生成图片的路径
3.在控制器中的方法中添加验证码的验证规则
在这里需要注意的是

'captcha'=>'required|captcha'

第二个captcha表示的是验证规则,在laravel手册里面没有这验证规则,但是在这个依赖包中规定了验证码的验证规则为captcha
因此·我们需要在validation.php中进行数据的更改
在attributes中设置属性在这里插入图片描述
以及设置验证规则
在这里插入图片描述

在这里插入图片描述

生成如果所示。此外还有就是我们需要在点击图片时随机切换验证码,因此需要进行js编写
我们需要进行java包的导入
https://php-acad.28sjw.com/Statics/Assets/js/jquery.min-3.2.1.js
接下来我们进行编写

<script type="text/javascript" src="https://php-acad.28sjw.com/Statics/Assets/js/jquery.min-3.2.1.js">
<script>
  $(function(){
     var url=$('img').attr('src');
    $('img').click(function(){
       $(this).attr('src',url+Math.random());
    })
})
<script>

这样我们就可以进行点击图片的时候进行验证码的切换

随机生成6位图片验证码. /// <summary> /// PicHandler1 的摘要说明 /// </summary> public class PicHandler1 : IHttpHandler, IRequiresSessionState { private string mCheckNo = string.Empty; protected ImgBuilder _ImgBuilder = new ImgBuilder(); protected VryImgGen _ImgBuilderNew = new VryImgGen(); private string _text = string.Empty; private string _font = "宋体"; private int _fontSize = 8; private int _padding = 2; public void ProcessRequest(HttpContext context) { mCheckNo = DisCheckNo(); context.Session["CheckCode"] = mCheckNo; this._ImgBuilder.FontSize = this._fontSize; this._ImgBuilder.Padding = this._padding; if (!string.IsNullOrEmpty(this._font)) { this._ImgBuilder.Fonts = new string[] { this._font }; } this._ImgBuilderNew.ChaosWight = 40; this._ImgBuilderNew.FontSize = 25; this._ImgBuilderNew.Padding = 3; System.Drawing.Bitmap image = this._ImgBuilderNew.CreateImage(mCheckNo); System.IO.MemoryStream ms = new System.IO.MemoryStream(); image.Save(ms, System.Drawing.Imaging.ImageFormat.Jpeg); context.Response.ClearContent(); context.Response.ContentType = "image/Jpeg"; context.Response.BinaryWrite(ms.ToArray()); context.Session["CheckCode"] = mCheckNo.ToString(); //如果没有实现IRequiresSessionState,则这里会出错,也无法生成图片 context.Response.End(); } //验证码生成 protected string DisCheckNo() { string hash = HashCode.GetNext(); string CheckNo = string.Empty; Random rd = new Random(DateTime.Now.Millisecond); for (int i = 0; i < 6; i++) { CheckNo += hash.Substring(rd.Next(1, hash.Length - 1), 1); } CheckNo = CheckNo.Replace("0", rd.Next(1, 9).ToString()); CheckNo = CheckNo.Replace("o", rd.Next(1, 9).ToString());
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值