url模块、path模块、querystring模块

一个URL比较完整,包括querystring部分(就是GET请求查询字符串部分)、hash部分

http://127.0.0.1:3000/b.html?id=123#123

此时req.url是:

也就是说,querystring属于req.url,但hash不属于。

此时我们想得到文件名的部分

此时Node 中提供了内置模块:url 、path、querystring他们都可以服务于URL识别

var http = require("http");
var fs = require("fs");
var url = require("url");

http.createServer((req,res)=>{
    //转为对象
    var urljson = url.parse(req.url);
    console.log(urljson);
    res.end("");
}).listen(3000,"127.0.0.1");

网址是:

http://127.0.0.1:3000/haha/1.html?id=123&name=小明&sex=#abc

此时输出的对象是:

如果加上url.parse(req.url,true),此时querystring部分将会自动变为一个对象,方便我们存入到数据库什么的。

另外两个模块:path 、querystring 他们都是服务于url的

var http = require("http");
var fs = require("fs");
var url = require("url");
var path = require("path");
var querystring = require("querystring");


http.createServer((req,res)=>{
    //转为对象,将URL字符串变为JSON对象。
    var urljson = url.parse(req.url);
    //得到文件路径
    var pathname = urljson.pathname;
    //得到拓展名
    var extname = path.extname(pathname);
    //得到查询字符串
    var qs = urljson.query;
    //转为查询对象,和url.parse加上true非常类似
    var qsjson = querystring.parse(qs);

    console.log(pathname);
    console.log(extname);
    console.log(qsjson);

    res.end("");
}).listen(3000,"127.0.0.1");

猜你喜欢

转载自www.cnblogs.com/kun666/p/9490840.html