基于ThinkPHP与阿里大于的PHP短信验证功能

基于ThinkPHP与阿里大于的PHP短信验证功能

https://blog.csdn.net/s371795639/article/details/53381274

PHP阿里大鱼短信验证

第一步

登陆阿里大于注册账号,在用户管理中心创建应用,确定AppKEY和App Secret还有配置签名

基于ThinkPHP与阿里大于的PHP短信验证功能基于ThinkPHP与阿里大于的PHP短信验证功能

第二步

在应用管理中选择SDK下载,或者直接点击http://download.csdn.net/detail/s371795639/9695983下载,免费的哦亲

把下载好的资源解压放到ThinkPHP\Library\Vendor目录下如图 

基于ThinkPHP与阿里大于的PHP短信验证功能基于ThinkPHP与阿里大于的PHP短信验证功能
并不是所有的php文件都需要,就用如图所示Alidayu文件夹下那几个php文件,把Alidayu里面的php文件分别打开,在开始的一行添加代码(如果你下载的来自我发的链接,那就没必要添加这个代码了,因为我添加过了)

namespace Vendor\Alidayu;

目的是为了在调用的时候不至于引入失败

第三步

可以写HTML了

<div class="form-group">
    <div class="field field-icon-right">
        <input type="text" id="admin" class="input" name="admin" placeholder="用户名" data-validate="required:请填写用户名,length#>=5:用户长度不符合要求"  />
        <span class="icon icon-user"></span>
    </div>
</div>

 

<div class="form-group">
    <div class="field field-icon-right">
        <input id="mobile" type="tel" class="input" name="mobile" placeholder="手机号码" οnblur="checkmobile(this)"  />
        <span class="icon icon-mobile"></span>
    </div>
</div>

 

 <span class="x4" style="text-align: center;vertical-align: middle">
   <button id="sendmsg">获取验证码</button>
</span>

第四步

写入JQ代码(功能是,发送验证码后倒计时,并且POST传递后台,后台返回的数据0,1,2分别对应不同的功能)这段代码是参考别人的


<script >

    /*-------------------------------------------*/
    var InterValObj; //timer变量,控制时间
    var count = 60; //间隔函数,1秒执行
    var curCount;//当前剩余秒数
    var code = ""; //验证码
    var codeLength = 6;//验证码长度

    $(function () {
        $('#sendmsg').click(function () {
            $.ajax({
                type: "POST",
                url: "/User/folder/child/obtainyzm",
                data: "admin=" + $('#admin').val()+"&mobile="+$("#mobile").val() ,
                success: function (result) {
                   if(result==0){
                       curCount = count;
                       //设置button效果,开始计时
                       $("#sendmsg").css("background-color", "LightSkyBlue");
                       $("#sendmsg").attr("disabled", "true");
                       $("#sendmsg").val("获取" + curCount + "秒");
                       InterValObj = window.setInterval(SetRemainTime, 1000); //启动计时器,1秒执行一次
                      // alert("验证码发送成功,请查收!");
                   }
                    if(result==1){

                        alert("用户名和手机号不匹配!");
                    }
                    if(result==2){

                        alert("用户名不存在!");
                    }

                },
                dataType: 'json'

            })
        })
    })

    function SetRemainTime() {

        if (curCount == 0) {
            window.clearInterval(InterValObj);//停止计时器
            $("#sendmsg").removeAttr("disabled");//启用按钮
            $("#sendmsg").css("background-color", "");
            $("#sendmsg").val("重发验证码");
            code = ""; //清除验证码。如果不清除,过时间后,输入收到的验证码依然有效
        }
        else {
            curCount--;
            $("#sendmsg").val("获取" + curCount + "秒");
        }
    }
</script>

上面有两个参数admin和mobile分别代表用户名和手机号码。

第五步

写入功能代码


