PHP实现阿里大鱼短信验证的实例代码

最近想实现PHP实现短信验证的效果,做PC网站的时候,可以通过注册用户需要使用短信验证的功能,或者找回密码,以及验证用户的信息等等功能,发现了阿里大鱼。留个笔记

第一步

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

第二步

在应用管理中选择SDK下载,或者直接点击下载,免费的哦亲

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

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

rush:java;"> namespace vendor\Alidayu;

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

第三步

可以写HTML了

rush:xhtml;">
用户长度不符合要求" />
rush:xhtml;">
rush:xhtml;">

第四步

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

rush:js;">

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

第五步

写入功能代码

$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();
}//获取验证码

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持编程之家。

相关文章

统一支付是JSAPI/NATIVE/APP各种支付场景下生成支付订单,返...
统一支付是JSAPI/NATIVE/APP各种支付场景下生成支付订单,返...
前言 之前做了微信登录,所以总结一下微信授权登录并获取用户...
FastAdmin是我第一个接触的后台管理系统框架。FastAdmin是一...
之前公司需要一个内部的通讯软件,就叫我做一个。通讯软件嘛...
统一支付是JSAPI/NATIVE/APP各种支付场景下生成支付订单,返...