打印 req.url,查看请求url
req.url 可以看到我们GET请求的链接以及数据
我们新建一个html,写一个简单的form表单,用get方式提交请求
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Document</title>
</head>
<body>
<form action="http://127.0.0.1:8081/aaa" method="get">
用户:<input type="text" name="username" /> <br>
密码:<input type="password" name="password" /> <br>
<input type="submit" value="提交">
</form>
</body>
</html>
打开html文件,输入账号密码,在服务端打印 req.url 数据,请看图1.1。
// 4 .js
const http = require('http')
let server = http.createServer(function(req, res){
console.log(req.url) // 打印请求 url ->/aaa?username=123&password=qweqwe
})
server.listen(8081)
【图1.1】
处理请求的url方法一:使用 querystring 模块
知识点:quertstring
我们可以看到,服务端接收到的url数据是 /aaa?username=123&password=qweqwe
,"?"号后面就是我们再form表单中输入的数据,我门可以提取问号后面的字符串,然后用 querystring.parse()
将字符串处理成对象。
const http = require('http')
const querystring = require('querystring')
let server = http.createServer(function(req, res){
let [url, query] = req.url.split('?'); // url->'/aaa', query->'username=123&password=qweqwe'
let get = querystring.parse(query); // { username: '123', password: 'qweqwe' }
})
server.listen(8081)
处理请求的url方法二:使用 url 模块
知识点:url.parse()
通过url.parse(req.url, true)
会直接帮我处理url,第二个参数设置为true,会帮我们将form提交的数据转化成对象,请看图1.2。
const http = require('http')
const url = require('url')
let server = http.createServer(function(req, res){
let result = url.parse(req.url, true)
console.log(result)
})
server.listen(8081)
【图1.2】
**粗体** _斜体_ [链接](http://example.com) `代码` - 列表 > 引用
。你还可以使用@
来通知其他用户。