欧类av怡春院_久久久久成人网站_亚洲国产一区在线_免费在线观看污_97热在线精品视频在线观看_久久久久久色_涩涩涩999_免费不卡欧美自拍视频_亚洲精品国产无天堂网2021_中文字幕av专区_欧美成va人片在线观看_精品视频第一页


待發短信

在線客服
產品支持 短信寶客服
合作渠道 渠道合作
服務咨詢

4001-021-502

工作時間

9:00-21:00

短信寶短信驗證碼開發教程 – 2.準備篇


現在跟著我一起來做短信驗證碼開發前的準備工作,工作需要完成以下幾點:定義目錄結構。使用html+css對案例的頁面進行布局。創建配置文件。編寫開發中的幫助文件和數據驗證文件。好了,開工!!

目錄結構定義工作: 

先創建目錄,需要一個項目目錄,配置文件目錄,js文件目錄,字體文件目錄,工具文件目錄。定義完成的目錄結構如下: 

sms — 項目目錄 

sms/config — 配置文件目錄 

sms/js — javascript文件目錄 

sms/font — 字體文件目錄 

sms/tool — 工具文件目錄

使用html+css對案例的頁面進行布局: 

在項目目錄sms下創建register.php文件,用于模擬用戶注冊的界面。其代碼如下:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <style>
        * {margin:0; padding:0;}
        h1 {margin:30px 0 25px 0;}
        .form-input {margin-bottom:10px;}
        .form-input input {width:200px; height:25px;}
        .form-input button {width:60px; height:25px;}
        #main {width:500px; margin:0 auto;}
        #vcode {width:80px;}

        #phone_code {width:80px;}
        .code_label {position:relative;}
        .code_label img {position:absolute; top:-5px; left:185px; cursor: pointer;}
        .code_label button {width:90px; cursor: pointer;}
    </style>
    <script src="js/jquery.js"></script>
</head>
<body>
<div id="main">
    <h1>用戶注冊</h1>
    <form method="post" action="register.php">
        <div class="form-input">
            <label>
                手機號碼&emsp;
                <input type="text" name="phone" value=""/>
                <p id="phone_err" class="errmsg" style="margin:5px 0 0 88px; color:red;"></p>
            </label>
        </div>
        <div class="form-input">
            <label>
                密&emsp;&emsp;碼&emsp;
                <input type="password" name="password" value=""/>
                <p id="phone_err" class="errmsg" style="margin:5px 0 0 88px; color:red;"></p>
            </label>
        </div>
        <div class="form-input">
            <label>
                確認密碼&emsp;
                <input type="password" name="repassword" value=""/>
            </label>
        </div>

        <div class="form-input">
            <label class="code_label">
                驗&ensp;證&ensp;碼&emsp;
                <input id="vcode" type="text" name="vcode" value=""/>
                <img id="code_img" src=""/>
                <p id="code_err" class="errmsg" style="margin:5px 0 0 88px; color:red;"></p>
            </label>
        </div>
        <div class="form-input">
            <label class="code_label">
                手機驗證碼
                <input id="phone_code" type="text" name="code" value=""/>
                <button type="button" id="get_code">獲取驗證碼</button>
                <p id="phone_err" class="errmsg" style="margin:5px 0 0 88px; color:red;"></p>
            </label>
        </div>
        <input type="hidden" name="is_send" value="1"/>
        <div class="form-input">
            <label>
                <button type="submit">提 交</button>
            </label>
        </div>
    </form>
</div>

</body>
</html>

js文件和字體文件: 

在sms/js目錄中添加jquery庫文件,在sms/font目錄中添加consola.ttf字體文件。這2個文件在我代碼案例中已經提供,可以拿來直接使用。也可以到網上去下載。

配置文件的使用: 

在sms/config目錄下創建config.php這個配置文件,并且在文件中配置自己的短信接口賬號和密碼,在案例中使用的是短信寶的接口,所以直接配置短信寶的賬號密碼就好了。
如果沒有短信寶的賬號和面,可以去他們的官網注冊一個,注冊還免費送短信哦。配置的代碼如下:

<?php
return array(
    'smsbao_name' => '您的短信寶賬號',
    'smsbao_password' => '您的短信寶密碼', 
);

 

工具文件創建: 

這里我們需要創建1個工具文件,用于驗證填寫的模擬注冊信息是否正確的。 

