国产xxxx99真实实拍_久久不雅视频_高清韩国a级特黄毛片_嗯老师别我我受不了了小说

資訊專欄INFORMATION COLUMN

4.3 路由設計/RESTful API-博客后端Api-NodeJs+Express+Mysql實

1fe1se / 3047人閱讀

摘要:路由設計路由設計以用戶注冊為例介紹如何閉環用戶注冊開發注意點使用郵箱注冊驗證郵箱是否注冊目前真實開發業務大部分都是手機號注冊,這塊由于沒有購買短信服務首先,在文件夾下新建上圖中對應真實業務邏輯現附上業務實現代碼加密國際化工具類用戶服務

路由設計
路由設計 以用戶注冊為例介紹如何閉環
用戶注冊開發注意點:(1)使用郵箱注冊(2)驗證郵箱是否注冊 【目前真實開發業務大部分都是手機號注冊,這塊由于沒有購買短信服務】

首先,在routers文件夾下新建user.js


上圖中checkEmail、reg對應真實業務邏輯

現附上checkEmail、reg業務實現代碼

/**
 * user controllers
 * add by wwj
 * 2019-05-03 20:52:05
 */
var co = require("co");
var md5 = require("blueimp-md5"); //md5 加密
var i18n = require("i18n"); //i18n 國際化
var utils = require("../libs/utils"); //工具類
var User = require("../models/index").User; //用戶
// var tokenService = require("../services/token"); //token服務

module.exports = {
    /**
     * 檢測郵箱是否注冊checkEmail
     */
    checkEmail:function(req, res, next) {
        //參數
        var params = req.query || req.params;
        //變量
        var email = utils.trim(params.email);
        if(!email){
            utils.handleJson({
                response: res,
                msg: i18n.__("success"),
                result: {
                    emailHadReg:false,
                },
            });
        }
        co(function*() {
            var userResult = yield User.findOne({
                where: {
                    email: email,
                },
            });
            var result =  false;
            if(userResult){
                result = true;
            }
            //success
            utils.handleJson({
                response: res,
                msg: i18n.__("success"),
                result: {
                    emailHadReg:result,
                },
            });
        }).catch(function(error) {
            //err
            utils.handleError({
                response: res,
                error: error,
            });
        });
    },
    /**
     * 注冊 post
     */
    reg: function(req, res, next) {
        var params = req.body;
        //變量
        var email = utils.trim(params.email);
        var password = utils.trim(params.password);
        //檢查用戶名、密碼是否為空
        if (!email || !password) {
            utils.handleJson({
                response: res,
                msg: i18n.__("emailOrPwdNull"),
            });
            return;
        }
        //檢查是否注冊過
        co(function*() {
            var userResult = yield User.findOne({
                where: {
                    email: email,
                },
            });
            //用戶已被注冊
            if (userResult) {
                utils.handleJson({
                    response: res,
                    msg: i18n.__("emailHadReg"),
                });
                return;
            }
            userResult = yield User.create({
                email: email,
                password: md5(password),
                state: "1", //先默認已激活狀態 //狀態 0未激活郵箱、1已激活郵箱
            });
            if (!userResult) { //注冊失敗
                utils.handleJson({
                    response: res,
                    msg: i18n.__("regFail"),
                });
                return;
            }
            //成功入庫
            var user = userResult.dataValues;
            //刪除密碼
            delete user.password;
            //success
            utils.handleJson({
                response: res,
                msg: i18n.__("regSuccess"),
                result: {
                    user: user,
                    // accessToken: tokenService.setToken({
                    //     uuid: user.uuid
                    // }), //token
                },
            });
        }).catch(function(error) {
            //err
            utils.handleError({
                response: res,
                error: error,
            });
        });
    },
};
【自測環節】使用Postman來測試驗證接口正確性
Postman下載 
https://www.getpostman.com/
http://chromecj.com/web-devel...

先將項目跑起來

npm run dev

RESTful API
RESTful API 最佳實踐 
http://www.ruanyifeng.com/blo...
Nodejs RESTFul架構實踐之api篇
https://my.oschina.net/nodeon...

以本項目為例,查詢用戶信息和更新用戶信息接口 可根據不同請求方式來實踐

文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。

轉載請注明本文地址:http://specialneedsforspecialkids.com/yun/104080.html

相關文章

  • NodeJs+Express+Mysql + Vuejs 項目戰 - 大綱

    摘要:多一個技能多一條出路,祝你在自學道路上越走越好,掌握自己的核心技能,不只是優秀,還要成為不可替代的人 NodeJs+Express+Mysql + Vuejs 項目實戰 最近準備寫一系列文章,全面講述如何基于NodeJs + Express + Mysql + Vuejs 從零開發前后端完全分離項目; 文筆及技術可能在某些方面欠佳,請您指正,共同學習進步 前端:Vuejs全家桶 后端:...

    noONE 評論0 收藏0
  • 4.5 Promise/Co yield-博客后端Api-NodeJs+Express+Mysql

    摘要:課前學習對象阮一峰廖雪峰從當年的回調地獄到語法糖再到,通過不斷的進化來更好的從代碼層面同步方式寫異步操作下面以語法糖為例介紹如何實現首先寫個基于 Promise 課前學習Promise 對象 阮一峰http://javascript.ruanyifeng....Promise 廖雪峰https://www.liaoxuefeng.com/w... js從當年的回調地獄、到co語法糖再...

    Tamic 評論0 收藏0
  • 4.1 開發環境目錄結構配置文件功能梳理-博客后端Api-NodeJs+Express+Mys

    摘要:從本章開始,正式學習如何使用搭建一個博客。但通常我們都會有許多環境,如本地開發環境測試環境和線上環境等,不同的環境的配置不同,我們不可能每次部署時都要去修改引用或者。會根據環境變量的不同從當前執行進程目錄下的目錄加載不同的配置文件。 從本章開始,正式學習如何使用 Nodejs + Express + Mysql 搭建一個博客。 開發環境 首先說下開發環境安裝的核心依賴版本: Node....

    DevWiki 評論0 收藏0
  • 4.2 數據庫表/Sequelize Mysql-博客后端Api-NodeJs+Express+My

    功能梳理完了以后,咱們就可以開始數據庫表設計了: 數據庫表圖: showImg(https://segmentfault.com/img/bVbr9GC?w=1922&h=1140); 首先打開Navicat Premium 創建數據庫 blog 配置如下: showImg(https://segmentfault.com/img/bVbr81Y?w=720&h=352); 課前學習:1、Sequ...

    nicercode 評論0 收藏0

發表評論

0條評論

最新活動
閱讀需要支付1元查看
<