精品深夜福利视频,日本中文字幕不卡,久久久久国产,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综合电影网站
欧美日韩一区自拍| 蜜桃av在线播放| 不卡中文一二三区| 久久免费高清| 婷婷国产精品| 在线日韩av| 激情久久中文字幕| 一区久久精品| 蜜臀久久99精品久久久久久9| 久久中文字幕av一区二区不卡| 天堂av在线| 中文在线中文资源| 日韩啪啪电影网| 久久久久99| 黄色成人精品网站| 一级成人国产| 日精品一区二区三区| 日韩欧美久久| 免费一区二区三区在线视频| аⅴ资源天堂资源库在线| 樱桃视频成人在线观看| 成人羞羞视频在线看网址| 久久精品电影| 99视频一区| 亚洲性视频在线| 久久激情综合网| 精品国产一区二区三区2021| 在线精品亚洲欧美日韩国产| 欧美一区二区性| 视频一区在线播放| 国产日韩欧美一区| 97欧美在线视频| 亚洲高清激情| 日韩精品一区二区三区av| 久久av日韩| 久久国产主播| 亚洲人成毛片在线播放女女| 欧美亚洲色图校园春色| 国产九九精品| 国产a亚洲精品| 999国产精品999久久久久久| 久久亚洲不卡| 国产精品毛片aⅴ一区二区三区| 精品久久网站| 久久久久网站| 男女激情视频一区| 欧美激情五月| 午夜精品网站| 国产日韩中文在线中文字幕| 97精品97| 久久香蕉精品| 国产一区二区三区日韩精品| 伊人成人在线视频| 国产精品探花在线观看| 久久久精品久久久久久96| 蜜桃免费网站一区二区三区| 久久中文精品| 欧美网站在线| 国产极品模特精品一二 | 久久高清免费观看| 国产精品亚洲产品| 美女少妇全过程你懂的久久| 日韩精品亚洲一区二区三区免费| 国产精品高颜值在线观看| 先锋影音久久久| 精品国产美女a久久9999| 99亚洲视频| 久久久久97| 亚洲女同中文字幕| 国产精品99精品一区二区三区∴| 欧美大黑bbbbbbbbb在线| 国产欧美日韩一级| 欧美理论视频| 国产精品99久久久久久董美香| 激情91久久| 国产一区二区色噜噜| 中文字幕视频精品一区二区三区| 欧美不卡高清一区二区三区| 久久国产日韩欧美精品| 亚洲综合不卡| 另类专区亚洲| 国产精品亚洲四区在线观看| 美女精品在线观看| 成人福利视频| 国产精品亚洲产品| 亚洲精品国产精品粉嫩| 999国产精品视频| 久久成人av| 最新国产精品视频| 91久久在线| 久久久久久自在自线| 欧美啪啪一区| 日韩一区精品视频| 欧美成人久久| 私拍精品福利视频在线一区| 国产第一亚洲| 欧美日本精品| 中文字幕一区二区三区四区久久| 日韩精品一区二区三区免费观看| 卡一卡二国产精品| 国产欧美综合一区二区三区| 亚洲网址在线观看| 欧美特黄a级高清免费大片a级| 黄色aa久久| 欧美交a欧美精品喷水| 日韩成人午夜精品| 久久亚洲国产精品一区二区| 久久青草久久| 日本精品黄色| 久久免费影院| 欧美日韩一区自拍| 日韩精品亚洲一区二区三区免费| 免费国产自线拍一欧美视频| 涩涩av在线| 韩国一区二区三区视频| 国产欧美日韩在线观看视频| 亚洲欧美在线专区| 日韩中文字幕av电影| 亚洲欧洲午夜| 国产综合亚洲精品一区二| 天堂√8在线中文| 另类专区亚洲| 国产精品久久久久av电视剧| 成人三级高清视频在线看| 精品日韩在线| 精品欧美日韩精品| 国产成年精品| 桃色一区二区| sm久久捆绑调教精品一区| 国产夫妻在线| 91tv亚洲精品香蕉国产一区| 91免费精品| 亚洲成人va| 1024精品久久久久久久久| 成人av动漫在线观看| 99国产精品视频免费观看一公开| 影院欧美亚洲| 自拍自偷一区二区三区| 日韩区一区二| 国产精品一线| 精品女同一区二区三区在线观看| 福利一区二区三区视频在线观看| bbw在线视频| 欧美日韩精品免费观看视完整| 性欧美videohd高精| 精品一区亚洲| 亚洲一区二区三区在线免费| 欧美日韩18| 国产成人精品三级高清久久91| 人在线成免费视频| 亚洲国产成人精品女人| 爽好久久久欧美精品| 日韩精品一区二区三区av| 欧美国产中文高清| 日韩理论片av| 亚洲作爱视频| 亚洲精品日本| 国产精品www994| 四季av一区二区凹凸精品| 日韩在线观看一区| 欧美日韩三区| 日本欧美一区二区在线观看| 精品香蕉视频| 精品一区欧美| 日韩一区二区三区高清在线观看| 国产精品传媒麻豆hd| 日韩电影免费在线观看| 性欧美精品高清| 国产精品qvod| 日韩在线高清| 欧美专区在线| 国产精品毛片aⅴ一区二区三区| 国产美女高潮在线观看| 国产精品88久久久久久| 亚洲另类视频| 成人在线免费观看网站| 亚洲经典在线| 国产乱子精品一区二区在线观看 | 在线观看视频免费一区二区三区| 久久精品99国产国产精| 国产亚洲一区二区手机在线观看| 不卡av一区二区| 国产欧美日韩在线一区二区 | 亚洲福利一区| 91精品尤物| 欧美日韩在线二区| 欧美精品中文| 好看的av在线不卡观看| 麻豆视频观看网址久久| 亚洲午夜在线| 国产精品一二| 在线一区免费观看| 久久久久亚洲精品中文字幕| 久久大逼视频| 国产精品宾馆| 夜夜嗨网站十八久久| 久久99精品久久久久久园产越南| 亚洲香蕉网站| 国产无遮挡裸体免费久久| 欧美日韩一区二区三区视频播放|