在sms/tool目錄下創建CheckTool.php 用于負責數據驗證,代碼如下:

<?php
class CheckTool
{
    /**
     * @var array 錯誤提示代碼
     */
    private static $errArr = array(
        0 => '用戶名不得為空',
        1 => '密碼不能為空',
        2 => '2次輸入的密碼不一致',
        3 => '手機驗證碼不正確',
        4 => '驗證碼不得為空',
        5 => '驗證碼填寫不正確',
        6 => '手機號碼格式不正確',
        7 => '手機號碼必須填寫',
        8 => '請先獲取短信驗證碼',
        9 => '短信驗證碼不正確',
        10 => '密碼不得少于6位數',
        11 => '驗證的手機號碼和當前的手機號碼不一致'
    );

    /**
     * 數據執行驗證的總接口
     * @param $data
     * @return bool
     */
    public static function exec($data)
    {
        $errType['phone'] = self::checkPhone($data['phone']);
        $errType['password'] = self::checkPassword($data['password'], $data['repassword']);
        $errType['code'] = self::checkSmsCode($data['code']);

        return self::checkErr($errType);
    }

    /**
     * 返回錯誤碼,如果驗證沒有錯誤,則返回true
     * @param $errorData
     * @return bool
     */
    public static function checkErr($errorData)
    {
        $cnt = count($errorData);
        $postOk = 0;

        foreach ($errorData as $key => $item) {
            if (true === $item) {
                $errorData[$key] = '';
                ++$postOk;
            }
        }

        return $cnt == $postOk ? true : $errorData;
    }

    /**
     * 驗證短信發送的驗證碼是否正確
     * @param $code
     * @return bool|mixed
     */
    public static function checkSmsCode($code)
    {
        if (!isset($_SESSION['sms_code']) || empty($_SESSION['sms_code'])) {
            return self::$errArr[8];
        }

        if (0 !== strcmp($_SESSION['sms_code'], $code)) {
            return self::$errArr[9];
        }

        return true;
    }

    /**
     * 驗證密碼的正確性,以及2次輸入是否一致。
     * @param $password
     * @param $repassword
     * @return bool|mixed
     */
    public static function checkPassword($password, $repassword)
    {
        if (empty($password)) {
            return self::$errArr[1];
        }

        if (!is_string($password) || strlen($password) < 6) {
            return self::$errArr[10];
        }

        if (0 !== strcmp($password, $repassword)) {
            return self::$errArr[2];
        }

        return true;
    }

    /**
     * 驗證用戶名
     * @param $name
     * @return bool|mixed
     */
    public static function checkName($name)
    {
        if (empty($name)) {
            return self::$errArr[0];
        }

        return true;
    }


    /**
     * 驗證碼的驗證
     * @param $code
     * @return bool|mixed
     */
    public static function checkCode($code)
    {
        if (empty($code)) {
            return self::$errArr[4];
        }

        session_start();
        $code = strtolower($code);
        $sessionCode = strtolower($_SESSION['code']);

        if (0 !== strcmp($code, $sessionCode)) {
            return self::$errArr[5];
        }

        return true;
    }

    /**
     * 手機號碼驗證規則
     * @param $phone
     * @return bool|mixed
     */
    public static function checkPhone($phone)
    {
        if (empty($phone)) {
            return self::$errArr[7];
        }

        $isOk = preg_match('/^13[0-9]{1}[0-9]{8}$|15[0189]{1}[0-9]{8}$|189[0-9]{8}$/', $phone);

        if (!$isOk) {
            return self::$errArr[6];
        }

        if (isset($_SESSION['send_phone'])) {
            if (0 !== strcmp($_SESSION['send_phone'], $phone)) {
                return self::$errArr[11];
            }
        }

        return true;
    }
}

準備工作完成,后面的文章帶大家進入正式開發階段。
 

開源插件

最新更新

電商類

CMS類

微信類

