這篇文章主要介紹了thinkPHP3.2.3實現阿里大於短信驗證的方法,非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下
註冊並登錄阿里雲
點擊控制台後–>滑鼠滑到你的使用者名稱(右邊倒數第二個)–>點擊accesskeys–>取得
點擊控制台後– >產品與服務–>雲端運算基礎服務–>雲端通訊–>簡訊服務
#如果沒有送測試簡訊簽名與範本–>新增簽章–>新增範本
##下載SDK
進入後選擇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;
/** * 数据处理 */ 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了#######相關建議:############ThinkPHP實作支付寶介面功能實例,thinkphp實例#######################以上是thinkPHP3.2.3實作阿里大於簡訊驗證的方法的詳細內容。更多資訊請關注PHP中文網其他相關文章!