91成人在线播放_欧美一区二区视频在线观看_91精品国产高清久久久久久_国产精品久久亚洲不卡4k岛国


待發短信

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

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類

微信類

文章標簽
91成人在线播放_欧美一区二区视频在线观看_91精品国产高清久久久久久_国产精品久久亚洲不卡4k岛国
91精品国产欧美日韩| 极品少妇xxxx偷拍精品少妇| 在线观看免费一区| 成人18精品视频| 成人激情小说网站| 成人97人人超碰人人99| 成人精品gif动图一区| 国产成人在线免费| 成人综合激情网| 成人av午夜电影| 91免费版pro下载短视频| 一本大道久久a久久精品综合| 91在线porny国产在线看| 色av成人天堂桃色av| 欧美精品乱码久久久久久按摩| 欧美色倩网站大全免费| 91麻豆精品久久久久蜜臀| 日韩午夜精品视频| 26uuu国产在线精品一区二区| 久久婷婷色综合| 国产精品高潮呻吟| 亚洲国产乱码最新视频| 青娱乐精品视频| 国产99久久久国产精品免费看 | 日韩三级.com| 久久免费精品国产久精品久久久久| 精品国产髙清在线看国产毛片| 久久久久久免费网| 亚洲毛片av在线| 久久爱www久久做| 99视频精品全部免费在线| 欧美日韩一区二区不卡| 久久综合色鬼综合色| 亚洲视频在线一区二区| 麻豆精品在线播放| 日本精品裸体写真集在线观看| 欧美一级xxx| 亚洲品质自拍视频| 韩国女主播一区| 欧美在线视频你懂得| 久久日韩粉嫩一区二区三区| 亚洲天堂网中文字| 韩国成人福利片在线播放| 91国模大尺度私拍在线视频| 久久精品亚洲一区二区三区浴池| 一区二区三区在线观看网站| 国内精品伊人久久久久av影院 | 欧美日韩色综合| 日本一区二区三区高清不卡| 日韩制服丝袜av| 色网综合在线观看| 国产精品五月天| 国内一区二区在线| 欧美一区日韩一区| 亚洲午夜久久久久久久久久久| 大桥未久av一区二区三区中文| 欧美一区二区不卡视频| 亚洲综合一区二区| www.亚洲色图.com| 国产日本欧洲亚洲| 国产一区在线观看视频| 制服丝袜亚洲精品中文字幕| 亚洲精品高清视频在线观看| 波多野结衣中文字幕一区| 精品久久人人做人人爽| 日韩在线播放一区二区| 在线观看日韩一区| 尤物视频一区二区| 91麻豆国产精品久久| 国产精品网站在线播放| 国产成人av在线影院| 精品嫩草影院久久| 久久国产精品区| 91精品国产色综合久久久蜜香臀| 亚洲午夜视频在线观看| 欧美丝袜丝交足nylons图片| 亚洲一二三区在线观看| 欧美亚洲高清一区| 亚洲国产精品久久久男人的天堂| 在线亚洲+欧美+日本专区| 亚洲美女在线一区| 在线视频你懂得一区| 一区二区成人在线| 欧美专区在线观看一区| 亚洲一区二区欧美日韩| 欧美日韩成人在线一区| 奇米综合一区二区三区精品视频 | 国产婷婷色一区二区三区在线| 久久国产尿小便嘘嘘| 欧美哺乳videos| 国产乱子轮精品视频| 国产日韩欧美精品电影三级在线 | 亚洲欧美中日韩| 91国产丝袜在线播放| 丝袜亚洲精品中文字幕一区| 8v天堂国产在线一区二区| 奇米影视一区二区三区| 欧美精品一区二区三区在线| 国产成人免费av在线| 一区精品在线播放| 欧洲一区二区三区在线| 日韩经典一区二区| 国产色产综合色产在线视频| 99久久精品免费看| 五月天中文字幕一区二区| 日韩精品一区二区三区蜜臀| 国产福利一区二区| 一区二区三区毛片| 精品日韩在线一区| 国产成人av一区二区三区在线| 亚洲美女视频一区| 日韩欧美国产系列| 成人午夜碰碰视频| 亚洲午夜电影在线| 久久久精品影视| 欧美在线视频日韩| 精品亚洲porn| 亚洲色图第一区| 精品乱人伦小说| 日本精品视频一区二区| 精品一区二区三区久久| 中文字幕日韩欧美一区二区三区| 欧美精选在线播放| 成人av中文字幕| 免费看日韩a级影片| 中文字幕一区二区三区蜜月| 欧美一区在线视频| 91麻豆国产香蕉久久精品| 久久国产尿小便嘘嘘尿| 亚洲乱码中文字幕| 国产日本一区二区| 欧美一区二区久久| 欧美中文字幕亚洲一区二区va在线 | 精品国产人成亚洲区| 麻豆久久久久久| 欧美日韩专区在线| 美女视频一区二区| 亚洲视频网在线直播| 91成人在线观看喷潮| 免费看精品久久片| 91一区一区三区| 国产精品网站一区| 春色校园综合激情亚洲| 欧美一a一片一级一片| 伊人夜夜躁av伊人久久| 91网站最新地址| 精品国产91乱码一区二区三区 | 欧美精品一区二区三区高清aⅴ | 欧美精品视频www在线观看| 欧美国产成人在线| 国产福利不卡视频| 99r精品视频| 亚洲欧美日韩久久精品| 欧美综合久久久| 在线一区二区视频| 欧美成人三级在线| 国产寡妇亲子伦一区二区| 久久婷婷一区二区三区| 日韩高清不卡在线| 午夜在线成人av| 韩国成人精品a∨在线观看| 精品区一区二区| 亚洲第一在线综合网站| 欧美精品一二三| 在线免费一区三区| 欧美日本视频在线| 国产精一品亚洲二区在线视频| 精品福利一区二区三区免费视频| 国产成人在线视频网址| 粉嫩在线一区二区三区视频| 99视频热这里只有精品免费| 一区二区三区精品视频| 成人教育av在线| 日韩电影一区二区三区四区| 日韩精品一区二区三区在线 | 青青青伊人色综合久久| 在线一区二区视频| 天天av天天翘天天综合网| 亚洲激情在线激情| 久久久久国产免费免费| 国产午夜精品一区二区| 欧美亚洲图片小说| 99久久精品国产麻豆演员表| 国产日韩欧美在线一区| 欧美一区国产二区| 精品少妇一区二区三区日产乱码| 精品日本一线二线三线不卡| 欧美videossexotv100| 久久久久亚洲蜜桃| 综合激情成人伊人| 亚洲成在线观看| 精品影院一区二区久久久| 成人综合在线观看| 精品视频色一区| 久久先锋影音av| 一区二区三区在线视频观看| 秋霞成人午夜伦在线观看| 国产成人精品一区二| 精品视频在线免费观看| 久久久久高清精品|