node.js - Express 驗證登入表單,如何進行判斷?
给我你的怀抱
给我你的怀抱 2017-06-20 10:06:32
0
2
774

問題描述:使用express session實作登入頁面,當使用app.post對表單進行處理時,判斷語句

if(req.body.password!=user[req.body.user].password||!user[req.body.user])

其中,json檔案內容為:

{
  "baidu":{
    "password":"123",
    "name":"百度"
  }
}

出現問題,具體表現為:

  1. 使用者名稱和密碼放置在一個json檔案中,在app.js裡面進行處理,進行測試時,如果使用者名稱和密碼正確,則正常運作;但是,使用者名稱和密碼出錯,則顯示:

#
TypeError: Cannot read property 'password' of undefined

查詢了資料,在overflow上諮詢也沒有得到確切的解答。

論壇中是否有這方面的大牛,可以提供一些解決方案。

以下是其中app.js的程式碼:

var express = require('express');
var user = require('./user');
var cookieParser = require('cookie-parser');
var bodyParser = require('body-parser');
var multer = require('multer');
var session = require('express-session');
var path = require('path');
var app = express();

app.set('views', path.join(__dirname, 'views'));
app.set('view engine', 'ejs');
app.use(bodyParser.json());
app.use(bodyParser.urlencoded({extended: true}));
app.use(cookieParser());

app.use(session({
    secret: 'baiduApp',
    cookie: {maxAge: 60 * 1000 * 30},
    resave: true,
    saveUninitialized: false
}));

app.get('/', function (req, res) {
    if (req.session.sign) {
        console.log(req.session);
        res.render('sign', {session: req.session})
    } else {
        res.render('index', {title: 'index'})
    }
});
app.get('/out', function (req, res) {
    req.session.destroy();
    res.redirect('/');
});

app.post('/sign', function (req, res) {
    //登录的数据和user.json中的数据进行对比
    if (req.body.password != user[req.body.user].password || !user[req.body.user]) {
        res.end('sign failure');
    } else {
        req.session.sign = true;
        req.session.name = user[req.body.user].name;
        res.send('welecome <strong>' + req.session.name + '</strong>,<a href="/out">登出</a>');
    }
});
app.listen(80);
给我你的怀抱
给我你的怀抱

全部回覆(2)
我想大声告诉你
if (req.body.password != user[req.body.user].password || !user[req.body.user]) {

這裡的判斷,寫反了吧
應該是:

if (!user[req.body.user] || req.body.password != user[req.body.user].password) {

首先得判斷json裡面有沒有req.body.user這個屬性。

巴扎黑

我找到了另一個解決這個問題的方案:

應該先判斷是否有帳戶,否則會得到cannot read property password of undefined錯誤:

if(!user[req.body.user] || req.body.password != user[req.body.user].password){
   //错误处理
}

結合之前的反向思路,兩種方案都可以很好地解決此問題。

熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板