public function obtainyzm(){

    $mobile = $_POST['mobile'];//获取手机号码
    $admin =$_POST['admin'];//获取用户名

    $user = M('db_admin')->where(array('admin'=>$admin))->find();

    /************引入*************/
    Vendor('Alidayu.TopClient');
    Vendor('Alidayu.AlibabaAliqinFcSmsNumSendRequest');
    Vendor('Alidayu.ResultSet');
    Vendor('Alidayu.RequestCheckUtil');

    $c = new \Vendor\Alidayu\TopClient;
    $req = new \Vendor\Alidayu\AlibabaAliqinFcSmsNumSendRequest;

    /*************配置***************/
    $code = randCode(4);//随机验证码
    $c->appkey = '23******';
    $c->secretKey = '6f73a******************';
    $req->setSmsType("normal");
    $req->setSmsFreeSignName("xx的测试");
    $req->setSmsParam("{code:'$code'}");
    $req->setRecNum("$mobile");
    $req->setSmsTemplateCode("SMS_3******");

    if($user)
    {
        if($user['mobile'] == $mobile)
        {
            /*************发送验证码短信,并把验证码作为新密码保存到服务器上***************/
           //$c->execute($req);  //不要开启,开启后就会有短信到账,一次几分钱..在服务器上看新密码就好
            $newpwd['pwd'] = md5($code);
            D('db_admin')->where(array('admin'=>$user['admin']))->save($newpwd);
            $this->ajaxreturn(0);//用户名密码匹配
        }
        else
        {
            $this->ajaxreturn(1);//用户名和手机号不匹配
        }
    }
    else
    {
        $this->ajaxreturn(2); //用户名不存在
    }
    $this->display();
}//获取验证码

谢谢观看,有什么不懂的可以留言~

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/113197.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 3500元计算机基本硬件配置清单,电脑硬件中配配置清单

    3500元计算机基本硬件配置清单,电脑硬件中配配置清单电脑硬件中配配置清单导语:攒机一直是电脑爱好者热衷的事,自己选购各配件,组装一台适合自己要求的机器给很多DIYer带来了极大的欢乐。下面小编为你整理的电脑硬件中配配置清单,希望对你有所帮助!电脑硬件中配配置清单1、实用性机型建议:首选1:intelG1620双核+H61M主板。(价格低廉性能不弱,超值!)首选2:intelG1840双核+H81M主板。(核心显卡性能比G1620更强)2、中级机…

    2022年7月12日
    12
  • NDK学习笔记:线程JNIEnv,JavaVM,JNI_OnLoad(GetEnv返回NULL?FindClass返回NULL?)

    NDK学习笔记:线程JNIEnv,JavaVM,JNI_OnLoad 此文章是关于NDK线程的第二篇理论知识笔记。主要有两个点,如下:pthread_create(Toomanyarguements,expected1)? 线程中如何获取JNIEnv?GetEnv返回NULL? FindClass返回NULL?首先我们在主页MainActivity的代码如下:p…

    2022年4月15日
    132
  • Java学习之爬虫篇

    Java学习之爬虫篇0x00前言总结完基础阶段,来写个爬虫练练手,从中能学到不少。0x01爬虫结构与概念爬虫更官方点的名字叫数据采集,英文一般称作spider,就是通过编程来全自动的从互联

    2021年12月12日
    55
  • B站上适合程序员的学习资源【赶紧收藏!】

    B站上适合程序员的学习资源【赶紧收藏!】

    2022年2月11日
    36
  • RSA 加密算法原理简述

    RSA 加密算法原理简述概述本文旨在说明RSA加密算法的原理及实现,而其相关的数学部分的证明则不是本文内容。版权说明著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。作者:Q-WHai发表日期:2016年2月29日本文链接:http://blog.csdn.net/lemon_tree12138/article/details/50696926来源:CSDN…

    2022年6月12日
    23
  • navicat12激活码在线生成(JetBrains全家桶)

    (navicat12激活码在线生成)好多小伙伴总是说激活码老是失效,太麻烦,关注/收藏全栈君太难教程,2021永久激活的方法等着你。IntelliJ2021最新激活注册码,破解教程可免费永久激活,亲测有效,下面是详细链接哦~https://javaforall.net/100143.html1STL5S9V8F-eyJsaWNlbnNlSWQi…

    2022年3月27日
    115

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号