文章標簽
精品人妻一区二区三区视频| 57pao精品| 日韩亚洲精品电影| 视频一区欧美日韩| 欧美中文字幕在线观看视频| 日韩欧美国产成人一区二区| 精品成a人在线观看| 国产精品77777| 99se婷婷在线视频观看| 亚洲福利国产精品| 亚洲免费在线观看av| 久久99久久99精品蜜柚传媒| 91福利在线导航| 日韩av免费播放| 丰满女人性猛交| 亚洲国产成人久久综合一区| 日本欧美在线看| 亚洲a级黄色片| 久久久精品国产一区二区| 懂色av中文一区二区三区| 亚洲美女在线播放| 日日碰狠狠添天天爽超碰97| 日韩欧美成人网| 在线观看亚洲国产| 日日橹狠狠爱欧美超碰| 精品国产一区二区三区在线观看| 99视频在线观看一区三区| 美女爆乳18禁www久久久久久| 国产精品一区专区欧美日韩| 亚洲成a人v欧美综合天堂 | 91网站免费观看| 亚洲一区二三区| 性色av一区二区三区四区| 日b视频免费观看| 亚洲图片欧美午夜| 波多野结衣精品在线| 国产一区二区三区视频播放| 久久久久久欧美精品色一二三四 | 国产麻豆剧传媒精品国产av| 国产欧美久久一区二区| 色婷婷av一区二区三区之一色屋| 亚洲精品一区二区三区蜜桃| 在线观看av免费观看| 国产精品久久久久久久久久久久| 偷偷要91色婷婷| 亚洲字幕av一区二区三区四区| 成人中文字幕在线播放| 性做久久久久久久免费看| 欧美日韩美女一区二区| 日韩一区二区视频在线| 国产av国片精品| 欧美福利小视频| 亚洲综合激情小说| 国产精品一区二区人人爽| 91精品国产欧美一区二区18| 99自拍视频在线| 日韩av图片| 亚洲视频在线观看免费| 欧美国产精品v| www.国产com| www.99在线| 国产主播喷水一区二区| 3d动漫精品啪啪1区2区免费| 国产精品亚洲专一区二区三区| 蜜臀av午夜精品久久| 九一免费在线观看| 午夜精品久久久久久久99热浪潮| 婷婷亚洲久悠悠色悠在线播放| 欧美一级淫片aaaaaa| 丰满少妇一区二区三区| 四虎影院一区二区三区| 欧美精品生活片| 午夜视频在线观看一区二区三区| 亚洲人成色777777精品音频| 久久久国产一级片| 亚洲国产福利视频| 久久99精品国产99久久| 亚洲毛片一区二区| 亚洲欧洲www| aa视频在线免费观看| 欧美在线一级片| 五月天亚洲综合小说网| 久久99久久久久久久噜噜| 一级性生活视频| 久久精品视频亚洲| 精品久久久久久中文字幕| 蜜臀国产一区二区三区在线播放| 亚洲伦理一区二区三区| 男女视频网站在线观看| 成人免费福利在线| 日韩成人激情视频| 亚洲视频免费在线| 久久香蕉精品| 欧美国产精品一二三| chinese少妇国语对白| 国产精品麻豆免费版| 深夜福利亚洲导航| 欧美午夜久久久| 国产mv日韩mv欧美| 一本色道久久综合精品婷婷| 黄色性生活一级片| 成年丰满熟妇午夜免费视频| 国产精品一区二区3区| 日韩精品免费电影| 亚洲国产精品久久艾草纯爱| 国产一区福利在线| 中文字幕视频二区| 在线观看免费小视频| 日本免费黄视频| 依依成人精品视频| 欧美黑人猛猛猛| 色综合手机在线| 欧美一级片免费观看| 高清一区二区三区日本久| 在线播放91灌醉迷j高跟美女| 国产性色一区二区| 青青青伊人色综合久久| 日本视频免费观看| 极品人妻videosss人妻| wwwwxxxx日韩| 国产日韩在线视频| 国产精品久久久免费看| 国产乡下妇女三片| 久久www免费人成看片高清| 国产一区二区三区av在线| 久久亚洲影音av资源网| 欧美人牲a欧美精品| 国产精品进线69影院| 久久精品国产一区二区三区免费看| 女人十八岁毛片| 9.1成人看片免费版| 久久久久久香蕉| 亚洲ai欧洲av| 91久久精品国产91久久| 欧美激情视频给我| 日韩精品在线免费观看视频| 91黄色激情网站| 亚洲图片欧美激情| 成人一区在线观看| 久热re这里精品视频在线6| 懂色av蜜臀av粉嫩av分享吧最新章节| 最近中文字幕免费视频| 成人综合久久网| 一本色道久久综合狠狠躁的推荐 | 精品久久久香蕉免费精品视频| 成人综合婷婷国产精品久久| 无码精品黑人一区二区三区 | 99国产欧美久久久精品| 午夜小视频免费| 一级片视频播放| 国产精品第108页| 少妇太紧太爽又黄又硬又爽小说| 性xxxxxxxxx| 黄色片视频在线免费观看| 一区不卡字幕| 精品亚洲一区二区三区四区五区高| 国产成人福利网站| 久久中文字幕在线视频| 亚洲免费精彩视频| 日韩免费一区二区| 在线精品国精品国产尤物884a| 亚洲精品乱码久久久久久黑人| jvid福利写真一区二区三区| 精品一区二区三区在线观看 | 91美女片黄在线观看| 久久99精品国产.久久久久久| 男人天堂一区二区| 国产精品一区二区人人爽| 69视频免费看| 日韩欧美国产亚洲| 欧洲成人性视频| 欧美日韩国产精品一区二区三区四区 | 人人妻人人澡人人爽| 国模大尺度视频| 欧美男女交配视频| 亚洲爆乳无码专区| 国产视频九色蝌蚪| 国产人妻777人伦精品hd| 国内自拍中文字幕| 超碰10000| 熟妇熟女乱妇乱女网站| 伊人精品久久久久7777| 在线不卡日本| 久久免费视频2| 最新精品视频| 91xxx视频| 亚洲自拍偷拍一区二区三区| 亚洲精品无人区| 亚洲美女搞黄| 中国成人亚色综合网站| 免费看啪啪网站| 五月天色婷婷综合| 91嫩草国产丨精品入口麻豆 | 天堂资源在线视频| 国产精品久久免费观看| 美国黄色特级片| 免费在线观看a级片| 日韩欧美综合视频| 国产一级做a爱免费视频| 久久综合色综合| 久久人人爽人人爽人人片亚洲| 91成人国产精品| 欧美日韩一区二区三区| 色哟哟国产精品| 欧美性色欧美a在线播放| 欧美日韩免费一区二区三区视频| 欧美精品自拍偷拍动漫精品| 日韩视频一区二区三区在线播放| 亚洲精品一区二区三区在线观看 | 国产夫妻性爱视频| 亚洲永久无码7777kkk| 亚洲精品成人无码| 午夜剧场免费在线观看| 国产无精乱码一区二区三区| 特级西西444www大精品视频免费看| 国产一区免费看| 午夜精品久久久久久久爽| 午夜av免费观看| 精品一区二区在线播放| 成人av在线影院| 国产精品欧美一区二区三区| 一区二区不卡在线播放 | 欧美精品18videos性欧美| 97视频在线观看免费| 国产精品一二三视频| 精品一区在线播放| 亚洲精品影院| 无码人妻丰满熟妇区96| 一级做a免费视频| 538国产视频| 少妇aaaaa| 中文字幕一区2区3区| 免费观看成年人视频| 狠狠狠色丁香婷婷综合久久五月| www.欧美亚洲| 中文字幕在线有码| 精品人妻少妇嫩草av无码专区| 91人成网站www| 日本精品视频在线观看| 2014亚洲精品| 亚洲一区二区在| 91视频 -- 69xx| 黑人巨大猛交丰满少妇| 卡一卡二卡三在线观看| 日韩少妇裸体做爰视频| 国产极品久久久| 国内久久婷婷综合| 91丨九色丨蝌蚪富婆spa| 亚洲黄色性网站| 欧美日韩国产精选| 亚洲一级片在线看| 2020欧美日韩在线视频| 国产精品久久久久免费| 欧美一区二区三区综合| 日韩欧美理论片| 日本激情视频一区二区三区| 最近中文字幕免费在线观看| 丝袜亚洲另类丝袜在线| 91免费视频大全| 欧美视频一区二区三区…| 亚洲黄色成人网| 97视频在线看| 久久综合福利| 欧美黄网站在线观看| 中文字幕一区二区久久人妻网站| 国产污视频在线观看| 性猛交xxxx| 国产日韩v精品一区二区| 欧美色倩网站大全免费| 久久精品99久久香蕉国产色戒| 国产综合久久久久| 成年人视频大全| 中文字幕在线永久| 亚洲综合图片网| 久久国产精品无码网站| 欧美国产成人精品| 欧美一区二区三区成人| 久久久人成影片一区二区三区观看| 国产区一区二区| 欧美日韩国产天堂| 香蕉加勒比综合久久| 亚洲精品国产拍免费91在线| 国产成人精品久久久| 自拍另类欧美| 少妇搡bbbb搡bbb搡打电话| 国产一级精品视频| 理论片日本一区| 亚洲影视在线播放| 亚洲无线码在线一区观看| 成人在线免费观看视视频| 大陆av在线播放| 色婷婷av777| 国产欧美久久久精品免费| 99re66热这里只有精品3直播| 欧美性猛交xxxxxx富婆| 欧美精品video| 欧洲一区二区在线| 国产成人av片| 一区二区自拍偷拍| 91小视频在线| 日韩一区二区三区三四区视频在线观看| 97碰碰碰免费色视频| 亚洲免费精品视频| 国产精品无码一区二区三区免费 | 寂寞少妇一区二区三区| 亚洲一区二区三区四区五区黄| 亚洲人a成www在线影院| 国产91视觉| 中文字幕第17页| 无码人妻熟妇av又粗又大| www.欧美日韩国产在线| 日韩欧美国产综合一区| 国产女人精品视频| 激情六月丁香婷婷| 久草国产精品视频| 白白色亚洲国产精品| 欧美一区二区三区系列电影| 国产精品自拍偷拍| 亚洲五月天综合| 久久久久久久久久久影院| 亚洲一区二区在线播放| 91av俱乐部| 天堂中文在线网| 99精品国产一区二区三区不卡| 日韩一区二区三区免费看| 91精品免费视频| 日韩在线不卡一区| 伊人网综合在线| 国产精品不卡视频| 在线观看免费高清视频97| 日本视频一区二区在线观看| 亚洲第一成人网站| 久久久xxx| 在线观看成人小视频| 国产成人亚洲精品| 日韩av一二三四| 国产一卡二卡三卡| 国产精品视频一二三区| 日韩中文字幕在线视频播放| 亚洲最大色综合成人av| 四虎884aa成人精品| 国产精品18久久久久久久久| 日韩欧美国产电影| 国产一区在线免费观看| 亚洲熟妇一区二区三区| 久久精品国产一区二区三区免费看| 欧美丰满少妇人妻精品| 天堂av在线8| 91在线你懂的| 亚洲精品大片www| 97超碰蝌蚪网人人做人人爽| 欧美韩国日本在线| 成人免费一区二区三区| 亚洲人123区| 高清在线视频日韩欧美| 日本免费一级视频| 91久久国产自产拍夜夜嗨| 亚洲国产精品123| 999精品视频在线观看播放| 成人的网站免费观看| 亚洲视频第一页| 久久视频免费在线| 九九热精品视频在线| 国产精品国产三级国产有无不卡| 久久91精品国产| 国模吧无码一区二区三区| 亚洲在线精品视频| 黑人狂躁日本妞一区二区三区| 国产精品视频导航| 妖精视频一区二区| 精品一区二区久久| 日韩国产高清视频在线| 在线观看免费91| 国产又黄又粗又爽| 亚洲国产日韩a在线播放| 国产精品视频26uuu| 亚洲熟女乱综合一区二区三区| 蜜臀av在线播放一区二区三区| 精品国产网站在线观看| 永久久久久久| 欧美日韩 一区二区三区| 五月婷婷另类国产| 91视频99| 欧美性猛交xxxx乱大交少妇| 久久久久久一二三区| 久久免费精品日本久久中文字幕| 男女男精品视频站| 欧美h在线观看| 国产91色在线观看| 这里只有精品在线观看视频| 国产在线一区观看| 国产亚洲欧美日韩一区二区| 黄页网站大全在线观看| 99久久久久成人国产免费| 欧美三级日韩在线| 日本一区二区三区www| 日本高清www免费视频| 精品久久久久久久久久久久久久| 91精品在线一区| 极品色av影院| 国产精品久久久久久亚洲毛片 | 免费在线观看日韩| 爱爱免费小视频| 国产又粗又大又爽| 日韩色在线观看| 色爽爽爽爽爽爽爽爽| 国产chinasex对白videos麻豆| 欧美一级淫片007| 乱熟女高潮一区二区在线| 精品久久久中文字幕人妻|