TypeError:无法读取未定义的mysql查询的属性“name”

时间:2015-02-04 06:35:12

标签: javascript node.js express

的所有人。 我做了一个小网站进行学习。我遇到了一个问题。实际上,似乎很简单的错误。但在我的情况下,这是一个巨大的错误。

在我的系统上 ubuntu,node.js和mysql。

var fs = require('fs');
var ejs = require('ejs');
var http = require('http');
var mysql = require('mysql');
var express = require('express');

var client = mysql.createConnection({
  user: 'root',
  password: 'password',
  database: 'Company'
});

var app = express();

http.createServer(app).listen(8080, function(){
  console.log('Server running at http://127.0.0.1:8080');
});

app.get('/', function(request, response) {
  fs.readFile('list.html', 'utf8', function(error, data) {
    client.query('SELECT * FROM products', function (error, results) {
       response.send(ejs.render(data, {
        data: results
      }));
    });
  });
});


app.get('/delete/:id', function(request, response) { 
  client.query('DELETE FROM products WHERE id=?', [request.param('id')], function() {
    response.redirect('/');
  });
});

app.get('/insert', function(request, response) { 
  fs.readFile('insert.html', 'utf8', function (error, data) {
  response.send(data);
  });
}); 

app.post('/insert', function(request, response) {
  var body = request.body;

  client.query('INSERT INTO products (name, modelnumber, series) VALUES (?, ?, ?)', [
       body.name, body.modelnumber, body.series 
  ],function() {
    response.redirect('/');
  });
});

我的错误信息就像标题; TypeError:无法读取属性' name'未定义的。

我知道错误在哪里。 app.post - > body.name,body.modelnumber,body.series ..  我读了一本书来编写代码... 我无法找到错误的原因..

1 个答案:

答案 0 :(得分:1)

来自express documentation

  

req.body

     

包含请求正文中提交的键值对数据。默认情况下,它是undefined,并在您使用正文解析中间件(例如body-parsermulter)时填充。

     

此示例显示如何使用正文解析中间件来填充req.body。

var app = require('express')();
var bodyParser = require('body-parser');
var multer = require('multer'); 

app.use(bodyParser.json()); // for parsing application/json
app.use(bodyParser.urlencoded({ extended: true })); // for parsing application/x-www-form-urlencoded
app.use(multer()); // for parsing multipart/form-data

app.post('/', function (req, res) {
  console.log(req.body);
  res.json(req.body);
})

从书中学习通常是不够的,您还应该阅读您正在使用的库/模块的文档。