thinkPHP3.2.3實現(xiàn)阿里大于短信驗證的方法
注冊并登錄阿里云
點擊控制臺后–>鼠標滑到你的用戶名稱(右邊倒數(shù)第二個)–>點擊accesskeys–>獲取
點擊控制臺后–>產(chǎn)品與服務(wù)–>云計算基礎(chǔ)服務(wù)–>云通信–>短信服務(wù)
如果沒有送測試短信簽名和模板–>添加簽名–>添加模板
下載SDK
https://help.aliyun.com/document_detail/55359.html?spm=5176.doc55451.6.569.0uXt4J
進入后選擇PHP,會得到dysmsapi_demo_sdk__php.zip,解壓得到下圖目錄
放置API
在TP根目錄下創(chuàng)建文件夾Api,并將api_sdk整個文件夾復(fù)制進去,改名dysms(可自由取名)
引入API文件
在自己需要調(diào)用的控制器頭部引入如下路徑
use Aliyun/Core/Config; use Aliyun/Core/Profile/DefaultProfile; use Aliyun/Core/DefaultAcsClient; use Aliyun/Api/Sms/Request/V20170525/SendSmsRequest;
8.正真的擼碼現(xiàn)在開始
上源碼:
/** * 數(shù)據(jù)處理 */ public function send_message(){ $phone=I("post.phone"); //查找是否已經(jīng)注冊 $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); } /** * 發(fā)送驗證碼 * @param[integer] $phone [手機號] */ public function send_phone($phone){ $code=$this->createSMSCode($length = 4); require_once'./Api/dysms/vendor/autoload.php';//此處為你放置API的路徑 Config::load();//加載區(qū)域結(jié)點配置 $accessKeyId = '換成自己的'; $accessKeySecret = '換成自己的'; $templateCode = '換成自己的'; //短信模板ID //短信API產(chǎn)品名(短信產(chǎn)品名固定,無需修改) $product = "Dysmsapi"; //短信API產(chǎn)品域名(接口地址固定,無需修改) $domain = "dysmsapi.aliyuncs.com"; //暫時不支持多Region(目前僅支持cn-hangzhou請勿修改) $region = "cn-hangzhou"; // 初始化用戶Profile實例 $profile = DefaultProfile::getProfile($region, $accessKeyId, $accessKeySecret); // 增加服務(wù)結(jié)點 DefaultProfile::addEndpoint("cn-hangzhou", "cn-hangzhou", $product, $domain); // 初始化AcsClient用于發(fā)起請求 $acsClient = new DefaultAcsClient($profile); // 初始化SendSmsRequest實例用于設(shè)置發(fā)送短信的參數(shù) $request = new SendSmsRequest(); // 必填,設(shè)置短信接收號碼 $request->setPhoneNumbers($phone); // 必填,設(shè)置簽名名稱 $request->setSignName("換成自己的"); // 必填,設(shè)置模板CODE $request->setTemplateCode("換成自己的"); $smsData = array('code'=>$code);//所使用的模板若有變量 在這里填入變量的值我的變量名為username此處也為username //選填-假如模板中存在變量需要替換則為必填(JSON格式),友情提示:如果JSON中需要帶換行符,請參照標準的JSON協(xié)議對換行符的要求,比如短信內(nèi)容中包含/r/n的情況在JSON中需要表示成//r//n,否則會導(dǎo)致JSON在服務(wù)端解析失敗 $request->setTemplateParam(json_encode($smsData)); //發(fā)起訪問請求 $acsResponse = $acsClient -> getAcsResponse($request); //返回請求結(jié)果 $result = json_decode(json_encode($acsResponse), true); $resp = $result['Code']; $this->sendMsgResult($resp,$phone,$code); } /** * 驗證手機號是否發(fā)送成功前端用ajax,發(fā)送成功則提示倒計時,如50秒后可以重新發(fā)送 * @param[json] $resp[發(fā)送結(jié)果] * @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="發(fā)送成功"; }else{ $data="發(fā)送失敗"; } } else{ $data="發(fā)送失敗"; } 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[發(fā)送結(jié)果] * @param[type] $smsCodeTimeStr [手機號] */ public function checkTime ($nowTimeStr,$smsCodeTimeStr) { $time = $nowTimeStr - $smsCodeTimeStr; if ($time>900) { return false; }else{ return true; } }
在來點前端js碼:
溫馨提示:html還請諸君能自己發(fā)揮
代碼有了,效果怎么可能沒有呢?。▽嵗怯脩糇?,我的手機號已經(jīng)注冊過了,所以效果是使用的找回密碼)
到這里就OK了
總結(jié)
以上所述是小編給大家介紹的thinkPHP3.2.3實現(xiàn)阿里大于短信驗證的方法,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
相關(guān)文章
PHP網(wǎng)頁游戲?qū)W習之Xnova(ogame)源碼解讀(一)
這篇文章主要介紹了PHP網(wǎng)頁游戲Xnova(ogame)源碼解讀,需要的朋友可以參考下2014-06-06php下獲取Discuz論壇登錄用戶名、用戶組、用戶ID等信息的實現(xiàn)代碼
前面有一篇文章講過自己從cookie和discuz數(shù)據(jù)庫中取用戶名、用戶組、用戶ID等信息,但那個并不一定準確,因為discuz登錄時會使用COOKIE中的auth值來動態(tài)登錄,而cookie信息是滯后的,所以獲取到的信息并不完全準確。2010-12-12