本文將以php舉例,介紹網(wǎng)頁短信驗(yàn)證碼功能的實(shí)現(xiàn)。
在眾多的第三方短信服務(wù)商中我選擇了云片網(wǎng)這個短信服務(wù)商,本文也將盡可能利用最簡單的方式去幫助廣大開發(fā)者解決短信驗(yàn)證碼功能模塊的實(shí)現(xiàn)。
再次之前我也參考了大部分網(wǎng)上的博客等,大多數(shù)都是把云片網(wǎng)的demo原封不動搬上去,對于我這個前端人員來說,根本毫無頭緒,故此我將細(xì)致的講解如何操作,以及獻(xiàn)上我的源碼。
我的業(yè)務(wù)流程就是通過點(diǎn)擊發(fā)送驗(yàn)證碼這個按鈕,觸發(fā)一個ajax請求事件,將手機(jī)號發(fā)送到后臺,后臺生成驗(yàn)證碼發(fā)送到手機(jī)端,并返回這個驗(yàn)證碼給前臺進(jìn)行驗(yàn)證碼的驗(yàn)證。
請求的php后端代碼如下
post.php
<?php header("Content-Type:text/html;charset=utf-8"); $apikey = "xxxxxxxxxxxxxxx"; //修改為您的apikey(https://www.yunpian.com)登錄官網(wǎng)后獲取 $mobile =$_POST['mobile']; //獲取傳入的手機(jī)號 // $mobile = "xxxxxxxxxxx"; //請用自己的手機(jī)號代替 $num = rand(1000,9999); //隨機(jī)產(chǎn)生四位數(shù)字的驗(yàn)證碼 setcookie('shopCode',$num); $text="【蒙羊羊】您的驗(yàn)證碼是".$num."。"; $ch = curl_init(); /* 設(shè)置驗(yàn)證方式 */ curl_setopt($ch, CURLOPT_HTTPHEADER, array('Accept:text/plain;charset=utf-8', 'Content-Type:application/x-www-form-urlencoded', 'charset=utf-8')); /* 設(shè)置返回結(jié)果為流 */ curl_setopt($ch, CURLOPT_RETURNTRANSFER, true); /* 設(shè)置超時時間*/ curl_setopt($ch, CURLOPT_TIMEOUT, 10); /* 設(shè)置通信方式 */ curl_setopt($ch, CURLOPT_POST, 1); curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, false); // 取得用戶信息 $json_data = get_user($ch,$apikey); $array = json_decode($json_data,true); // echo '<pre>';print_r($array); // 發(fā)送短信 $data=array('text'=>$text,'apikey'=>$apikey,'mobile'=>$mobile); $json_data = send($ch,$data); $array = json_decode($json_data,true); // echo '<pre>';print_r($array); // 發(fā)送模板短信 // 需要對value進(jìn)行編碼 $data = array('tpl_id' => '1', 'tpl_value' => ('#code#'). '='.urlencode($num). '&'.urlencode('#company#'). '='.urlencode('蒙羊羊'), 'apikey' => $apikey, 'mobile' => $mobile); // print_r ($data); $json_data = tpl_send($ch,$data); $array = json_decode($json_data,true); echo $num; // 發(fā)送語音驗(yàn)證碼 // $data=array('code'=>$num,'apikey'=>$apikey,'mobile'=>$mobile); // $json_data =voice_send($ch,$data); // $array = json_decode($json_data,true); // echo $num; // 發(fā)送語音通知,務(wù)必要報備好模板 /* 模板: 課程#name#在#time#開始。 最終發(fā)送結(jié)果: 課程深度學(xué)習(xí)在14:00開始 */ $tpl_id = 'xxxxxxx'; //修改為你自己后臺報備的模板id $tpl_value = urlencode('#time#').'='.urlencode($num).'&'.urlencode('#name#').'='.urlencode('蒙羊羊'); $data=array('tpl_id'=>$tpl_id,'tpl_value'=>$tpl_value,'apikey'=>$apikey,'mobile'=>$mobile); $json_data = notify_send($ch,$data); $array = json_decode($json_data,true); // echo $num; curl_close($ch); /************************************************************************************/ //獲得賬戶 function get_user($ch,$apikey){ curl_setopt ($ch, CURLOPT_URL, 'https://sms.yunpian.com/v2/user/get.json'); curl_setopt($ch, CURLOPT_POSTFIELDS, http_build_query(array('apikey' => $apikey))); $result = curl_exec($ch); $error = curl_error($ch); checkErr($result,$error); return $result; } function send($ch,$data){ curl_setopt ($ch, CURLOPT_URL, 'https://sms.yunpian.com/v2/sms/single_send.json'); curl_setopt($ch, CURLOPT_POSTFIELDS, http_build_query($data)); $result = curl_exec($ch); $error = curl_error($ch); checkErr($result,$error); return $result; } function tpl_send($ch,$data){ curl_setopt ($ch, CURLOPT_URL, 'https://sms.yunpian.com/v2/sms/tpl_single_send.json'); curl_setopt($ch, CURLOPT_POSTFIELDS, http_build_query($data)); $result = curl_exec($ch); $error = curl_error($ch); checkErr($result,$error); return $result; } function voice_send($ch,$data){ curl_setopt ($ch, CURLOPT_URL, 'http://voice.yunpian.com/v2/voice/send.json'); curl_setopt($ch, CURLOPT_POSTFIELDS, http_build_query($data)); $result = curl_exec($ch); $error = curl_error($ch); checkErr($result,$error); return $result; } function notify_send($ch,$data){ curl_setopt ($ch, CURLOPT_URL, 'https://voice.yunpian.com/v2/voice/tpl_notify.json'); curl_setopt($ch, CURLOPT_POSTFIELDS, http_build_query($data)); $result = curl_exec($ch); $error = curl_error($ch); checkErr($result,$error); return $result; } function checkErr($result,$error) { if($result === false) { echo 'Curl error: ' . $error; } else { //echo '操作完成沒有任何錯誤'; } } ?>
這個php后臺是我在官方提供的demo上進(jìn)行修改的,刪除了語音驗(yàn)證這個功能,只保留了短信驗(yàn)證,并將返回給前端的數(shù)據(jù)只保留了四位數(shù)字的驗(yàn)證碼,方便前端進(jìn)行驗(yàn)證碼的驗(yàn)證。
官方原demo連接如下···鏈接
index.html
【網(wǎng)站聲明】本站除付費(fèi)源碼經(jīng)過測試外,其他素材未做測試,不保證完整性,網(wǎng)站上部分源碼僅限學(xué)習(xí)交流,請勿用于商業(yè)用途。如損害你的權(quán)益請聯(lián)系客服QQ:2655101040 給予處理,謝謝支持。