精品深夜福利视频,日本中文字幕不卡,久久久久国产,av综合电影网站


待發短信

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

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類

微信類

文章標簽
精品深夜福利视频,日本中文字幕不卡,久久久久国产,av综合电影网站
久久亚洲国产| 亚洲精品黄色| 久久不见久久见中文字幕免费 | 婷婷综合亚洲| 久久伦理在线| 国产一区日韩欧美| 午夜久久tv| 色老板在线视频一区二区| 日韩电影免费网址| 日韩不卡视频在线观看| 999精品色在线播放| 99久久亚洲精品蜜臀| 成人av动漫在线观看| 亚洲免费影院| 日韩黄色av| 久久精品国产免费| 香蕉成人av| 好吊日精品视频| 亚洲精品乱码| 国产精品久久国产愉拍| 福利片在线一区二区| 久久久五月天| 香蕉精品视频在线观看| 久久香蕉精品| 91精品福利观看| 久久女人天堂| 亚洲成人日韩| 亚洲免费专区| 久草精品视频| 免费av一区| 日韩美女精品| 国产一区二区三区不卡视频网站 | 日韩精品一区二区三区免费观看| 欧美精品一区二区三区精品| 久久亚洲国产精品一区二区| 日韩黄色免费网站| 国产精品成久久久久| 婷婷亚洲综合| 日韩国产精品久久久久久亚洲| 国产一区二区三区网| 亚洲欧洲日本mm| 国产欧美日韩一级| 久久国产日本精品| 日韩精品午夜视频| 91麻豆国产自产在线观看亚洲| 日韩精品一区二区三区免费观看| 蜜桃视频免费观看一区| 国产福利亚洲| 欧美日韩国产综合网| 国产精品主播| 欧美成人亚洲| 久久国产精品色av免费看| av高清一区| 欧美偷窥清纯综合图区| 日韩精品一区二区三区免费观影| 亚洲综合国产| 精品视频91| 久久国产精品99国产| 久久精品免费看| 9色精品在线| 国产精品亚洲综合色区韩国| 久久麻豆精品| 91国内精品| 性欧美xxxx免费岛国不卡电影| 色狠狠一区二区三区| 四虎成人av| 性一交一乱一区二区洋洋av| 久久的色偷偷| 日韩制服丝袜av| 国产中文在线播放| 午夜精品福利影院| 激情视频一区二区三区| 久久精品99国产精品日本| av亚洲免费| 成人三级高清视频在线看| 亚洲人成毛片在线播放女女| 欧美aa在线观看| 国产激情欧美| 日韩1区2区3区| 激情91久久| 国产成人精品一区二区三区在线| 亚洲人成亚洲精品| 激情欧美一区二区三区| 精品一区二区三区四区五区| 亚洲va久久久噜噜噜久久| 久久婷婷丁香| 久久天堂影院| 日韩二区三区四区| 亚洲一区二区成人| 91精品xxx在线观看| 国产精品a久久久久| 免费在线观看一区二区三区| 少妇久久久久| 91欧美日韩| 美腿丝袜亚洲一区| 日韩精品久久久久久| 久久亚洲视频| 亚洲激情中文在线| 日韩免费在线| 精品99在线| 国产精品a级| 国产午夜一区| 亚洲影视一区| 日韩午夜av| 欧美搞黄网站| 成人久久一区| 日韩av自拍| 国产精品s色| 国产精品久久久免费| 欧美日韩亚洲三区| 亚洲精品美女91| 亚洲欧洲免费| 日韩三区四区| 亚洲精品在线国产| 亚洲欧美网站在线观看| 亚洲18在线| 日本不卡视频在线| 久久国产欧美日韩精品| 国产精品亚洲四区在线观看| 国产精品黄色| 老司机精品视频网| 国产精品一级| 美腿丝袜亚洲一区| 国内不卡的一区二区三区中文字幕| 欧美日韩亚洲一区在线观看| 日韩超碰人人爽人人做人人添| 日韩精品社区| 国产午夜一区| 精品视频一区二区三区四区五区 | 日韩一区二区免费看| 国产日韩专区| 国产精品视区| 久久高清国产| 日精品一区二区三区| 日韩精品一区二区三区中文| 欧美天堂在线| 精品网站999| 久久天堂av| 黄色亚洲精品| 日韩精品第一| 麻豆成人av在线| 97国产精品| 91精品1区| 色综合视频一区二区三区日韩| 欧美一区不卡| 精品久久视频| 欧美成人综合| 婷婷亚洲成人| 日韩高清电影免费| 精品中文在线| 久久精品国语| 蜜臀av性久久久久蜜臀aⅴ四虎| 日韩福利视频一区| 精品国产aⅴ| 国精品一区二区三区| 蜜臀av性久久久久蜜臀aⅴ流畅| 国产亚洲精品美女久久 | 欧美日韩尤物久久| 免播放器亚洲| 国产三级一区| 国产福利片在线观看| 成人羞羞在线观看网站| 九一成人免费视频| 日韩中文一区二区| 国产精品成人一区二区不卡| 欧美网站在线| 国产精久久久| 亚洲精品电影| 国产精品.xx视频.xxtv| 美女少妇全过程你懂的久久| 婷婷亚洲精品| 国产伊人久久| 欧美午夜不卡| 国产福利资源一区| 黄色av一区| 久久亚洲道色| 最新日韩欧美| 久久免费精品| 免费在线成人网| 福利一区二区| 亚洲91网站| 日韩欧美一区二区三区免费观看| 在线观看一区| 国产在线看片免费视频在线观看| 日本欧洲一区二区| 久久久久久一区二区| 中文字幕一区二区三区日韩精品| 国产成人免费视频网站视频社区| 久久国产高清| 福利一区和二区| 亚洲精品极品| 欧美亚洲日本精品| 日韩va亚洲va欧美va久久| 日韩免费一区| 久久激情五月婷婷| 欧美日韩国产免费观看视频| 国产精品极品国产中出| 亚洲专区欧美专区| 色在线视频观看| 91欧美极品|