thinkPHP3.2.3实现阿里大于短信验证的方法
程序员文章站
2023-12-09 21:24:57
注册并登录阿里云
点击控制台后–>鼠标滑到你的用户名称(右边倒数第二个)–>点击accesskeys–>获取
点击控制台后–>产品与服务–&g...
注册并登录阿里云
点击控制台后–>鼠标滑到你的用户名称(右边倒数第二个)–>点击accesskeys–>获取
点击控制台后–>产品与服务–>云计算基础服务–>云通信–>短信服务
如果没有送测试短信签名和模板–>添加签名–>添加模板
下载sdk
https://help.aliyun.com/document_detail/55359.html?spm=5176.doc55451.6.569.0uxt4j
进入后选择php,会得到dysmsapi_demo_sdk__php.zip,解压得到下图目录
放置api
在tp根目录下创建文件夹api,并将api_sdk整个文件夹复制进去,改名dysms(可*取名)
引入api文件
在自己需要调用的控制器头部引入如下路径
use aliyun/core/config; use aliyun/core/profile/defaultprofile; use aliyun/core/defaultacsclient; use aliyun/api/sms/request/v20170525/sendsmsrequest;
8.正真的撸码现在开始
上源码:
/** * 数据处理 */ public function send_message(){ $phone=i("post.phone"); //查找是否已经注册 $user = d('user') -> where("user_phone = {$phone}") -> find(); if ($user) { echo "手机号已注册!"; }else{ $this->send_phone($phone); } // $this->ajaxreturn($data,"json"); } /** * 生成短信验证码 * @paraminteger $length [验证码长度] */ public function createsmscode($length = 4){ $min = pow(10 , ($length - 1)); $max = pow(10, $length) - 1; return rand($min, $max); } /** * 发送验证码 * @param[integer] $phone [手机号] */ public function send_phone($phone){ $code=$this->createsmscode($length = 4); require_once'./api/dysms/vendor/autoload.php';//此处为你放置api的路径 config::load();//加载区域结点配置 $accesskeyid = '换成自己的'; $accesskeysecret = '换成自己的'; $templatecode = '换成自己的'; //短信模板id //短信api产品名(短信产品名固定,无需修改) $product = "dysmsapi"; //短信api产品域名(接口地址固定,无需修改) $domain = "dysmsapi.aliyuncs.com"; //暂时不支持多region(目前仅支持cn-hangzhou请勿修改) $region = "cn-hangzhou"; // 初始化用户profile实例 $profile = defaultprofile::getprofile($region, $accesskeyid, $accesskeysecret); // 增加服务结点 defaultprofile::addendpoint("cn-hangzhou", "cn-hangzhou", $product, $domain); // 初始化acsclient用于发起请求 $acsclient = new defaultacsclient($profile); // 初始化sendsmsrequest实例用于设置发送短信的参数 $request = new sendsmsrequest(); // 必填,设置短信接收号码 $request->setphonenumbers($phone); // 必填,设置签名名称 $request->setsignname("换成自己的"); // 必填,设置模板code $request->settemplatecode("换成自己的"); $smsdata = array('code'=>$code);//所使用的模板若有变量 在这里填入变量的值我的变量名为username此处也为username //选填-假如模板中存在变量需要替换则为必填(json格式),友情提示:如果json中需要带换行符,请参照标准的json协议对换行符的要求,比如短信内容中包含/r/n的情况在json中需要表示成//r//n,否则会导致json在服务端解析失败 $request->settemplateparam(json_encode($smsdata)); //发起访问请求 $acsresponse = $acsclient -> getacsresponse($request); //返回请求结果 $result = json_decode(json_encode($acsresponse), true); $resp = $result['code']; $this->sendmsgresult($resp,$phone,$code); } /** * 验证手机号是否发送成功前端用ajax,发送成功则提示倒计时,如50秒后可以重新发送 * @param[json] $resp[发送结果] * @param[type] $phone [手机号] * @param[type] $code[验证码] * @return [type] [description] */ private function sendmsgresult($resp,$phone,$code){ if ($resp == "ok") { $data['phone']=$phone; $data['code']=$code; $data['send_time']=time(); $result=d("smsverif")->add($data); if($result){ $data="发送成功"; }else{ $data="发送失败"; } } else{ $data="发送失败"; } return $data; } /** * 验证短信验证码是否有效,前端用jquery validate的remote * @return [type] [description] */ public function checksmscode(){ $phone = $_post['phone']; $code = $_post['verify']; $nowtimestr = time(); $smscodeobj = d("smsverif")->where("phone={$phone} and code = {$code}")->find(); if($smscodeobj){ $smscodetimestr = $smscodeobj['send_time']; $recordcode = $smscodeobj['code']; $flag = $this->checktime($nowtimestr, $smscodetimestr); if($flag!=true || $code !== $recordcode){ echo 'no'; }else{ echo 'ok'; } } } /** * 验证验证码是否在可用时间 *@param[json] $nowtimestr[发送结果] * @param[type] $smscodetimestr [手机号] */ public function checktime ($nowtimestr,$smscodetimestr) { $time = $nowtimestr - $smscodetimestr; if ($time>900) { return false; }else{ return true; } }
在来点前端js码:
温馨提示:html还请诸君能自己发挥
代码有了,效果怎么可能没有呢!(实例是用户注册,我的手机号已经注册过了,所以效果是使用的找回密码)
到这里就ok了
总结
以上所述是小编给大家介绍的thinkphp3.2.3实现阿里大于短信验证的方法,希望对大家有所帮助