【PHP】呼叫阿里大魚簡訊驗證
阿新 • • 發佈:2018-11-09
1.第一步
登陸阿里大於註冊賬號,在使用者管理中心建立應用,確定AppKEY和App Secret還有配置簽名
2.第二步
在應用管理中選擇SDK下載,或者直接點選http://download.csdn.net/detail/s371795639/9695983下載,免費的哦親
把下載好的資源解壓放到ThinkPHP\Library\Vendor目錄下如圖
第三步 可以寫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="手機號碼" onblur="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(); }//獲取驗證碼