当前位置: 首页 > news >正文

化妆品网站建设目的哈尔滨最新信息

化妆品网站建设目的,哈尔滨最新信息,湘潭网站建设 多少钱磐石网络,免费咨询怀孕用 zlib 来实现 gzip 压缩 服务端优化都是#xff1a;压缩 缓存 前端可以通过 webpack 插件进行压缩 gzip 根据替换来实现的#xff0c;重复率越高#xff0c;压缩后的结果越小 const zlib require(zlib); const fs require(fs); const path …用 zlib 来实现 gzip 压缩 服务端优化都是压缩 缓存 前端可以通过 webpack 插件进行压缩 gzip 根据替换来实现的重复率越高压缩后的结果越小 const zlib require(zlib); const fs require(fs); const path require(path);方式一读取文件压缩如果文件大的话都读取到内存中耗内存 zlib.gzip(fs.readFileSync(path.resolve(__dirname, ./65/1.txt)), (err, data) {fs.writeFileSync(path.resolve(__dirname, ./65/2.txt.gz), data); });方式二用转化流可读可写的方式服务端的文件 压缩 客户端 fs.createReadStream(path.resolve(__dirname, ./65/1.txt)).pipe(zlib.createGzip()).pipe(fs.createWriteStream(path.resolve(__dirname, ./65/2.txt.gz)));新建 1.txt 文件用来测试压缩里面写的都是1大概有个 10k 的样子两种方式执行之后都会生成压缩文件 2.txt.gz如下 代码实现 http-server 里的 gzip 压缩 下面实现 http-server 里的 gzip 压缩 实现思路就是根据请求头 header [accept-encoding] 里是否包含 gzip 来判断浏览器是否支持 gzip 压缩如果支持就创建转化流处理。 在上一节的 server.js 里面添加代码如下 // 核心模块 const http require(http); const path require(path); const url require(url); const fs require(fs).promises; const { createReadStream, createWriteStream, readFileSync } require(fs);// 第三方模块 const ejs require(ejs); // 服务端读取目录进行渲染 const mime require(mime); const chalk require(chalk); const debug require(debug)(server); // 根据环境变量来进行打印 process.env.EDBUG debug(hello kaimo-http-server);// 同步读取模板 const template readFileSync(path.resolve(__dirname, template.ejs), utf-8);class Server {constructor(config) {this.host config.host;this.port config.port;this.directory config.directory;this.template template;}async handleRequest(req, res) {let { pathname } url.parse(req.url);// 需要对 pathname 进行一次转义避免访问中文名称文件找不到问题console.log(pathname);pathname decodeURIComponent(pathname);console.log(pathname);// 通过路径找到这个文件返回let filePath path.join(this.directory, pathname);console.log(filePath);try {// 用流读取文件let statObj await fs.stat(filePath);// 判断是否是文件if (statObj.isFile()) {this.sendFile(req, res, filePath, statObj);} else {// 文件夹的话就先尝试找找 index.htmllet concatFilePath path.join(filePath, index.html);try {let statObj await fs.stat(concatFilePath);this.sendFile(req, res, concatFilePath, statObj);} catch (e) {// index.html 不存在就列出目录this.showList(req, res, filePath, statObj, pathname);}}} catch (e) {this.sendError(req, res, e);}}// 列出目录async showList(req, res, filePath, statObj, pathname) {// 读取目录包含的信息let dirs await fs.readdir(filePath);console.log(dirs, -------------dirs----------);try {let parseObj dirs.map((item) ({dir: item,href: path.join(pathname, item) // url路径拼接自己的路径}));// 渲染列表这里采用异步渲染let templateStr await ejs.render(this.template, { dirs: parseObj }, { async: true });console.log(templateStr, -------------templateStr----------);res.setHeader(Content-type, text/html;charsetutf-8);res.end(templateStr);} catch (e) {this.sendError(req, res, e);}}gzip(req, res, filePath, statObj) {if (req.headers[accept-encoding] req.headers[accept-encoding].includes(gzip)) {// 给响应头添加内容编码类型头告诉浏览器内容是什么编码类型res.setHeader(Content-Encoding, gzip);// 创建转化流return require(zlib).createGzip();} else {return false;}}// 读取文件返回sendFile(req, res, filePath, statObj) {// 设置类型res.setHeader(Content-type, mime.getType(filePath) ;charsetutf-8);// 读取文件进行响应// 先判断浏览器是否支持 gzip 压缩let gzip this.gzip(req, res, filePath, statObj);if (gzip) {createReadStream(filePath).pipe(gzip).pipe(res);} else {createReadStream(filePath).pipe(res);}}// 专门处理错误信息sendError(req, res, e) {debug(e);res.statusCode 404;res.end(Not Found);}start() {const server http.createServer(this.handleRequest.bind(this));server.listen(this.port, this.host, () {console.log(chalk.yellow(Starting up kaimo-http-server, serving ./${this.directory.split(\\).pop()}\r\n));console.log(chalk.green( http://${this.host}:${this.port}));});} }module.exports Server;我们启动服务去访问 http://localhost:3000/1.txt kaimo-http-server跟没有压缩的对比如下
http://www.sadfv.cn/news/230572/

相关文章:

  • 建立网站原理鞍山诺亚人才网
  • 温州公司建设网站网站打开慢的解决方法
  • 最高级网站建设中教在线3d建模培训
  • 网站建设三折页制作一个网站步骤
  • 买的有域名怎么做网站tk网站的dns修改
  • 福建省住房和建设厅网站宝安中心是富人区吗
  • 建设部网站监理工程师产品网站开发流程
  • 唐山网站建设方案咨询胶州家园网站建设
  • 常德城乡和住房建设局网站手机ppt免费制作软件
  • 酒仙网技术开发与网站建设方面wordpress表单采集
  • 用电脑做网站的历史在哪里找南京网站建设网站制作
  • 陕西中洋建设工程有限公司网站多个网站域名 是新增接入
  • 福州企业免费建站绘图软件免费版
  • 晋江住房和城乡建设局网站做区块链好的网站
  • 昆明建设网站公司网页版梦幻西游周游方壶
  • 机械东莞网站建设0769客户管理系统排行榜
  • go 做视频网站女装网站建设规划书
  • 能浏览的海外网站百度热搜榜排行
  • 广东网站建设公司报价xp做网站服务器吗
  • 学校网站建设调查问卷北京的互联网公司有哪些
  • 定制网站开发公司wordpress 空白页
  • 网站 建设 计划济南网站建设 刘彬彬
  • 有哪些搜索引擎网站如何自建一个便宜的网站
  • 如何架设网站服务器四川手机网站有哪些
  • 做投标的在什么网站找信息php网站开发试题及答案
  • 国外做问卷赚购物券等的网站wordpress hermit
  • dede电影网站模板南宁做网站培训
  • 网站首页关键字方案wordpress图片加水印
  • 苏州网站制作及推广购物网站seo搜索引擎前期分析
  • 商城类网站建设报价网站建设代理招标