升级一下上一篇的功能

首先还是配置:config.js

module.exports = {host: 'http://127.0.0.1',   //主机名port: 3000,                 //服务器端口号documentRoot: 'E:/webdev',  //根目录directoryBrowse: true,  //是否开启目录浏览功能directoryIndex: [    //目录默认访问页'index.html','index.htm','deflaut.html'],charset: 'utf-8',mineType: {image: {gif: 'image/gif',jpeg: 'image/jpeg',jpg: 'image/jpeg',png: 'image/png',},text: {css: 'text/css',htm: 'text/html',html: 'text/html',js: 'application/x-javascript',json: 'application/json',pdf: 'application/pdf',},other: 'text/plain'}
}

接着是服务器代码:index.js

const http = require('http')
const fs = require('fs')
const path = require('path')
const tpl = require('art-template')
const config = require('./config')
const server = http.createServer()
const documentRoot = config.documentRootserver.on('request', function (req, res) {let url = req.urlconsole.log(url)let tmp = documentRoot + urllet exist = fs.existsSync(tmp)if (exist) {let stats1 = fs.statSync(tmp)if (stats1.isDirectory()) {for (let key in config.directoryIndex) {let file = tmp + '/' + config.directoryIndex[key]console.log(`${config.host}:${config.port + url + config.directoryIndex[key]}`);if (fs.existsSync(file)) {res.writeHead(302, {'Location': `${config.host}:${config.port + url + config.directoryIndex[key]}`})res.end()return}}if (!config.directoryBrowse) {//没有开放目录浏览权限res.writeHead(403, {"Content-Type": "text/html"});res.end('<h2>403 forbidden!!</h2>')return}fs.readFile('./template-apache.html', function (err, data) {if (err) {return res.end('404 Not Found.')}let prevDisplay = 'block'if (url == '/') {prevDisplay = 'none'}fs.readdir(tmp, function (err, files) {if (err) {return res.end('Can not find www dir.')}let fileObjArr = []for(key in files){fileObjArr[key] = {}fileObjArr[key].name = files[key]fileObjArr[key].type = 'file'fileObjArr[key].separate = ''let stats = fs.statSync(tmp + files[key])if (stats.isDirectory()) {fileObjArr[key].type = 'dir'fileObjArr[key].separate = '/'}fileObjArr[key].href = `${config.host}:${config.port + url + files[key] + fileObjArr[key].separate}`}let parentPath = url.substring(0, url.substr(0, url.length - 1).lastIndexOf('/') + 1)let htmlStr = tpl.render(data.toString(), {title: 'Index Of' + url,files: fileObjArr,prevDisplay,parentPath})res.end(htmlStr)})})} else {//渲染文件fs.readFile(tmp, function (err, data) {if (err) {res.end()}let ext = path.extname(tmp).substring(1)if (ext in config.mineType.text) {res.setHeader('Content-Type', `${config.mineType.text[ext]}; charset=${config.charset}`)} else if (ext in config.mineType.image) {res.setHeader('Content-Type', `${config.mineType.text[ext]}`)} else {res.setHeader('Content-Type', `${config.mineType.other}; charset=${config.charset}`)}res.end(data)})}} else {res.end()}
})
server.listen(config.port, function () {console.log(`server running in: ${config.host}:${config.port}`)const cp = require('child_process')cp.exec(`start ${config.host}:${config.port}`)  //自动打开浏览器
})

最后是模板:template-apache.html

<html>
<head><meta charset="utf-8"><style>h1 {border-bottom: 1px solid #c0c0c0;margin-bottom: 10px;padding-bottom: 10px;white-space: nowrap;}table {border-collapse: collapse;}a.icon {-webkit-padding-start: 1.5em;text-decoration: none;}a.icon:hover {text-decoration: underline;}a.file {background: url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABAAAAAQCAIAAACQkWg2AAAABnRSTlMAAAAAAABupgeRAAABHUlEQVR42o2RMW7DIBiF3498iHRJD5JKHurL+CRVBp+i2T16tTynF2gO0KSb5ZrBBl4HHDBuK/WXACH4eO9/CAAAbdvijzLGNE1TVZXfZuHg6XCAQESAZXbOKaXO57eiKG6ft9PrKQIkCQqFoIiQFBGlFIB5nvM8t9aOX2Nd18oDzjnPgCDpn/BH4zh2XZdlWVmWiUK4IgCBoFMUz9eP6zRN75cLgEQhcmTQIbl72O0f9865qLAAsURAAgKBJKEtgLXWvyjLuFsThCSstb8rBCaAQhDYWgIZ7myM+TUBjDHrHlZcbMYYk34cN0YSLcgS+wL0fe9TXDMbY33fR2AYBvyQ8L0Gk8MwREBrTfKe4TpTzwhArXWi8HI84h/1DfwI5mhxJamFAAAAAElFTkSuQmCC ") left top no-repeat;}a.dir {background: url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABAAAAAQCAYAAAAf8/9hAAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAAd5JREFUeNqMU79rFUEQ/vbuodFEEkzAImBpkUabFP4ldpaJhZXYm/RiZWsv/hkWFglBUyTIgyAIIfgIRjHv3r39MePM7N3LcbxAFvZ2b2bn22/mm3XMjF+HL3YW7q28YSIw8mBKoBihhhgCsoORot9d3/ywg3YowMXwNde/PzGnk2vn6PitrT+/PGeNaecg4+qNY3D43vy16A5wDDd4Aqg/ngmrjl/GoN0U5V1QquHQG3q+TPDVhVwyBffcmQGJmSVfyZk7R3SngI4JKfwDJ2+05zIg8gbiereTZRHhJ5KCMOwDFLjhoBTn2g0ghagfKeIYJDPFyibJVBtTREwq60SpYvh5++PpwatHsxSm9QRLSQpEVSd7/TYJUb49TX7gztpjjEffnoVw66+Ytovs14Yp7HaKmUXeX9rKUoMoLNW3srqI5fWn8JejrVkK0QcrkFLOgS39yoKUQe292WJ1guUHG8K2o8K00oO1BTvXoW4yasclUTgZYJY9aFNfAThX5CZRmczAV52oAPoupHhWRIUUAOoyUIlYVaAa/VbLbyiZUiyFbjQFNwiZQSGl4IDy9sO5Wrty0QLKhdZPxmgGcDo8ejn+c/6eiK9poz15Kw7Dr/vN/z6W7q++091/AQYA5mZ8GYJ9K0AAAAAASUVORK5CYII= ") left top no-repeat;}a.up {background: url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABAAAAAQCAYAAAAf8/9hAAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAAmlJREFUeNpsU0toU0EUPfPysx/tTxuDH9SCWhUDooIbd7oRUUTMouqi2iIoCO6lceHWhegy4EJFinWjrlQUpVm0IIoFpVDEIthm0dpikpf3ZuZ6Z94nrXhhMjM3c8895977BBHB2PznK8WPtDgyWH5q77cPH8PpdXuhpQT4ifR9u5sfJb1bmw6VivahATDrxcRZ2njfoaMv+2j7mLDn93MPiNRMvGbL18L9IpF8h9/TN+EYkMffSiOXJ5+hkD+PdqcLpICWHOHc2CC+LEyA/K+cKQMnlQHJX8wqYG3MAJy88Wa4OLDvEqAEOpJd0LxHIMdHBziowSwVlF8D6QaicK01krw/JynwcKoEwZczewroTvZirlKJs5CqQ5CG8pb57FnJUA0LYCXMX5fibd+p8LWDDemcPZbzQyjvH+Ki1TlIciElA7ghwLKV4kRZstt2sANWRjYTAGzuP2hXZFpJ/GsxgGJ0ox1aoFWsDXyyxqCs26+ydmagFN/rRjymJ1898bzGzmQE0HCZpmk5A0RFIv8Pn0WYPsiu6t/Rsj6PauVTwffTSzGAGZhUG2F06hEc9ibS7OPMNp6ErYFlKavo7MkhmTqCxZ/jwzGA9Hx82H2BZSw1NTN9Gx8ycHkajU/7M+jInsDC7DiaEmo1bNl1AMr9ASFgqVu9MCTIzoGUimXVAnnaN0PdBBDCCYbEtMk6wkpQwIG0sn0PQIUF4GsTwLSIFKNqF6DVrQq+IWVrQDxAYQC/1SsYOI4pOxKZrfifiUSbDUisif7XlpGIPufXd/uvdvZm760M0no1FZcnrzUdjw7au3vu/BVgAFLXeuTxhTXVAAAAAElFTkSuQmCC ") left top no-repeat;}#parentDirLinkBox {margin-bottom: 10px;padding-bottom: 10px;}</style><title id="title">{{ title }}</title>
</head><body>
<h1 id="header">{{ title }}</h1>
<div id="parentDirLinkBox" style="display:{{ prevDisplay }}"><a id="parentDirLink" class="icon up" href="{{ parentPath }}"><span id="parentDirText">[上级目录]</span></a>
</div>
<table>{{each files}}<tr><td data-value="apple/"><a class="icon {{$value.type}}" href="{{$value.href}}">{{$value.name}}{{ $value.separate}}</a></td></tr>{{/each}}
</table>
</body></html>

end^_^

转载于:https://www.cnblogs.com/chuanzi/p/10514223.html

使用nodejs和art-template模板引擎实现apache的部分功能相关推荐

  1. Spring Boot 使用 Kotlin Script Template 模板引擎kts 开发web应用

    Spring Boot 使用 Kotlin Script Template 模板引擎kts 开发web应用 在 Spring Framework 5.0 M4 中引入了一个专门的Kotlin支持. K ...

  2. template模板引擎的使用例子

    背景:使用模板引擎可以避免复杂的数据操作,例如数据很多时,把数据渲染到表单中是特别麻烦的事情.如果使用模板引擎可以很方便的帮助我们完成这些繁琐的操作. 模板引擎有很多种,但是每种模板引擎的使用方式都是 ...

  3. JavaScript中template模板引擎

    这篇文章主要为大家详细介绍了JavaScript模板引擎Template.js使用方法,具有一定的参考价值,感兴趣的小伙伴们可以参考一下 template.js 一款 JavaScript 模板引擎, ...

  4. art template 模板渲染数据

    客户端 <!DOCTYPE html> <html lang="en"> <head><meta charset="UTF-8& ...

  5. nodejs jade mysql_学习篇:NodeJS中的模板引擎:jade

    NodeJS 模板引擎作用:生成页面 在node常用的模板引擎一般是 1.jade --破坏式的.侵入式.强依赖(对原有的html体系不友好,走自己的一套体系) 2.ejs --温和的.非侵入式的.弱 ...

  6. html中模板引擎—前端与后端

    模板引擎 模板引擎 起到 数据和视图分离的作用, 模板对应视图, 关注如何展示数据, 在模板外头准备的数据, 关注那些数据可以被展示. 后端模板引擎 freemarker 如下介绍,  java后台的 ...

  7. java 前端模板_前端模板引擎入门

    模板引擎 模板引擎 起到 数据和视图分离的作用, 模板对应视图, 关注如何展示数据, 在模板外头准备的数据, 关注那些数据可以被展示. 后端模板引擎 freemarker 如下介绍,  java后台的 ...

  8. 从零开始学 Python 之 Web 开发 Jinja2 模板引擎

    被之前的文章中,简单介绍了 Python Web 开发框架 Flask,知道了如何写个 Hello World,但是距离用 Flask 开发真正的项目,还有段距离,现在我们目标更靠近一些 -- 学习下 ...

  9. 前端与后端的模板引擎

    模板引擎 模板引擎 起到 数据和视图分离的作用, 模板对应视图, 关注如何展示数据, 在模板外头准备的数据, 关注那些数据可以被展示. 后端模板引擎 freemarker 如下介绍,  java后台的 ...

最新文章

  1. machine learning
  2. 养娃时做过的蠢事,程序员必看!
  3. contentProvider中有关query方法的使用
  4. 正面管教PHP交流互助会,父母的心态决定孩子的状态/慧育家正面管教家长讲师认证班...
  5. [译]5步实现Silverlight中的Command
  6. JAVA中this用法小结
  7. 程序员所应具备的品质
  8. 远程无法连接svn服务器失败_windows vscode 远程连接linux服务器
  9. 大型企业多账号管理“安全心法”
  10. Google的三篇大数据思想论文
  11. 你觉得你个性上最大的优点是什么?
  12. synchronized的使用方法
  13. 本周没有学习,估计用脑过度...
  14. 【Python-3.3】字典存储调查问卷
  15. LeetCode513 找左下角的值
  16. 学习ExtJS(九) fit布局
  17. day5 字典 dict
  18. python3 获取文件目录_python3--os.path获取当前文件的绝对路径和所在目录
  19. Hibernate必须掌握的知识
  20. java爬虫爬取豆瓣电影_小爬虫之爬取豆瓣电影排行榜

热门文章

  1. qemu+linux+x86+64,qemu以64位跟32位的方式跑busybox
  2. 二、nodemon-Node.js 监控工具
  3. 四、MyBatis 框架 Dao 动态代理
  4. LeetCode 1848. 到目标元素的最小距离
  5. Scala 入门1(变量、分支循环、函数)
  6. LeetCode 68. 文本左右对齐(字符串逻辑题)
  7. LeetCode 978. 最长湍流子数组(DP)
  8. LeetCode 712. 两个字符串的最小ASCII删除和(DP,类似编辑距离)
  9. js固定表格行列_纯前端表格控件SpreadJS V14.0发布:组件化编辑器+数据透视表
  10. mask属性是css3的吗_使用CSS3 mask(蒙版,遮罩)属性实现超酷按钮悬停动画