当前位置:主页 > 聚焦 >

Node.js学习之静态资源服务器

时间:2020-12-16 16:23:07

  相关:《nodejs 教程》

  在创建 HTTP 服务器实现了一个最简单的静态资源服务器,可以对代码进行写改造,增加文件夹预览功能,暴露出一些配置,变成一个可定制的静态资源服务器模块
 

  模块化

  可定制的静态资源服务器理想的使用方式应该是这样的

  const StaticServer = require('YOUR_STATIC_SERVER_FILE_PATH'); const staticServer = new StaticServer({ port: 9527, root: '/public', }); staticServer.start(); staticServer.close();

  这样的使用方式就要求代码实现模块化,Node.js 实现一个模块非常简单

  完整代码:
执行 npm run test 可以测试


 

  支持文件夹预览

  当访问的路径是文件夹的时候程序会报错

  Error: EISDIR: illegal operation on a directory, read Emitted 'error' event on ReadStream instance at: at internal/fs/streams.js:217:14 at FSReqCallback.wrapper [as oncomplete] (fs.js:524:5) { errno: -21, code: 'EISDIR', syscall: 'read' }

  因为 fs.createReadStream 尝试读取文件夹,需要兼容下访问路径是文件夹的时候,返回一个目录页,也就是在 fs.access 之后判断文件类型

  fs.access(filePath, fs.constants.R_OK, err => { if (err) { res.writeHead(404, { 'content-type': 'text/html', }); res.end('文件不存在!'); } else { const stats = fs.statSync(filePath); const list = []; if (stats.isDirectory()) { // 如果是文件夹则遍历文件夹,生成改文件夹内的文件树 // 遍历文件内容,生成 html } else { res.writeHead(200, { 'content-type': mime.contentType(path.extname(url)), }); fs.createReadStream(filePath).pipe(res); } } });

  遍历生成 html 部分需要用到 文件夹操作 章节介绍的知识,为了方便生成 HTML,demo 使用了 Handlebar 模板引擎,主要逻辑

  if (stats.isDirectory()) { // 如果是文件夹则遍历文件夹,生成改文件夹内的文件树 path: path.join(url, dirent.name), type: dirent.isDirectory() ? 'folder' : 'file', }); dirent = dir.readSync(); } dir.close(); res.writeHead(200, { 'content-type': 'text/html', }); // 对文件顺序重排,文件夹在文件前面,相同类型按字母排序,不区分大小写 list.sort((x, y) => { if (x.type > y.type) { // 'folder' > 'file', 返回 -1,folder 在 file 之前 return -1; } else if (x.type == y.type) { return compare(x.name.toLowerCase(), y.name.toLowerCase()); } else { return 1; } }); // 使用 handlebars 模板引擎,生成目录页面 html const html = template({ list }); res.end(html); }

  通过 git 代码修改记录可以清晰看到本次的变更:

  同样在项目根目录执行 npm run test ,使用浏览器访问 127.0.0.1:9527 可以看到目录文件的展示

完整代码:

  编程教学!!

热点推荐
1 Winklevoss Twins:出售6000万美元比特币

消息,Winklevoss Twins最近出售了价值6000万美元的比特币,加入了越来越多的早期比特币持有者的...

2 BTC OG内幕巨鲸「 BTC 多仓 TOP 1」:BTC OG内

消息,BTC OG内幕巨鲸的多单浮亏已从2193万美元收窄至1981万美元。该巨鲸的均价为76,117.30美元,...

3 ETF资金流出:BTC和ETH近一周净流出超20亿

消息,据Lookonchain数据,7月1日更新显示,ETF近1天净流出2708枚BTC,价值约1.6亿美元近7天净流出...

4 Venice AI完成6500万美元A轮融资,成为独角

消息,Venice AI宣布完成6500万美元的A轮融资,成为独角兽。该公司以隐私优先的人工智能平台迅...

5 Meta Platforms正在构建云业务,出售多余人

消息,Meta Platforms正在构建云业务,旨在出售其多余的人工智能算力资源。...

6 Anthropic:与亚马逊、微软和谷歌共同起草

消息,Anthropic宣布正在与亚马逊、微软和谷歌共同起草一个共识框架,以评估AI监控的严重性。...

7 Hester Peirce:Bitcoin Clarity Act预计夏天通过

消息,美国证券交易委员会委员Hester Peirce表示,Bitcoin Clarity Act预计将于今年夏天获得通过,目...

8 Paradex TVL从2.23亿美元暴跌至2300万美元

消息,衍生品协议Paradex的总锁仓价值在代币推出后的数个月里,从1月下旬的峰值2.23亿美元暴...

9 XBIT DEX:深圳站世界杯预测活动圆满结束

消息,XBIT DEX表示,深圳的预言家活动已圆满结束,镜头记录下了比赛的精彩瞬间、现场的热度...

10 伊朗议长说同时备战才好谈判

消息,当地时间6月30日,伊朗首席谈判代表、议长卡利巴夫在接受采访时表示,伊朗决心维护...

成都来彰科技 蜀ICP备2025134723号-1

资讯来源互联网,如有版权问题请联系管理员删除。