打印 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 .jsconst 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】

使用 querystring 模块处理url数据

知识点: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】