提交 html 表单到 nodejs
Submit html form to nodejs
我正在尝试编写一个非常简单的项目,从 node js 编写一个 web 并将其发送到 node js,这样我就可以保存到达那里的信息。
所以,我用了一些YouTube tutorials,但似乎不起作用
表格本身只是为了练习,所以我从网上得到的:
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>Payment form example</title>
<link href="../css/style.css" rel="stylesheet">
</head>
<body>
<form action="/ipo" method="POST" >
<h1>Payment form</h1>
<p>Required fields are followed by <strong><abbr title="required">*</abbr></strong>.</p>
<section>
<h2>Contact information</h2>
<fieldset>
<legend>Title</legend>
<ul>
<li>
<label for="title_1">
<input type="radio" id="title_1" name="title" value="A">
Ace
</label>
</li>
<li>
<label for="title_2">
<input type="radio" id="title_2" name="title" value="K" >
King
</label>
</li>
<li>
<label for="title_3">
<input type="radio" id="title_3" name="title" value="Q">
Queen
</label>
</li>
</ul>
</fieldset>
<p>
<label for="name">
<span>Name: </span>
<strong><abbr title="required">*</abbr></strong>
</label>
<input type="text" id="name" name="username">
</p>
<p>
<label for="mail">
<span>E-mail: </span>
<strong><abbr title="required">*</abbr></strong>
</label>
<input type="email" id="mail" name="usermail">
</p>
<p>
<label for="pwd">
<span>Password: </span>
<strong><abbr title="required">*</abbr></strong>
</label>
<input type="password" id="pwd" name="password">
</p>
</section>
<section>
<h2>Payment information</h2>
<p>
<label for="card">
<span>Card type:</span>
</label>
<select id="card" name="usercard">
<option value="visa">Visa</option>
<option value="mc">Mastercard</option>
<option value="amex">American Express</option>
</select>
</p>
<p>
<label for="number">
<span>Card number:</span>
<strong><abbr title="required">*</abbr></strong>
</label>
<input type="tel" id="number" name="cardnumber">
</p>
<p>
<label for="expiration">
<span>Expiration date:</span>
<strong><abbr title="required">*</abbr></strong>
</label>
<input type="text" id="expiration" required="true" placeholder="MM/YY" pattern="^(0[1-9]|1[0-2])\/([0-9]{2})$">
</p>
</section>
<section>
<p> <button type="submit" id="submit">Validate the payment</button> </p>
</section>
</form>
</body>
</html>
服务器端是:
const host = 'localhost';
const port = 3000;
const express = require('express');
const app = express();
const bodyParser = require('body-parser')
app.use(express.static('public'))
var urlencodedParser = bodyParser.urlencoded({ extended: true })
app.get('/', function (req, res) {
res.sendFile("/Users/idanhauser/Documents/NodeJs/web/client/pages/index.html");
})
app.listen(port, () => {
console.log(`Example app listening at http://localhost:${port}`)
})
app.post('/ipo', urlencodedParser, function (req, res) {
console.log(req.params);
console.log(req.body);
console.log("not ok");
res.send("ok");
})
服务器上的最后一个函数,这是监听我的请求的函数。
但是当我尝试这样做时,我发现 req.body
是空的 {}.
我错过了什么?
非常感谢
伊丹
所以你已经设置了 urlencodedParser
但你忘了将它添加到你的中间件中:
var urlencodedParser = bodyParser.urlencoded({ extended: true })
+ app.use(urlencodedParser);
body-parser
已弃用,您可以使用 express
指定您的中间件,如下所示:
app.use(express.urlencoded({ extended: true }));
urlencoded 是您需要解析 HTML 表单数据的解析器。
终于,我在服务器中成功获取了这些数据。
我不明白为什么,但在更改表格后,它将只有姓名和电子邮件。成功了。
谢谢!
我正在尝试编写一个非常简单的项目,从 node js 编写一个 web 并将其发送到 node js,这样我就可以保存到达那里的信息。
所以,我用了一些YouTube tutorials,但似乎不起作用
表格本身只是为了练习,所以我从网上得到的:
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>Payment form example</title>
<link href="../css/style.css" rel="stylesheet">
</head>
<body>
<form action="/ipo" method="POST" >
<h1>Payment form</h1>
<p>Required fields are followed by <strong><abbr title="required">*</abbr></strong>.</p>
<section>
<h2>Contact information</h2>
<fieldset>
<legend>Title</legend>
<ul>
<li>
<label for="title_1">
<input type="radio" id="title_1" name="title" value="A">
Ace
</label>
</li>
<li>
<label for="title_2">
<input type="radio" id="title_2" name="title" value="K" >
King
</label>
</li>
<li>
<label for="title_3">
<input type="radio" id="title_3" name="title" value="Q">
Queen
</label>
</li>
</ul>
</fieldset>
<p>
<label for="name">
<span>Name: </span>
<strong><abbr title="required">*</abbr></strong>
</label>
<input type="text" id="name" name="username">
</p>
<p>
<label for="mail">
<span>E-mail: </span>
<strong><abbr title="required">*</abbr></strong>
</label>
<input type="email" id="mail" name="usermail">
</p>
<p>
<label for="pwd">
<span>Password: </span>
<strong><abbr title="required">*</abbr></strong>
</label>
<input type="password" id="pwd" name="password">
</p>
</section>
<section>
<h2>Payment information</h2>
<p>
<label for="card">
<span>Card type:</span>
</label>
<select id="card" name="usercard">
<option value="visa">Visa</option>
<option value="mc">Mastercard</option>
<option value="amex">American Express</option>
</select>
</p>
<p>
<label for="number">
<span>Card number:</span>
<strong><abbr title="required">*</abbr></strong>
</label>
<input type="tel" id="number" name="cardnumber">
</p>
<p>
<label for="expiration">
<span>Expiration date:</span>
<strong><abbr title="required">*</abbr></strong>
</label>
<input type="text" id="expiration" required="true" placeholder="MM/YY" pattern="^(0[1-9]|1[0-2])\/([0-9]{2})$">
</p>
</section>
<section>
<p> <button type="submit" id="submit">Validate the payment</button> </p>
</section>
</form>
</body>
</html>
服务器端是:
const host = 'localhost';
const port = 3000;
const express = require('express');
const app = express();
const bodyParser = require('body-parser')
app.use(express.static('public'))
var urlencodedParser = bodyParser.urlencoded({ extended: true })
app.get('/', function (req, res) {
res.sendFile("/Users/idanhauser/Documents/NodeJs/web/client/pages/index.html");
})
app.listen(port, () => {
console.log(`Example app listening at http://localhost:${port}`)
})
app.post('/ipo', urlencodedParser, function (req, res) {
console.log(req.params);
console.log(req.body);
console.log("not ok");
res.send("ok");
})
服务器上的最后一个函数,这是监听我的请求的函数。
但是当我尝试这样做时,我发现 req.body
是空的 {}.
我错过了什么?
非常感谢 伊丹
所以你已经设置了 urlencodedParser
但你忘了将它添加到你的中间件中:
var urlencodedParser = bodyParser.urlencoded({ extended: true })
+ app.use(urlencodedParser);
body-parser
已弃用,您可以使用 express
指定您的中间件,如下所示:
app.use(express.urlencoded({ extended: true }));
urlencoded 是您需要解析 HTML 表单数据的解析器。
终于,我在服务器中成功获取了这些数据。 我不明白为什么,但在更改表格后,它将只有姓名和电子邮件。成功了。
谢谢!