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

男女做那个的免费视频网站门户网站营销怎么做

男女做那个的免费视频网站,门户网站营销怎么做,宁波网站制作公司,故城网站建设用 zlib 来实现 gzip 压缩 服务端优化都是:压缩 缓存 前端可以通过 webpack 插件进行压缩 gzip 根据替换来实现的,重复率越高,压缩后的结果越小 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;charset=utf-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) + ";charset=utf-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.yayakq.cn/news/301408/

相关文章:

  • 网站建设投资预算利用织梦搭网站
  • 南阳网站排名优化公司去黄山旅游大概要多少钱
  • 龙海市住房和城乡建设局网站wordpress进销存插件
  • 国内家居行业网站开发深圳网站建设服务联系方式
  • 怎样设置默认网站网站demo制作
  • 淘客网站做百度推广wordpress 收费下载系统
  • 建设银行个人网站打不开什么作为国内的主要门户网站
  • 网站被管理员权限品牌设计网站怎么做
  • 免费网站如何做宣传专做外贸的网站有哪些
  • 专门做民宿的网站有哪些建设银行网站关闭闪付
  • 超级简历网站不是搜索网站的是
  • 苏州建网站的公司哪家口碑好网页制作与网站建设实战大全pdf
  • 建设干部学校网站首页中国建设银行开放式网站
  • 商丘旅游网站的建设汉中建设工程
  • 淮安企业网站制作零基础网站建设
  • 龙华网站开发公司电话360网站建设搜索
  • 静态网站开发考虑什么wordpress如何加入点赞
  • 做网站好还是做微信小程序好诏安建设局网站
  • 成品网站w灬源码火龙果购门户网站系统
  • 科技公司网站 asp源码wordpress 文章 排序
  • 九年级上册信息技术做网站广西建设教育学会网站
  • 郑州大型网站开发公司小程序搭建赚钱吗
  • 网站建设自查自评网站优化公司哪家效果好
  • 怎么建企业自己的网站吗网站vps
  • 免费ppt下载网站有哪些小程序宣传推广方案
  • 股票配资网站建设效果图网站排行榜前十名
  • 佳木斯市城乡建设局网站深圳网站开发运营公司
  • 网站建设大连wordpress默认主题修改
  • wordpress门户站西安网络推广公司大全
  • 北京城乡建设门户网站wordpress文章标题前显示置顶