3

我正在使用 Express 来提供静态 HTML 文件profile.html。在文件中,我有一个简单的表格。它曾经有一个文件上传,但为了简单起见,我将它简化为一个文本输入。这是它的样子:

<form action="profile.html" method="post" id="foo" enctype="multipart/form-data">
    <input type="text" name="foo" value="bar">
    <input type="submit">
</form>

当我单击提交按钮时,Chrome 会显示提交表单的迹象,但从未发生过。profile.html提交表单时,我的 Node.js 代码永远不会运行。如果我查看 Chrome 开发者工具的网络选项卡,它会显示请求仍处于待处理状态。这在使用 PHP 和 Apache 时效果很好,但在使用 Node.js 和 Express 时却失败了。

我看过无数的例子,但我觉得这必须是配置问题,而不是代码问题。是什么阻止了表单提交给我的服务?

编辑:这大致是我的路线:

//modules, initialization, etc.
var app = express();

app.use(function(req, res, next) {
    var data = "";
    req.setEncoding("utf8");
    req.on("data", function(chunk) {
        data += chunk;
    });
    req.on("end", function() {
        req.rawBody = data;
        next();
    });
});
app.use(express.bodyParser());

//Server up our templated static HTML
app.use("/search.html", search_html.handler);
app.use("/app.html", app_html.handler);
app.use("/login.html", login_html.handler);
app.use("/graph", graph_page.handler);
app.use("/dbrequest", dbrequest_page.handler);
app.use("/profile.html", profile_html.handler);

app.use("/", function(request, response) {
    response.redirect("login.html");
});
app.listen(3000);
4

1 回答 1

1

rawBody你的中间件的组合bodyParser是行不通的:你的中间件“耗尽”了req完全提供的流,并且bodyParser会尝试做同样的事情。

但是由于流已经被读取并且它的end事件已经被触发,bodyParser它将无休止地等待一个end永远不会发生的事件(这也解释了为什么请求会陷入挂起状态)。

如果您的中间件不是绝对必要的,则将其排除在外。如果出于某种原因,您确实需要访问原始正文内容,我不确定是否可以在不重新实现bodyParser自己的情况下完成。

于 2013-04-03T19:51:24.177 回答