97国产精品视频人人做人人爱,3344在线观看无码,成年人国产视频,欧美日一级片,在线看AV天堂,高清无码一本到东京热,欧美一级黄片一区2区,免费又爽又刺激高潮网址

node系列之數據接口注冊接口的實現(token驗證登陸)

2019-10-31    seo達人

node系列之數據接口注冊登陸接口的實現

1、使用express腳手架創建項目

2、了解項目的目錄結構

3、準備數據庫相關文件

4、編寫注冊接口

5、編寫登陸接口

6、驗證登陸實現

7、預告

1、使用express腳手架創建項目

// 安裝腳手架,只需安裝一次

npm i express-generator -g

// 創建express項目

express myapp --view=ejs

cd myapp

// 安裝依賴

npm i 

// 安裝需要使用的模塊

// 數據庫模塊 用戶唯一id模塊 密碼加密模塊 token模塊

npm i mongoose node-uuid bcryptjs jsonwebtoken -S



2、了解項目的目錄結構

bin

www ------- 服務器啟動

node_modules ------- 項目的依賴文件

public ------- 靜態資源文件夾

images ------- 靜態圖片

javascripts ------- 靜態的js文件

stylesheets ------- 靜態的樣式表文件

routes ------- 路由文件

index.js ------- 默認的路由

users.js ------- 用戶相關的路由

views ------- 路由對應的頁面

index.ejs ------- 默認的首頁

error.ejs ------- 錯誤頁面

app.js ------- 使用中間件,注冊路由

package.json ------- 描述文件

3、準備數據庫相關文件

大勛在node系列之數據庫mongoose的封裝中給大家介紹了如何封裝mongoose,可以先行查看如何封裝,封裝的文件夾為sql,如果不想看的,可以直接通過網盤下載該文件夾



將該sql文件放置項目的跟目錄下


  • myapp

    - sql

    - collection

    users.js

    db.js

    index.js



    4、編寫注冊接口

    目標文件: myapp/routes/users.js



    實現思路:使用post提交數據的方式,先以手機號查詢有沒有該用戶,如果有該用戶,提示用戶該賬號已經注冊過了;如果沒有該用戶,則可以完成注冊,首先得將密碼加密,加密完成后插入數據庫



    代碼實現:



    // 找到用戶集合

    var User = require('./../sql/collection/users');

    // 找到數據庫封裝文件

    var sql = require('./../sql');

    // 狀態碼的封裝

    var utils = require('./../utils')

    // 用戶唯一標識的id

    var uuid = require('node-uuid');

    // 密碼加密模塊

    var bcrypt = require('bcryptjs');

    var salt = bcrypt.genSaltSync(10); // 加密級別



    // 實現注冊接口 -- post提交方式

    router.post('/register', (req, res, next) => {

      // 1、先獲取表單信息

      let { username, password, tel } = req.body;

      // 2、根據手機號查詢 用戶集合中是否有該用戶,如果有,返回有該賬戶,如果沒有注冊繼續

      sql.find(User, { tel }, { id: 0 }).then(data => {

        // 2.1 判斷有沒有該用戶

        if (data.length === 0) {

          // 2.2 沒有該用戶----繼續完成注冊操作

          // 2.2.1 生成用戶的id

          let userid = 'users
    ' + uuid.v1();

          // 2.2.2 對密碼加密

          password = bcrypt.hashSync(password, salt)

          // 2.2.3 插入數據庫

          sql.insert(User, { userid, username, password, tel}).then(() => {

            res.send(utils.registersuccess)

          })

        } else {

          // 2.3 已有該用戶

          res.send(utils.registered)

        }

      })

    })



    附 狀態碼封裝模塊 myapp/utils/index.js

    module.exports = {

      registered: {

        code: '10000',

        message: '該用戶已注冊,請直接登錄' 

      },

      registersuccess: {

        code: '10101',

        message: '注冊成功' 

      }

    }



    5、編寫登陸接口

    目標文件 myapp/routes/users.js

    實現思路:根據手機號查詢有沒有該用戶,如果沒有,提示用戶未注冊,如果有該用戶,使用bcryptjs模塊驗證密碼的有效性,如果有效,生成token,返回給前端相應的token值。

    var jwt = require('jsonwebtoken');

    // 實現登陸功能

    router.post('/login', (req, res, next) => {

      // 1、獲取表單信息

      let { tel, password } = req.body;

      // 2、依據手機號查詢有沒有該用戶

      sql.find(User, { tel }, { _id: 0 }).then(data => {

        // 2.1 判斷有么有該用戶

        if (data.length === 0) {

          // 2.2 沒有該用戶

          res.send(utils.unregister)

        } else {

          // 2.3 有該用戶,驗證密碼

          // 2.3.1 獲取數據庫中的密碼

          let pwd = data[0].password;

          // 2.3.2 比較 輸入的 密碼和數據庫中的密碼

          var flag = bcrypt.compareSync(password, pwd) // 前為輸入,后為數據庫

          if (flag) {

            // 2.3.3 密碼正確,生成token

            let userid = data[0].userid

            let username = data[0].username

            let token = jwt.sign({ userid, username }, 'daxunxun', {

              expiresIn: 606024// 授權時效24小時

            })

            res.send({

              code: '10010',

              message: '登陸成功',

              token: token

            })

          } else {

            // 2.3.4 密碼錯誤

            res.send({

              code: '10100',

              message: '密碼錯誤'

            })

          }

        }

      })

    })



    6、驗證登陸實現

    目標文件: myapp/app.js

    實現思路:很多的數據請求都需要登陸之后才能獲取到,在此統一封裝驗證登陸

    // 引入token模塊

    var jwt = require('jsonwebtoken');

    // 全局的路由匹配

    app.use((req, res, next) => {

     // 排除登陸注冊頁面

      if (req.url !== '/users/login' && req.url !== '/users/register') {

      // 不同形式獲取token值

        let token = req.headers.token || req.query.token || req.body.token;

        // 如果存在token ---- 驗證

        if (token) {

          jwt.verify(token, 'daxunxun', function(err, decoded) {

            if (err) {

              res.send({ 

                code: '10119', 

                message: '沒有找到token.' 

              });

            } else {

              req.decoded = decoded;  

              console.log('驗證成功', decoded);

              next()

            }

          }) 

        } else { // 不存在 - 告訴用戶---意味著未登錄

          res.send({ 

            code: '10119', 

            message: '沒有找到token.' 

          });

        }

      } else {

        next()

      }

    })




