摘要:路由設計路由設計以用戶注冊為例介紹如何閉環用戶注冊開發注意點使用郵箱注冊驗證郵箱是否注冊目前真實開發業務大部分都是手機號注冊,這塊由于沒有購買短信服務首先,在文件夾下新建上圖中對應真實業務邏輯現附上業務實現代碼加密國際化工具類用戶服務
路由設計
路由設計 以用戶注冊為例介紹如何閉環
用戶注冊開發注意點:(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 devRESTful API
RESTful API 最佳實踐
http://www.ruanyifeng.com/blo...
Nodejs RESTFul架構實踐之api篇
https://my.oschina.net/nodeon...
以本項目為例,查詢用戶信息和更新用戶信息接口 可根據不同請求方式來實踐
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/104080.html
摘要:多一個技能多一條出路,祝你在自學道路上越走越好,掌握自己的核心技能,不只是優秀,還要成為不可替代的人 NodeJs+Express+Mysql + Vuejs 項目實戰 最近準備寫一系列文章,全面講述如何基于NodeJs + Express + Mysql + Vuejs 從零開發前后端完全分離項目; 文筆及技術可能在某些方面欠佳,請您指正,共同學習進步 前端:Vuejs全家桶 后端:...
摘要:課前學習對象阮一峰廖雪峰從當年的回調地獄到語法糖再到,通過不斷的進化來更好的從代碼層面同步方式寫異步操作下面以語法糖為例介紹如何實現首先寫個基于 Promise 課前學習Promise 對象 阮一峰http://javascript.ruanyifeng....Promise 廖雪峰https://www.liaoxuefeng.com/w... js從當年的回調地獄、到co語法糖再...
摘要:從本章開始,正式學習如何使用搭建一個博客。但通常我們都會有許多環境,如本地開發環境測試環境和線上環境等,不同的環境的配置不同,我們不可能每次部署時都要去修改引用或者。會根據環境變量的不同從當前執行進程目錄下的目錄加載不同的配置文件。 從本章開始,正式學習如何使用 Nodejs + Express + Mysql 搭建一個博客。 開發環境 首先說下開發環境安裝的核心依賴版本: Node....
功能梳理完了以后,咱們就可以開始數據庫表設計了: 數據庫表圖: 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...
閱讀 1918·2021-11-22 09:34
閱讀 1158·2021-10-09 09:44
閱讀 3046·2021-09-29 09:35
閱讀 3626·2021-09-14 18:01
閱讀 1494·2021-08-16 10:49
閱讀 1096·2019-08-29 14:11
閱讀 859·2019-08-29 12:47
閱讀 3081·2019-08-26 13:47