概述
在JDK中提供了GZIP压缩,来压缩网页的内容,降低网络传输时候的字节数,到达浏览器端的时候,再解压,GZIP压缩之后传输耗费的流量大大降低,但是同时也不会降低用户体验。
package day04;
import java.io.ByteArrayOutputStream;
import java.io.IOException;
import java.util.zip.GZIPOutputStream;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
/**
* @author mzy
*/
public class ContentServlet extends HttpServlet {
private static final long serialVersionUID = 3505039773816640152L;
public void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
response.setContentType("text/html;charset=utf-8");
// 准备内容
StringBuffer sb = new StringBuffer();
for (int i=1; i<=3000; i++) {
sb.append("abcd");
}
System.out.println("压缩前的数据大小:"+sb.toString().getBytes().length);
// 输出到浏览器
// response.getWriter().write(sb.toString());
/*
* 对网页内容进行gzip格式进行压缩
*
* 使用ByteArrayOutputStream作为缓存
* 直接有个toByteArray方法!
*
* 压缩前:12000B
* 压缩后:51B
*/
// 1) 创建一个临时缓存容器
ByteArrayOutputStream buf = new ByteArrayOutputStream();
// 2) 创建GZIPOutputStream
GZIPOutputStream gzip = new GZIPOutputStream(buf);
// 3) 进行压缩
gzip.write(sb.toString().getBytes());
// 4) 调用结束方法,把缓存内容刷新
gzip.finish();
// 5) 得到压缩后的内容
byte[] result = buf.toByteArray();
System.out.println("压缩后的数据大小:"+result.length);
// 因为压缩成了字节,所以不能使用Writer了
// 必须使用outputStream了
response.getOutputStream().write(result);
/*
* 告诉浏览器,是通过GZIP压缩过的内容;
* 不然没有办法正常解析。
* 通过响应头!
*/
response.setHeader("content-encoding", "gzip");
}
public void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
request.setCharacterEncoding("utf-8");
response.setContentType("text/html;charset=utf-8");
}
}
转载于:https://www.cnblogs.com/mzywucai/p/11053414.html
最后
以上就是英俊钻石为你收集整理的使用GZIP压缩网页内容(一)的全部内容,希望文章能够帮你解决使用GZIP压缩网页内容(一)所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
发表评论 取消回复