在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");
}
}