简单的文件服务器
有时候,我们想读取一些服务器上的文件,但是又不想写太复杂的程序,可以考虑用nodejs,可以很简单的写出一个文件服务器
下面是我写的一个简单的文件服务器,附带缓存功能,这是github链接,或者直接复制下面的代码运行即可,需要安装mime的依赖
const port = 3004; // 端口号 const http = require('http'); const url = require('url'); const fs = require('fs'); const path = require('path'); const mime = require('mime'); const STATIC_FOLDER = 'public'; // 默认读取public文件夹下的文件 const IS_OPEN_CACHE = true; // 是否开启缓存功能 const CACHE_TIME = 10;// 告诉浏览器多少时间内可以不用请求服务器,单位:秒 const server = http.createServer((req, res) => { const obj = url.parse(req.url); // 解析请求的url let pathname = obj.pathname; // 请求的路径 if (pathname === '/') { pathname = './index.html'; } const realPath = path.join(__dirname, STATIC_FOLDER, pathname); // 获取物理路径 // 获取文件基本信息,包括大小,创建时间修改时间等信息 fs.stat(realPath, (err, stats) => { let endFilePath = '', contentType = ''; if (err || stats.isDirectory()) { // 报错了或者请求的路径是文件夹,则返回404 res.writeHead(404, 'not found', { 'Content-Type': 'text/plain' }); res.write(`the request ${pathname} is not found`); res.end(); } else { let ext = path.extname(realPath).slice(1); // 获取文件拓展名 contentType = mime.getType(ext) || 'text/plain'; endFilePath = realPath; if (!IS_OPEN_CACHE) { // 未开启缓存 let raw = fs.createReadStream(endFilePath); res.writeHead(200, 'ok'); raw.pipe(res); } else { // 获取文件最后修改时间,并把时间转换成世界时间字符串 let lastModified = stats.mtime.toUTCString(); const ifModifiedSince = 'if-modified-since'; // 告诉浏览器在规定的什么时间内可以不用请求服务器,直接使用浏览器缓存,不过貌似没有生效,需要再学习一下为什么 let expires = new Date(); expires.setTime(expires.getTime() + CACHE_TIME * 1000); res.setHeader("Expires", expires.toUTCString()); res.setHeader('Cache-Control', 'max-age=' + CACHE_TIME); if (req.headers[ifModifiedSince] && lastModified === req.headers[ifModifiedSince]) { // 请求头里包含请求ifModifiedSince且文件没有修改,则返回304 res.writeHead(304, 'Not Modified'); res.end(); } else { // 返回头Last-Modified为当前请求文件的最后修改时间 res.setHeader('Last-Modified', lastModified); // 返回文件 let raw = fs.createReadStream(endFilePath); res.writeHead(200, 'ok'); raw.pipe(res); } } } }); }); server.listen(port); console.log(`server is running at http://localhost:${port}`)
不过目前还有一点问题,服务器缓存返回304,还有修改文件后,再次请求会返回最新文件这个功能目前没有问题,不过设置的Cache-Control和Expires后,在规定的时间内还是会请求服务器,这个还需要再看一下怎么回事,要是有人了解的话可以告诉我一下,谢谢。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
华山资源网 Design By www.eoogi.com
广告合作:本站广告合作请联系QQ:858582 申请时备注:广告合作(否则不回)
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
华山资源网 Design By www.eoogi.com
暂无评论...
P70系列延期,华为新旗舰将在下月发布
3月20日消息,近期博主@数码闲聊站 透露,原定三月份发布的华为新旗舰P70系列延期发布,预计4月份上市。
而博主@定焦数码 爆料,华为的P70系列在定位上已经超过了Mate60,成为了重要的旗舰系列之一。它肩负着重返影像领域顶尖的使命。那么这次P70会带来哪些令人惊艳的创新呢?
根据目前爆料的消息来看,华为P70系列将推出三个版本,其中P70和P70 Pro采用了三角形的摄像头模组设计,而P70 Art则采用了与上一代P60 Art相似的不规则形状设计。这样的外观是否好看见仁见智,但辨识度绝对拉满。
更新日志
2024年12月26日
2024年12月26日
- 小骆驼-《草原狼2(蓝光CD)》[原抓WAV+CUE]
- 群星《欢迎来到我身边 电影原声专辑》[320K/MP3][105.02MB]
- 群星《欢迎来到我身边 电影原声专辑》[FLAC/分轨][480.9MB]
- 雷婷《梦里蓝天HQⅡ》 2023头版限量编号低速原抓[WAV+CUE][463M]
- 群星《2024好听新歌42》AI调整音效【WAV分轨】
- 王思雨-《思念陪着鸿雁飞》WAV
- 王思雨《喜马拉雅HQ》头版限量编号[WAV+CUE]
- 李健《无时无刻》[WAV+CUE][590M]
- 陈奕迅《酝酿》[WAV分轨][502M]
- 卓依婷《化蝶》2CD[WAV+CUE][1.1G]
- 群星《吉他王(黑胶CD)》[WAV+CUE]
- 齐秦《穿乐(穿越)》[WAV+CUE]
- 发烧珍品《数位CD音响测试-动向效果(九)》【WAV+CUE】
- 邝美云《邝美云精装歌集》[DSF][1.6G]
- 吕方《爱一回伤一回》[WAV+CUE][454M]