日歷

鏈接

個人資料

藍藍設計的小編 http://www.0391cbd.com

存檔

主站蜘蛛池模板: 激情影院内射美女| 国产成+人+综合+亚洲欧美| 一区二区三区高清视频国产女人| 国产精品区视频中文字幕| 欧美日本中文| 在线免费a视频| 全部毛片免费看| 午夜a级毛片| 99re66精品视频在线观看| 熟女成人国产精品视频| 国产打屁股免费区网站| 欧美乱妇高清无乱码免费| 精品国产91爱| 国产呦视频免费视频在线观看| 国产真实乱了在线播放| 国产精品手机视频| 日日噜噜夜夜狠狠视频| 亚洲开心婷婷中文字幕| 国产另类乱子伦精品免费女| 国产超碰一区二区三区| 久久精品日日躁夜夜躁欧美| AV无码无在线观看免费| 香蕉国产精品视频| 成人午夜福利视频| 3D动漫精品啪啪一区二区下载| 女人18毛片一级毛片在线 | 高h视频在线| 国产午夜看片| 视频国产精品丝袜第一页| 亚洲美女操| 国产真实自在自线免费精品| 国产毛片一区| 4虎影视国产在线观看精品| 精品人妻AV区| 日本高清免费一本在线观看| 亚洲欧洲日韩久久狠狠爱| 色哟哟精品无码网站在线播放视频| 国产福利在线免费| julia中文字幕久久亚洲| 亚洲国产一成久久精品国产成人综合| 亚洲欧美精品一中文字幕| 国产在线一区二区视频| 亚洲日韩国产精品综合在线观看| 亚洲综合久久成人AV| 亚洲免费人成影院| 97精品伊人久久大香线蕉| 一本色道久久88| 免费无码网站| 成人午夜免费观看| 91精品国产综合久久香蕉922 | 丁香婷婷激情网| 伊人天堂网| 全午夜免费一级毛片| 一级毛片无毒不卡直接观看| 亚洲成在线观看 | 欧美97色| 国产人人干| m男亚洲一区中文字幕| 无码AV高清毛片中国一级毛片| 亚洲AV无码久久精品色欲| 亚洲区第一页| 国产日韩欧美视频| 亚洲h视频在线| 中文字幕久久波多野结衣| 日本色综合网| 日韩精品无码免费专网站| 2018日日摸夜夜添狠狠躁| 99久久国产综合精品2020| 激情六月丁香婷婷四房播| 91精品国产综合久久香蕉922| 亚洲成人福利网站| 一本一本大道香蕉久在线播放| 亚洲狼网站狼狼鲁亚洲下载| 国产成人喷潮在线观看| 又污又黄又无遮挡网站| 中文字幕一区二区人妻电影| 欧美黄网在线| 亚洲欧美日本国产综合在线| 亚洲国产精品日韩欧美一区| 午夜免费小视频| 国产三级韩国三级理| 亚洲欧洲综合|