簡體   English   中英

如何使用Node.js和MongoDB進行用戶注冊(使用mongoose和Express.js)

[英]How to make user registration with Node.js and MongoDB (using mongoose and Express.js)

我需要你的幫助。 我想制作用戶注冊表並使用Nodejs,Express.js,MongoDB(mongoose),並給我一個非常簡單的例子,如何使用以下方式創建用戶注冊表:姓名,電子郵件,密碼和手機號碼:)我已經制作了mongoose架構和給出像這樣的名字:req.body.name但它不起作用:/在我的意見中,我做了一件壞事。

這是我的代碼,如果您認為不正確,請更正。 (對不起,我的英語不好)。 這是server.js

var mongoose = require('mongoose');
mongoose.connect('mongodb://localhost/addressbookdb');
var express = require('express');
var app = express();
var db = mongoose.connection;

app.use(express.static(__dirname + '/../client'));

app.post("/",function(req,res){
    res.end("Registration Succesfully Completed!");

    var db = mongoose.connection;
    db.on('error', console.error.bind(console, 'connection error:'));
    db.once('open', function (callback) {
        console.log("connected.")
    });

    // Schema
    var RegSchema = mongoose.Schema({
        Name: String,
        Email: String,
        Pass: String,
        Num: Number,
        reg_time : {
            type : Date, default: Date.now
        }
    }, { collection: 'AddressCol' });

    // Model
    var UserReg = mongoose.model('UserReg', RegSchema);

    // Add in collection
    var UserAdd = new UserReg({
        Name: req.body.name,
        Email: req.body.email,
        Pass: req.body.pass,
        Num: req.body.num,
    });

    // Save
    UserAdd.save(function (err, fluffy) {
        if (err) return console.error(err);
    });
});

app.listen(8000, function() {
  console.log("Server is running!");
});

這是我的HTML頁面:

<div class="form-group">
    <input type="text" class="form-control" id="name" placeholder="name><br>
    <input type="email" class="form-control" id="email" placeholder="Email"><br>
    <input type="password" class="form-control" id="pass" placeholder="Password"><br>
    <input type="number" class="form-control" id="num" placeholder="Number"><br>
    <button type="submit" class="btn btn-primary" id="reg-form-btn">Registration!</button>
</div>
<script>
    $(document).ready(function() {
        $("#reg-form-btn").click(function() {
            var name = $("#name").val();
            var email = $("#email").val();
            var pass = $("#pass").val();
            var num = $("#num").val();
            $.post("/", {
                Name: name,
                Email: email,
                Pass: pass,
                Num: num
            });
        });
    });
</script>

也許您應該考慮Passport或其他模塊。 但你可以這樣做:

app.post('/signup', function (req, res, next) {
    var user = {
       Name: req.body.name,
       Email: req.body.email,
       Pass: req.body.pass,
       Num: req.body.num
   };
   var UserReg = mongoose.model('UserReg', RegSchema);
   UserReg.create(user, function(err, newUser) {
      if(err) return next(err);
      req.session.user = email;
      return res.send('Logged In!');
   });
});

app.post('/login', function (req, res, next) {
   var email = req.body.email;
   var pass = req.body.pass;

   User.findOne({Email: email, Pass: pass}, function(err, user) {
      if(err) return next(err);
      if(!user) return res.send('Not logged in!');

      req.session.user = email;
      return res.send('Logged In!);
   });
});

app.get('/logout', function (req, res) {
   req.session.user = null;
});

那么你應該有一個中間件來處理身份驗證

function isLoggedIn (req, res, next) {
  if (!(req.session && req.session.user)) {
    return res.send('Not logged in!');
  }
  next();
}

並在私人路線上使用它

app.get("/api", isLoggedIn, function (req, res) {
   //Something private
})

這是一個很好的教程,如何使用非常有用的模塊護照制作你想要的東西。 您還可以快速瀏覽一下Jade模板引擎,它可以幫助您進一步學習創建快速應用程序。

查看本教程...如果需要,可以忽略Angular和mongojs: http ://www.phloxblog.in/single-page-application-angular-js-node-js-mongodb-mongojs-module/#.Vc20OXW1Gkq

你缺少body-parser 在服務器代碼中嘗試此操作:

const bodyParser = require('body-parser');
app.use(bodyParser);

使用Node.js和Express進行POST時,請參考問題如何訪問請求體?

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM