【问题标题】:Insert data in mongodb via form input + Express.js通过表单输入 + Express.js 在 mongodb 中插入数据
【发布时间】:2017-01-17 03:23:10
【问题描述】:

我尝试通过表单输入在 mongoDB 中插入数据。问题是,我正在重定向到“/new”并收到“找不到文件”错误,而不是说“成功插入”。我尝试将用户信息存储在现有集合“用户”中 - 之后,我想在路径“/retrieve.pug”的表单输入中显示数据并将其显示在客户端。如果有人可以帮助我,我将不胜感激,这是我的代码:

app.js

var express = require('express');
var bodyParser = require('body-parser');
var methodOverride = require('method-override');
var mongoose = require('mongoose');
var passport = require('passport');
var session = require('express-session');
var MongoStore = require('connect-mongo')(session);
var User = require('./models/user');
var app = express();

// mongodb connection
mongoose.connect("mongodb://localhost:27017/socialempireclub");
var db = mongoose.connection;

// mongo error
db.on('error', console.error.bind(console, 'connection error:'));

// use sessions for tracking logins
app.use(session({
  secret: 'treehouse loves you',
  resave: true,
  saveUninitialized: false,
  store: new MongoStore({
    mongooseConnection: db
  })
}));

// make user ID available in templates
app.use(function (req, res, next){
  res.locals.currentUser = req.session.userId;
  next();
});

// parse incoming requests
app.use(bodyParser.json());
app.use(bodyParser.urlencoded({ extended: false }));
app.use(require('express-method-override')('method_override_param_name'));
// serve static files from /public
app.use(express.static(__dirname + '/public'));

// view engine setup
app.set('view engine', 'pug');
app.set('views', __dirname + '/views');

// include routes
var routes = require('./routes/index');
app.use('/', routes);

// catch 404 and forward to error handler
app.use(function(req, res, next) {
  var err = new Error('File Not Found');
  err.status = 404;
  next(err);
});

// error handler
// define as the last app.use callback
app.use(function(err, req, res, next) {
  res.status(err.status || 500);
  res.render('error', {
    message: err.message,
    error: {}
  });
});

app.post('/new', function(req, res){
  new user({
    country: req.body.country
  }).save(function(err, user){
      if(err) res.json(err);
      else res.send('Sucessfully inserted');
  });
});

app.get('/retrieve', function(req, res){
    user.find({}, function(err, user){
        if(err) res.json(err);
        else    res.render('retrieve', {users: docs});
    });
});

// listen on port 3000
app.listen(3000, function () {
  console.log('Express app listening on port 3000');
});

user.js 模型

var mongoose = require('mongoose');
var bcrypt = require('bcrypt');
var UserSchema = new mongoose.Schema({
  username: {
    type: String,
    unique: true,
    required: true,
    trim: true
  },
  email: {
    type: String,
    unique: true,
    required: true,
    trim: true
  },
  password: {
    type: String,
    required: true
  },
  country: String
});
// authenticate input against database documents
UserSchema.statics.authenticate = function(email, password, callback) {
  User.findOne({ email: email })
    .exec(function (error, user){
      if (error) {
        return callback(error);
      } else if ( !user ) {
        var err = new Error('User not found.');
        err.status = 401;
        return callback(err);
      }
      bcrypt.compare(password, user.password, function(error, result){
        if (result === true) {
          return callback(null, user);
        } else {
          return callback();
        }
      })
    });
}
// hash password before saving to database
UserSchema.pre('save', function(next){
  var user = this;
  bcrypt.hash(user.password, 10, function(err, hash){
    if (err) {
      return next(err);
    }
    user.password = hash;
    next();
  })
});
var user = mongoose.model('user', UserSchema);
module.exports = user;

profile.pug //Pug模板引擎 //用户信息+表单输入

