node.js搭建一个简易的仿apache服务器
程序员文章站
2022-04-18 11:31:19
...
node.js搭建一个简易的仿apache服务器
node环境
当然,开始之前,我们首先还是需要配置好自己的Node环境,node的环境配置网上还是有许多教程的,没有的小伙伴阔以参考这里,有详细的配置与教程。
引入http模块并创建服务,
因为在apache服务中我们使用的是他自己的www目录,所以在这里为了读取到我们自定义的www目录,还得引入文件模块
let http = require('http');
let fs = require('fs');
let server = http.createServer();
我们自定义www目录,并实现目录读取和判断
let wwwUrl = 'F:/textstudy/simplePaging/node/www';
server.on('request',function(request,response){
//手动配置类似apache
let url = request.url;
if(url == '/'){
fs.readFile(wwwUrl + '/index.html',(err,data) => {
if(err){
return response.end('404 Not Found!!');
}
response.end(data);
});
}else if(url == '/a.txt'){
fs.readFile(wwwUrl + '/a.txt',(err,data) => {
if(err){
return response.end('404 Not Found!!');
}
response.end(data);
});
}else if(url == '/login.html'){
fs.readFile(wwwUrl + '/login.html',(err,data) => {
if(err){
return response.end('404 Not Found!!');
}
response.end(data);
});
}else{
response.end('404 Not Found');
}
然后在我们的代码根目录下运行powershell命令窗口,运行我们这个js文件,对了,我们也不能忘了对服务做监听:
server.listen(3000,function(){
console.log('服务已启动')
})
当然,我们不可能只是在自己每新建一个文件或者目录的时候,都去做一次if判断,所以我们还可以将代码改进:
server.on('request',function(request,response){
//手动配置类似apache
let wwwUrl = 'F:/textstudy/simplePaging/node/www';
let filePath = '/index.html';
let url = request.url;
if(url != '/'){
filePath = url;
};
fs.readFile(wwwUrl + filePath,(err,data) => {
if(err){
return response.end('404 not found')
}
response.end(data)
})
})
因为每一次我们在后面跟的路径名,就是我们的request.url,所以我们只需要将这个值取出来就好了,这样我们就不需要去一次次的判断了。
这就是一个简单的仿apache,写这个主要是为了体现一哈js的牛逼哈哈,可以多学到一些服务器端的知识。。