Heim >Backend-Entwicklung >PHP-Tutorial >thinkPHP3.2.3-Methode zur Implementierung der Alibaba-SMS-Überprüfung
In diesem Artikel wird hauptsächlich die Methode von thinkPHP3.2.3 zur Implementierung der Alibaba Cloud SMS-Überprüfung vorgestellt. Sie ist sehr gut und hat einen gewissen Referenzwert.
Registrieren und anmelden zu Alibaba Cloud
Nachdem Sie auf die Konsole geklickt haben –>Fahren Sie mit der Maus zu Ihrem Benutzernamen (der vorletzte auf der rechten Seite) –>Klicken Sie auf die Zugriffstasten –>Get
Nach dem Klicken auf die Konsole – >Produkte und Dienste–>Cloud Computing Basic Services–>Cloud Communications–>SMS-Dienst
Wenn keine Test-SMS-Signatur und -Vorlage gesendet werden –>Hinzufügen Signatur–>Vorlage hinzufügen
SDK herunterladen
Nach der Eingabe PHP auswählen, Sie erhalten dysmsapi_demo_sdk__php.zip, entpacken Sie es und erhalten Sie das folgende Verzeichnis
API platzieren
Erstellen Sie den Ordner Api im TP-Stammverzeichnis, kopieren Sie den gesamten Ordner api_sdk hinein und benennen Sie ihn in dysms um (Sie können ihn benennen). es frei)
Fügen Sie die API-Datei ein
Fügen Sie den folgenden Pfad im Kopf des Controllers ein, den Sie benötigen Anruf
use Aliyun/Core/Config; use Aliyun/Core/Profile/DefaultProfile; use Aliyun/Core/DefaultAcsClient; use Aliyun/Api/Sms/Request/V20170525/SendSmsRequest;
8. Zhengzhen-Codierung beginnt jetzt
Quellcode:
/** * 数据处理 */ 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; } }
Demnächst verfügbar Klicken Sie auf den Front-End-JS-Code:
Warme Erinnerung: Bitte verwenden Sie den HTML-Code selbst
Mit dem Code, wie kann das gehen? es wird nicht effektiv sein! (Das Beispiel ist die Benutzerregistrierung. Meine Mobiltelefonnummer wurde bereits registriert, daher wird das Passwort abgerufen.)
Das ist in Ordnung
Verwandte Themen Empfehlungen:
ThinkPHP-Implementierung der Alipay-Schnittstellenfunktion, Beispiel für Thinkphp
Das obige ist der detaillierte Inhalt vonthinkPHP3.2.3-Methode zur Implementierung der Alibaba-SMS-Überprüfung. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!