基于laravel的验证码验证方式
2019-02-21 本文已影响0人
骆旺达
基于laravel的验证码验证方式
1、腾讯云手机短信验证
微信截图_20190224231654.png(1)登录腾讯云-云通信,办理好相关手续,及安装配置
1550737185450.pngsdk配置如下:
qcloudsms_php 采用 composer 进行安装,要使用 qcloudsms 功能,只需要在 composer.json 中添加如下依赖:
{
"require": {
"qcloudsms/qcloudsms_php": "0.1.*"
}
}
然后,更新composer,下载几分钟
composer update
(2)在.env配置文件中,添加如下参数
QCLOUD_SMS_APP_ID=短信备案appid
QCLOUD_SMS_APP_KEY=短信备案秘钥
QCLOUD_SMS_SIGN=短信备案短信签名
(3)在config文件夹中,创建sms.php文件,写入下面代码,用于返回.env中数据
<?php
return [
'app_id' => env('QCLOUD_SMS_APP_ID',''),
'app_key' => env('QCLOUD_SMS_APP_KEY',''),
'smsSign' => env('QCLOUD_SMS_SIGN','')
];
(4)在控制器中,新建控制函数
function SendMsg(Request $request){
// 参数1000-9999的随机数
$code = mt_rand(1000,9999);
$code = str_pad($code,4,0,STR_PAD_RIGHT);
$phone = $request->get('phone');
// 发送手机短信
try{
$this->sms = config('sms');
$sender = new SmsSingleSender($this->sms['app_id'],$this->sms['app_key']);
$templateId = '模板号';
$result = $sender->sendWithParam(
'86',
$phone,
$templateId,
[$code,"60"],
$this->sms['smsSign'],
"",
""
);
//返回发送结果
$rsp = json_decode($result,true);
if($rsp['result']==0){
return "{
\"status\":0,
\"result\":\"logo\"
}";
}else{
dd($rsp);
}
}catch (Exception $e){
return self::error(4025,$e);
}
}
(5) 创建路由,调用该函数发送短信
Route::any('SendMsg',['uses'=>'cbec@SendMsg']);
(6)前端代码
<div class="layui-inline iphone">
<div class="layui-input-inline">
<i class="layui-icon layui-icon-cellphone iphone-icon"></i>
<input type="tel" name="phone" id="phone" lay-verify="required|phone" placeholder="请输入手机号" autocomplete="off" class="layui-input">
</div>
</div>
<div class="layui-inline veri-code">
<div class="layui-input-inline">
<input id="pnum" type="text" name="pnum" lay-verify="required" placeholder="请输入验证码" autocomplete="off" class="layui-input">
<input type="button" class="layui-btn" id="find" value="验证码" />
</div>
</div>
</div>
(7)前端脚本代码
<script type="text/javascript">
layui.config({
base: 'static/js/util' //你存放新模块的目录,注意,不是layui的模块目录
}).use(['jquery','form'],function(){
var $ = layui.$,form = layui.form;
$("#find").click(function() {
if(!/^1\d{10}$/.test($("#phone").val())){
layer.msg("请输入正确的手机号");
return false;
}
var obj=this;
$.ajax({
type:"get",
url:"{{url('SendMsg')}}?phone="+$("#phone").val(),
dataType:"json",//返回的
success:function(data) {
if(data.result){
$("#find").addClass(" layui-btn-disabled");
$('#find').attr('disabled',"true");
settime(obj);
$("#msg").text(data.msg);
}else{
layer.msg(data.msg);
}
},
error:function(msg) {
console.log(msg);
}
});
})
var countdown=60;
function settime(obj) {
if (countdown == 0) {
obj.removeAttribute("disabled");
obj.classList.remove("layui-btn-disabled")
obj.value="获取验证码";
countdown = 60;
return;
} else {
obj.value="重新发送(" + countdown + ")";
countdown--;
}
setTimeout(function() {
settime(obj) }
,1000)
}
})
</script>
2、邮箱验证
微信截图_20190224231049.png(0)在.env中配置邮箱参数
MAIL_DRIVER=smtp
MAIL_HOST=smtp.163.com
MAIL_PORT=465
MAIL_USERNAME=163邮箱账号
MAIL_PASSWORD=163邮箱密码
MAIL_ENCRYPTION=ssl
(1)前端代码
<div class="layui-form-item">
<div style="display: inline-block;width: 15%;">邮箱</div>
<div style="display: inline-block;width: 80%;">
<input type="email" name="password" required lay-verify="required" placeholder="邮箱" value="{{$student['email']}}" autocomplete="off" class="layui-input" disabled="">
</div>
<button id="count" class="layui-btn layui-btn-xs" style="margin-left: 16%;margin-top: 1%;" onClick="click1();return false;">发送邮箱</button>
</div>
(2)前端脚本
var time = 30;
function click1(){
$.ajax({
url:'{{url('activation')}}',
data:"id="+"{{$student['id']}}&operate=1",
type:'post',
dataType:'text',
success:function(msg){
layui.use(['laypage', 'layer'], function() {var layer = layui.layer;
if(msg=='1'){
layer.alert("邮箱发送失败",{title:"Warning",icon:2});
}else if(msg=='2'){
alert("邮箱发送成功");
}
});
}
})
getRandomCode();
}
click1();
//倒计时
function getRandomCode() {
if (time === 0) {
time = 30;
$('#count').text("重新发送");
$("#count").removeAttr("disabled");
return ;
} else {
time--;
$('#count').text(time+"秒后重新发送");
$("#count").attr("disabled","disabled");
}
setTimeout(function () {
getRandomCode();
}, 1000);
}
(3)邮箱模板send_mail.blade.php
<html>
<style>
*{
font-family: 微软雅黑;
}
</style>
<body >
<div style="border:3px solid cornflowerblue;width: 96%;margin: auto auto;">
<div style="padding: 1% 1% 1% 1%;width: 98%;">
<h2>亲爱的{{ $user['user_name'] }}:</h2>
<div>
<p style="margin-left: 20px;">您好!很高兴您能使用我们提供的邮箱激活服务。</p>
<p style="margin-left: 20px">感谢您使用此服务,您的 <span style="font-size: 18px;color: red">验证信息为:{{$info}}</span></p>
<p style="margin-left: 20px">如果服务器尚未响应,一定要换个新版本浏览器再试试哦!</p>
</div>
</div>
</div>
</body>
</html>
(4) 发送邮箱
//发送邮箱
if($request->ajax()){
if($request->input("operate")==1){
//发送邮箱
$student = student_info::find(Session::get("user_id"));
$num = rand(1000,9999);
$email = $student->email;
$student->code = $num;
if($student->save()) {
Mail::send('send_mail',['user' => $student, 'info' => $num], function ($message) use ($email) {
$message->subject('HITSZ-哈尔滨工业大学邮箱激活');
$message->to($email);
});
return 2;
}else{
return 1;
}
}else{
//验证邮箱信息
$student = student_info::find(Session::get("user_id"));
if($student['code']==$request->input("code")&&$student['code']!="0"){
$student->role=1;
if($student->save()){
Session::put("login_ope",1);
Session::put("login_name",$student->user_name);
return 1;
}else{
return 2;
}
}else{
return 2;
}
}
}
3、普通验证
微信截图_20190224231002.png
(1)验证码自动生成
<?php
/**
* Created by PhpStorm.
* User: Administrator
* Date: 2017/5/20
* Time: 23:23
*/
session_start(); //必须处于程序的最顶部,会议管理
$image= imagecreatetruecolor(100,30); //定义一个长为100,宽为30px大小的图片(默认是黑色)
$bgcolor=imagecolorallocate($image,255,255,255); //定义白色的颜色参数,生成彩色像素
imagefill($image,0,0,$bgcolor); //把彩色像素填充进$image里面,
$captch_code=''; //预先定义captch_code,空字符串
for($i=0;$i<4;$i++){
$fontsize=6;
$fontcolor=imagecolorallocate($image,rand(0,120),rand(0,120),rand(0,120));
$data='0123456789'; //设立一个字典数组
$fontcontent=substr($data,rand(0,strlen($data)-1),1); //从substr方法,从字典数组从随机选取一个字符
$captch_code.=$fontcontent; //将验证信息拼接到$captch_code里面
$x=($i*100/4)+rand(5,10);
$y=rand(5,10);
imagestring($image,$fontsize,$x,$y,$fontcontent,$fontcolor);
}
//
$_SESSION['authcode']=$captch_code; //将验证信息保存在authcode里面
for($i=0;$i<200;$i++){ //设定图片有200个小点
$pointcolor=imagecolorallocate($image,rand(50,200),rand(50,200),rand(50,200));//设定点的颜色像素
imagesetpixel($image,rand(1,99),rand(1,29),$pointcolor); //将点内容添加到$image图片上,($image,$x,$y,填充颜色);
}
for($i=0;$i<3;$i++){ //设定图片有3条线
$linecolor=imagecolorallocate($image,rand(80,220),rand(80,220),rand(80,220)); //设线的颜色像素
imageline($image,rand(1,99),rand(1,29),rand(1,99),rand(1,29),$linecolor); //将线添加到图片上,($image,$x1,$y1,$x2,$y2,填充颜色);
}
header('content-type:image/png'); //输出图片格式content-type:image/png
imagepng($image);
imagedestroy($image);
(2)前台获取验证码
<div class="layui-form-item">
<div style="display: inline-block;width: 15%;vertical-align: middle">验证码</div>
<div style="display: inline-block;width: 40%;vertical-align: middle">
<input type="text" name="code" required lay-verify="required" placeholder="请输入验证码" autocomplete="off" class="layui-input">
</div>
<div style="display: inline-block;border: 1px solid #ccc;width: 25%;vertical-align: middle">
<img id="captch_img" src="{{url("auto_code?r=")}}<?php echo rand();?>" alt="">
</div>
<div style="display: inline-block;width: 10%;vertical-align: top">
<a href="javascript:void(0)" onclick="change()" style="margin-left: 10px;font-size: 30px;"><i class="layui-icon layui-icon-refresh-3"></i></a>
</div>
</div>
(3)验证码核对
public function auto_code(Request $request){
if ($request->isMethod("POST")){
session_start();
// 是否注册过账号
$test_user_id = student_info::where("user_id","=",$request->input("user_id"))->count();
if($test_user_id>0){
return 3;
}
// 验证码核对
if($_SESSION['authcode']==$request->input("code")){
return 2;
}else{
return 1;
}
}
return view("auto_code");
}