gpt4 book ai didi

javascript - 无法读取未定义的属性 'user_first_name'

转载 作者:可可西里 更新时间:2023-11-01 10:00:23 25 4
gpt4 key购买 nike

我正在尝试使用 expressjs/mongoose 注册用户,但出现以下错误:

TypeError: Cannot read property 'user_first_name' of undefined
at C:\Quiz webPolitica\server.js:20:24
at Layer.handle [as handle_request] (C:\Quiz webPolitica\node_modules\express\lib\router\layer.js:95:5)
at next (C:\Quiz webPolitica\node_modules\express\lib\router\route.js:131:13)
at Route.dispatch (C:\Quiz webPolitica\node_modules\express\lib\router\route.js:112:3)
at Layer.handle [as handle_request] (C:\Quiz webPolitica\node_modules\express\lib\router\layer.js:95:5)
at C:\Quiz webPolitica\node_modules\express\lib\router\index.js:277:22
at Function.process_params (C:\Quiz webPolitica\node_modules\express\lib\router\index.js:330:12)
at next (C:\Quiz webPolitica\node_modules\express\lib\router\index.js:271:10)
at serveStatic (C:\Quiz webPolitica\node_modules\express\node_modules\serve-static\index.js:75:16)
at Layer.handle [as handle_request] (C:\Quiz webPolitica\node_modules\express\lib\router\layer.js:95:5)
at trim_prefix (C:\Quiz webPolitica\node_modules\express\lib\router\index.js:312:13)
at C:\Quiz webPolitica\node_modules\express\lib\router\index.js:280:7
at Function.process_params (C:\Quiz webPolitica\node_modules\express\lib\router\index.js:330:12)
at next (C:\Quiz webPolitica\node_modules\express\lib\router\index.js:271:10)
at expressInit (C:\Quiz webPolitica\node_modules\express\lib\middleware\init.js:33:5)
at Layer.handle [as handle_request] (C:\Quiz webPolitica\node_modules\express\lib\router\layer.js:95:5)

我已经尝试调试了几个小时并查找了其他人的问题,但我一无所获。非常感谢任何帮助。请在下面查看我的代码:

服务器.js

var express = require('express');
var app = express();

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

var mongoose = require('mongoose');
mongoose.connect('mongodb://localhost/iPolitico');

var Register_User_Schema = new mongoose.Schema({
Firstname: { type: String, required: true },
Lastname: { type: String, required: true },
Email: { type: String, required: true, index: { unique: true } },
Password: { type: String, required: true }
}, {collection:"user"});

var Register_User = mongoose.model("Register_User", Register_User_Schema);

app.post('/register', function(req,res){
new Register_User({
Firstname: req.body.user_first_name,
Lastname : req.body.user_last_name,
Email : req.body.user_email,
Password : req.body.user_password
}).save(function(err, doc){
if(err){
res.json;
}else{
app.use(express.static(__dirname + '/user_profile.html'));
}
})
});

app.get('/', function(req, res){
//res.send('hello world');
Register_User.find(function (err, data){
res.json(data);
});
});

app.listen(3000);

index.html

<form role="form" action="/register" method="POST" class="registration_form">  <!--action="javascript:;" onsubmit="register_user()"-->
<div class="form-group">
<label class="sr-only" for="form-first-name">First name</label>
<input type="text" name="user_first_name" id="user_first_name" placeholder="First name..." class="form-first-name form-control" >
</div>
<div class="form-group">
<label class="sr-only" for="form-last-name">Last name</label>
<input type="text" name="user_last_name" id="user_last_name" placeholder="Last name..." class="form-last-name form-control">
</div>
<div class="form-group">
<label class="sr-only" for="form-email">Email</label>
<input type="text" name="user_email" id="user_email" placeholder="Email..." class="form-email form-control" >
</div>
<div class="form-group">
<label class="sr-only" for="form-password">Senha</label>
<input type="password" name="user_password" id="user_password" placeholder="Senha..." class="form-password form-control" >
</div>
<div class="form-group">
<label class="sr-only" for="form-password">Confirmar Senha</label>
<input type="password" name="user_confirm_password" placeholder="Confirmar Senha..." class="form-password form-control" >
</div>
<button type="submit">Sign me up!</button>
</form>

作为附带问题。当我完成注册后,我想重定向到一个新页面。我目前有“app.use(express.static(__dirname + '/user_profile.html'));”,但我很确定这是不正确的或一半正确。

最佳答案

req.body 实际上由 Express 中的中间件处理,以便在您的自定义代码访问它之前将请求数据转换为 JSON。

尝试包括 body-parser在您的项目中 (npm install body-parser) 并在您的第一个 app.post 之前添加:

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

这将抓取对您的服务器的请求,从您的 POST 调用中解析出数据,并将其作为 req.body 放入 JSON 对象中。

至于重定向,在调用结束时只需添加一个简单的 res.redirect('/newPage')

关于javascript - 无法读取未定义的属性 'user_first_name',我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38030499/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com