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

升级一下上一篇的功能

首先还是配置: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(" ") left top no-repeat;}a.dir {background: url(" ") left top no-repeat;}a.up {background: url(" ") 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

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/483966.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

哈佛商业评论:什么是颠覆性创新?

来源&#xff1a;点滴科技资讯什么是颠覆性创新&#xff1f;在引入该理论 20 年后&#xff0c;我们重新审视了它所解释的和未解释的。本文发表于哈佛商业评论&#xff08;2015 年 12 月&#xff09; 作者&#xff1a;克莱顿 M.克里斯滕森&#xff0c; 迈克尔E雷诺&#xff0c;和…

定长掩码地址划分与VLSM子网划分

定长掩码地址划分 案例 若某个公司得到一个C类网络地址210.33.15.0&#xff0c;假如所有子网的掩码都一样&#xff0c;该如何划分子网&#xff1f; 步骤一&#xff1a;确定子网个数 7个子网&#xff0c;其中4个局域网&#xff0c;3个广域网 步骤2&#xff1a;确定每个子网所需…

OpenGL之几何、投影、裁剪、视口变换以及全局变换与局部变换

一、变换的概念 1.1 图形流水线 1.2 变换&#xff08;Transformation&#xff09; 变换主要分为四个步骤&#xff0c;主要就是在Vertex operations阶段操作顶点信息&#xff0c;会在流水线中依次进行。 几何变换投影变换裁剪视口变换 三维模型到二维图形的主要变换过程&am…

WinForm中DataGridView的TextBoxColumm换行

一、内容超过显示宽度自动换行&#xff1a; 在需要自动换行的列中设置 二、换行符换行&#xff1a; 一开始在需要换行的文本添加"\r\n"并不能直接换行&#xff0c;DGV直接把\r\n显示出来了&#xff0c;后换成 System.Environment.NewLine 解决问题转载于:https://www…

无类别地址CIDR概述

问题 IPv4的地址空间最终将全部耗尽子网掩码无法改变IP地址的分配方式&#xff0c;无法缓解IP地址危机 CIDR概述 CIDR是无类别域间路由CIDR取消了IP地址的分类限制&#xff0c;可以取IP地址的任意前缀作为网络号CIDR改善了IP地址的分配方式&#xff0c;缓解了IP地址危机CIDR…

刷脸背后,卷积神经网络的数学原理原来是这样的

来源&#xff1a;深度学习这件小事计算机视觉技术在日常生活中有着非常普遍的应用&#xff1a;发朋友圈之前自动修图、网上购物时刷脸支付……在这一系列成功的应用背后&#xff0c;卷积神经网络功不可没。本文将介绍卷积神经网络背后的数学原理。在自动驾驶、医疗以及零售这些…

OpenGL之坐标系以及单位

1.1 OpenGL中默认的坐标系为右手坐标系&#xff0c;默认视点位置为原点&#xff0c;原点正好投影在投影窗口的中心&#xff0c;也正好投影在视口的中心。 1.2 在OpenGL中无绝对单位&#xff0c;只有相对的大小&#xff0c;相对于视锥体的大小来设定物体的大小。 1.3 通过估算…

人工智能设计芯片,比你想象的更大胆

来源&#xff1a;ZDNet作者&#xff1a;Tiernan Ray编译&#xff1a;科技行者AI&#xff08;人工智能&#xff09;技术正在越来越多地被应用于半导体设计之中&#xff0c;这种做法的优势之一是&#xff0c;人工智能技术会尝试人类想都不敢想的设计方案。例如&#xff0c;对边际…

OpenGL之相关库介绍及基本语法、The OpenGL Machine

1.1 OpenGL Library核心库 包括115个函数&#xff0c;前缀为 &#xff1a;gl&#xff0c;主要在gl.h、openGL32.lib&#xff0c;openGL32.dll中&#xff1b; 1.2 OpenGL utility library 实用程序库 包含43个函数&#xff0c;前缀&#xff1a;glu&#xff1b;主要为核心库的…

JavaWeb从开发环境搭建,到第一个servlet程序(图文)

## 开学到今天&#xff0c;已经是第三周了~ 然而这门课的教材还没发~ 滋滋滋 表示很“蓝瘦”~~~ Java Web开发环境搭建 1、 下载安装Tomcat 官网地址&#xff1a;http://tomcat.apache.org/ 选择Tomcat 8 -- (如图所示) --选择 zip 文件 --下载后&#xff0c;将压缩包中的…

远望智库未来产业研究院与资本实验室联合发布《2021全球区块链应用市场报告》...

来源&#xff1a;远望智库预见未来从以比特币为代表的区块链1.0时代&#xff1b;到以智能合约为媒介&#xff0c;以金融应用为核心的区块链2.0时代&#xff1b;再到区块链应用于政务服务和更广泛的各行业&#xff0c;并开始推动信息互联网向价值互联网靠拢&#xff0c;短短10余…

因特网的硬件组成

终端系统 主机、服务器、PDA 通信介质 有线介质&#xff1a;双绞线、同轴电缆、光纤无线介质&#xff1a;无线电波、卫星 中间设备 路由器、交换机等 路由器 路由器的产生 由思科公司创始人伯塞克发明 路由器的特性和作用 存储转发机制连接异构的网络 交换机 交换机的…

OpenGL之光照明模型、Phong光照模型与Blinn-Phong光照模型

1.1 光照效果 通过光照&#xff0c;能反映模型的空间几何形态&#xff0c;通过光照明模型&#xff0c;计算模型表面任一点被光照后投射到观察者眼中的光亮度的大小。光照的计算就是计算投射到观察者眼中的光&#xff0c;这部分光与物体与光源的位置、物体与视点、物体表面的材质…

winfrom导出DataGridView为Excel方法

声明&#xff1a;此方法需要电脑安装Excel软件 需要类库&#xff1a;Microsoft.Office.Interop.Excel.dll 可百度自行下载 方法代码&#xff1a; /// <summary>/// 导出exc/// </summary>/// <param name"dataGridView"></param>/// <pa…

计算机网络——因特网的接入技术

因特网接入与ISP ISP&#xff1a;Internet服务供应商&#xff0c;为接入Internet提供基本的服务 一、模拟拨号 早期使用调制解调器&#xff08;Modem&#xff09;和常规的语音级电话线路早期使用最为广泛&#xff0c;最大带宽56Kb/s【下一首歌差不多要30分钟、上网就不能打电…

谈人工智能:深度学习对老牌AI

来源&#xff1a;李晓榕科学网博客链接地址&#xff1a;http://blog.sciencenet.cn/blog-687793-1300748.html学&#xff1a;学生&#xff0c;教&#xff1a;教师&#xff0c;李&#xff1a;李晓榕李&#xff1a;三代人工智能都各有所本、各有所倚&#xff0c;也就各有所偏&…

OpenGL之Phong光照模型和Blinn-Phong光照模型的局限性、OpenGL光照参数设置与光照模式

一、相关概念 1.1 Phong、Blinn-Phong光照模型是一种简单光照模型&#xff0c;它仅考虑了光源直接照射的效果&#xff0c;没有考虑非直接光照的效果。如下直接光照与间接光照。 1.2 上述模型在考虑间接光照&#xff08;环境光&#xff09;时&#xff0c;采用的是一个常数来表…

【Codeforces 1096D】Easy Problem

【链接】 我是链接,点我呀:) 【题意】 让你将一个字符串删掉一些字符。 使得字符串中不包含子序列"hard" 删掉每个字符的代价已知为ai 让你求出代价最小的方法. 【题解】 设dp[i][j]表示前i个字符,已经和"hard"匹配前j个的最小花费。 对于dp[i][j] 对s[i…

OpenGL之图形流水线中的光照计算、明暗处理

1.1 光照计算发生在图形流水线的Vertex Operations中&#xff0c;只计算每个顶点的颜色&#xff0c;而三角形内部的点的颜色在Fragment Operations阶段通计算&#xff0c;这样效率高&#xff0c;因为像素的数量远远大于顶点的数量。 1.2 计算三角形内每个像素的颜色的过程&am…

教学5层网络体系结构——分层之后数据的发送和接收

协议分层后数据发送过程 发送方层层封装 接收方层层解封装 唯一加尾部的是数据链路层 思考 发送方某层封装完如何知道该交给哪个下层封装&#xff1f; 应用层选择传输层由应用程序决定&#xff0c;传输层选择网络层由固定的搭配&#xff0c;例如因特网只有IP协议&#x…