最近想實現PHP實現簡訊驗證的效果,做PC網站的時候,可以透過註冊用戶需要使用簡訊驗證的功能,或是找回密碼,以及驗證用戶的資訊等等功能。本文主要和大家介紹PHP實現阿里大魚簡訊驗證的實例代碼的相關資料,具有一定的參考價值,有興趣的小伙伴們可以參考一下,希望能幫助到大家。
第一步
登陸阿里大於註冊帳號,在使用者管理中心建立應用,確定AppKEY和App Secret還有設定簽章
第二步
在應用程式管理中選擇SDK下載,或者直接點選http://www.jb51.net/softs/312325.html下載,免費的哦親
把下載好的資源解壓縮放到ThinkPHP\Library\Vendor目錄下如圖
並不是所有的php檔案都需要,就用如圖所示Alidayu資料夾下那幾個php文件,把Alidayu裡面的php檔案分別打開,在開始的一行添加代碼(如果你下載的來自我發送的鏈接,那就沒必要添加這個代碼了,因為我添加過了)
namespace Vendor\Alidayu;
目的是為了在呼叫的時候不至於引入失敗
第三步
可以寫HTML了
<p class="form-group"> <p 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> </p> </p>
<p class="form-group"> <p class="field field-icon-right"> <input id="mobile" type="tel" class="input" name="mobile" placeholder="手机号码" onblur="checkmobile(this)" /> <span class="icon icon-mobile"></span> </p> </p>
<button id="sendmsg">获取验证码</button>
第四個步驟
寫入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(); }//获取验证码
相關推薦:
以上是PHP實作阿里簡訊驗證方法程式碼的詳細內容。更多資訊請關注PHP中文網其他相關文章!