本文主要是介绍node.js实际应用【模拟Apache服务器】,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
- 编写js文件
var http = require('http');
var fs = require('fs');
var template = require('art-template');
var path = require('path');
var port = 5000;
var server = http.createServer();
server.on('request',function(request, response){
var url = request.url;
var wwwDir = '.';
fs.readFile('./src/template.html', function(error, data){
if (error) {
console.log(error);
return response.end('404 Not Found');
}
if (url !== '/') {
wwwDir += url;
}
var dirList = [];
var fileList = [];
var fileEnd = path.extname(wwwDir);
if (fileEnd !== '') {
fs.readFile(wwwDir, function(error, data){
if (error) {
console.log(error);
return response.end('404 Not Found');
}
if (fileEnd === '.txt') {
response.setHeader('Content-Type', 'text/plain; charset=utf-8');
}
if (fileEnd === '.jpg') {
response.setHeader('Content-Type', 'image/jpeg');
}
if (fileEnd === '.mp4') {
response.setHeader('Content-Type', 'video/mpeg4');
}
response.end(data);
});
} else {
fs.readdir(wwwDir, function(error, files){
if (error) {
return response.end('Can not find this dir');
}
var dirList = [];
var fileList =[];
files.forEach(function(iterm){
var fullPath = path.join(wwwDir,iterm);
// 同步
var stat = fs.lstatSync(fullPath);
console.log(fullPath,stat.mtime)
if (stat.isFile()){
fileList.push({'fullPath':fullPath,'fileSise':stat.size,'mtime':stat.mtime});
}else{
console.log(fullPath)
dirList.push(fullPath);
}
});
var htmlStr = template.render(data.toString(), {
title: wwwDir,
files: files,
dirList:dirList,
fileList:fileList,
});
response.end(htmlStr);
});
}
});
});
server.listen(port, function(){
console.log(`服务器已经开启,您可以通过 http://127.0.0.1:${port} 访问....`);
});
- 编写template文件
<html dir="ltr" lang="zh" i18n-processed="">
<head>
<meta charset="utf-8">
<meta name="google" value="notranslate">
<style>
h1 {
border-bottom: 1px solid #c0c0c0;
margin-bottom: 10px;
padding-bottom: 10px;
white-space: nowrap;
}
table {
border-collapse: collapse;
}
th {
cursor: pointer;
}
td.detailsColumn {
-webkit-padding-start: 2em;
text-align: end;
white-space: nowrap;
}
a.icon {
-webkit-padding-start: 1.5em;
text-decoration: none;
}
a.icon:hover {
text-decoration: underline;
}
a.file {
background: url(" ") left top no-repeat;
}
a.dir {
background: url(" ") left top no-repeat;
}
a.up {
background: url(" ") left top no-repeat;
}
html[dir=rtl] a {
background-position-x: right;
}
#parentDirLinkBox {
margin-bottom: 10px;
padding-bottom: 10px;
}
#listingParsingErrorBox {
border: 1px solid black;
background: #fae691;
padding: 10px;
display: none;
}
</style>
<title id="title">{{ title }}</title>
</head>
<body>
<h1 id="header">索引</h1>
<div id="parentDirLinkBox">
<a id="parentDirLink" class="icon up">
<span id="parentDirText">[上级目录]</span>
</a>
</div>
<table>
<thead>
<tr class="header" id="theader">
<th onclick="javascript:sortTable(0);">名称</th>
<th class="detailsColumn" onclick="javascript:sortTable(1);">
大小
</th>
<th class="detailsColumn" onclick="javascript:sortTable(2);">
修改日期
</th>
</tr>
</thead>
<tbody id="tbody">
<!-- file list -->
{{each fileList}}
<tr>
<td data-value="{{ $value.fullPath }}"><a class="icon file" draggable="true" href="/{{ $value.fullPath }}" >{{ $value['fullPath'] }}</a></td>
<td class="detailsColumn" data-value="0">{{ $value.fileSise }}</td>
<td class="detailsColumn" data-value="{{ $value.mtime }}">{{ $value.mtime }}</td>
</tr>
{{/each}}
<!-- dir list -->
{{each dirList}}
<tr>
<td data-value="{{ $value }}"><a class="icon dir" href="/{{ $value }}" >{{$value}}/</a></td>
<td class="detailsColumn" data-value="0"></td>
<td class="detailsColumn" data-value="1509589967">2017/11/2 上午10:32:47</td>
</tr>
{{/each}}
</tbody>
</table>
</body>
</html>
这篇关于node.js实际应用【模拟Apache服务器】的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!