我们知道nodejs可以做顶级路由,但是每向浏览器请求一个资源,都要给它配置一个路由,这未免太麻烦,我们我们仿照阿帕奇做一个路由,当向浏览器请求资源的时候不用我们一个一个的配置
直接上代码
const http = require("http");
const fs = require("fs");
const url = require("url");
const path = require("path");
const querystring = require("querystring");
var mime = {
".jpg": "image/jpeg",
".jpeg": "image/jpeg",
".png": "image/png",
".css": "text/css",
".js": "application/javascript ",
".html": "text/html;charset=UTF-8"
}
var server = http.createServer((req,res) => {
//转为对象
var pathname = url.parse(req.url).pathname;
var extname = path.extname(pathname);
if(!extname) {
//如果不是以/结尾,此时会造成浏览器识别图片路径层次有问题
// 比如http://127.0.0.1/b和http://127.0.0.1/b/不一样.同样的1.jpg
// 前者认为是同级目录下的图片,后者认为是b文件夹中的图片
if(pathname.substr(-1) != '/'){
// console.log("跳转");
res.writeHead(302,{"Location": pathname + '/'})
}
pathname += 'index.html';
}
//如果URL中不存在拓展名,此时表示这是一个文件夹,此时自动补全。
//得到拓展名
// console.log(urljson);
//得到文件路径
// var pathname = urljson.pathname;
//此时就要真的去读取myweb中的0.jpg文件
// console.log(`./myweb/${pathname}`);
fs.readFile('./myweb/' + pathname, (err,data) => {
// res.setHeader('Content-ty pe','text/html;charset=UTF-8');
if(err) {
res.end('没有这个文件');
return;
}
if(mime.hasOwnProperty(extname)){
res.setHeader("Content-type",mime[extname])
}
res.end(data)
})
})
server.listen(3000)
console.log(3000);