p.heading-profile Contact details
                 form(action='/new', method='POST')
                  p
                    | First name
                    input.form-control.input-first-name(type='text', placeholder='First name', aria-describedby='sizing-addon3')
                  p
                    | Last name
                    input.form-control.input-last-name(type='text', placeholder='Last name', aria-describedby='sizing-addon3')
                  p
                    | Street address
                    input.form-control.input-street-address(type='text', placeholder='Street address', aria-describedby='sizing-addon3')
                  p
                    | City
                    input.form-control.input-city(type='text', placeholder='City', aria-describedby='sizing-addon3')
                  p
                    | State/Province
                    input.form-control.input-state(type='text', placeholder='State/Province', aria-describedby='sizing-addon3')
                  p
                    | Zip/Post Code
                    input.form-control.input-zip(type='text', placeholder='Zip/Post code', aria-describedby='sizing-addon3')
                  label(for='country') Country
                    input.form-control.input-country(type='text', name='country', aria-describedby='sizing-addon3')
                  input.button(type='submit', value='Edit')

最后,retrieve.pug

html
  head
    title Registration Form
  body
ul
each user in users
    form(action='', method='POST')
      label(for='user[email]') Email:
      input(type='text', name="user[_id]", value=user._id)
      br
      label(for='user[country]') Country:
      input(type='text', name="user[country]", value=user.country)
      br
      input(type='submit')

【问题讨论】:

  • 你能在这里发布错误吗?
  • 感谢您的评论,错误是“找不到文件”。在表单输入上点击“提交”按钮后显示,路线为“/new”。这是我得到的唯一错误,我有点不知所措,这是怎么发生的。
  • /new 上,您正在渲染哪个哈巴狗,它在哪里?
  • 没有 'new.pug' - 文件或路由,点击提交后重定向到 'localhost:3000/new' 并显示 'File not found error'。但是,如果您在我的“app.js”文件中看到,它应该在“/new”上发送带有“成功插入”的响应。我想,要么我的 'app.post(...) in app.js' 错误,要么是 'user.js' 中设置的 mongodb ?!

标签: javascript node.js express pug


【解决方案1】:

如果您要重定向路由 /new,那么您必须在 POST 调用中提供一个用于呈现数据的页面,如 Browser 期望的那样,但它没有得到任何页面,这就是您得到此 error 的原因.

尝试创建一个new.pug 存在所有pug files 的文件并执行此操作

app.post('/new', function(req, res) {
    new user({
        country: req.body.country
    }).save(function(err, user) {
        if (err) res.json(err);
        else {
            res.render('new', {
                mesage: 'Sucessfully inserted'
            });
        }
    });
});

例如创建new.pug 用于显示简单消息

block content
  p Welcome to #{message}

【讨论】:

  • 好的,非常感谢,abdulbarik,这很有道理。我创建了一个新文件“new.pug”。我应该在里面写什么或展示什么?
  • 我刚刚用 new.pug 文件更新了答案,你可以使用这个
  • 我昨天尝试在mongoDB中插入数据,与上面类似,但我只使用表单输入并在'/new'路由上发送了响应,它成功显示'成功插入'。毕竟,数据实际上是在 mongoDB 内部。所以现在我尝试在我的网络应用程序中实现它 - 以同样的方式 - 但它停在“找不到文件”处。因此,我不确定为什么它在昨天没有创建“new.pug”文件的情况下工作。
  • 如果您从Browser 访问URL,那么它总是发送GET 请求,在此请求中您可以将响应发送为JSON
  • 太棒了,谢谢!我试过了,正如你用“new.pug”描述的那样,但我仍然遇到“找不到文件”错误。有没有办法了解更多关于错误的信息?
【解决方案2】:

解决办法如下:

  • 我在 mongoDB 中创建了两个不同的模式:1) user 2) user_info
  • 然后我将它连接到我的 app.js 中,并将 user_info 表单输入显示给客户端

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2021-10-27
    • 2023-03-19
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多