2

我看过几篇与此相关的帖子,但这里似乎没有一个问题。

这是一个非常简单的初学者 nodejs 应用程序,在 windows7 上使用 expressjs

/**
 * Module dependencies.
 */


var express = require('express')
    , connect = require('connect')
    , http = require('http')


var app = express();

app.configure(function(){
  app.set('port', process.env.PORT || 3000);
  // app.use(express.bodyParser());
  app.use(connect.bodyParser());
});

/**
 * Routes
 */
//get requests
// app.get("/", function(req, res){
//   res.send("Hello, Express!");
// });

// app.get("/hi", function(req, res){
//   var message = [
//     "<h1>Hello, Express!</h1>",
//     "<p>Welcome to 'Building Web Apps in Node.js with Express.'</p>",
//     "<p>You'll love Express because it's</p>",
//     "<ul><li>Fast</li>",
//     "<li>Fun</li>",
//     "<li>Flexible</li>"
//   ].join("\n");

//   res.send(message);
// });

// app.get("/users/:userID", function(req, res){
//   res.send("<h1>Hello, User #" + req.params.userID + "!");
// });

//post requests
app.post("/users", function(req, res){
    // res.send(req.body);
    res.send(req.body.username);
});


http.createServer(app).listen(app.get('port'), function(){
  console.log("Express server listening on port " + app.get('port'));
});

如您所见,我已经注释掉了其他路线,以确保它们不会导致问题,并且我也尝试安装和使用“连接”,但 express.bodyParser() 和 connect.bodyParser() 都给了我相同的结果。

我使用了 chrome adv rest 客户端扩展,还尝试了以下简单的 php 表单。

<form action="http://localhost:3000/users" method="POST" enctype="application/x-www-form-urlencoded">
    <li>
        <label for="username">Username</label>
        <input type="text" name="username" id="username">
    </li>
    <li>
        <input type="submit" name="submit" id="submit">
    </li>
</form>

在所有情况下,我都会得到一个空的或未定义的 req.body.username,当我在响应中尝试 req.body 时,我得到一个空对象 {}

更新: 这是来自 chrome 的响应/请求标头信息:

Request URL:http://localhost:3000/users
Request Method:POST
Status Code:200 OK
Request Headersview source
Cache-Control:max-age=0
Connection:keep-alive
Content-Length:31
Host:localhost:3000
Request Payload
username=isimmons&submit=Submit
Response Headersview source
Connection:keep-alive
Date:Sat, 27 Oct 2012 23:01:45 GMT
Transfer-Encoding:chunked
X-Powered-By:Express

这是我发送 req.route 时得到的

//result of console.log(req.route);
{ path: '/users',
  method: 'post',
  callbacks: [ [Function] ],
  keys: [],
  regexp: /^\/users\/?$/i,
  params: [] }

Node 和 Express 版本:express 3.0 node 0.8.9

UPDATE2 问题半解决 见下面的评论。我应该在这里说。无论如何,这是正常工作时来自 chrome 的请求标头信息。

Request URL:http://localhost:3000/users
Request Method:POST
Status Code:200 OK
Request Headersview source
Accept:text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8
Accept-Charset:ISO-8859-1,utf-8;q=0.7,*;q=0.3
Accept-Encoding:gzip,deflate,sdch
Accept-Language:en-US,en;q=0.8
Cache-Control:max-age=0
Connection:keep-alive
Content-Length:26
Content-Type:application/x-www-form-urlencoded
Host:localhost:3000
Origin:http://localhost
Referer:http://localhost/nodeform.php
User-Agent:Mozilla/5.0 (Windows NT 6.1) AppleWebKit/537.16 (KHTML, like Gecko) Chrome/24.0.1305.3 Safari/537.16
Form Dataview sourceview URL encoded
username:dfd
submit:Submit
Response Headersview source
Connection:keep-alive
Content-Length:3
Content-Type:text/html; charset=utf-8
Date:Sun, 28 Oct 2012 01:12:23 GMT
X-Powered-By:Express

谢谢

4

1 回答 1

1

好的,终于遇到了这个其余 api 的错误报告,只需添加内容类型即可解决问题。

错误报告

错误报告有一个答复,要求在发送前手动添加“Content-type”标头。这就是 php 表单起作用的原因。它设置了 enctype,因此我得到了完整的请求标头,如上所示。

要手动添加的正确内容类型标头是

Content-Type: application/x-www-form-urlencoded
于 2012-10-28T02:31:13.683 回答