前后台数据传输压缩(前后台都压缩)

目录传回数据的压缩Response:传入数据的压缩request(前台后台统一压缩方式后台进行解压):配置压缩数据生效:传回数据的压缩Response:package com.pds.report.core.config.mvc;import javax.servlet.*;import javax.servlet.http.HttpServletRequest;im...
摘要由CSDN通过智能技术生成

目录

传回数据的压缩Response:

传入数据的压缩request(前台后台统一压缩方式后台进行解压):

配置压缩数据生效:


传回数据的压缩Response:

package com.pds.report.core.config.mvc;

import javax.servlet.*;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpServletResponseWrapper;
import java.io.*;
import java.util.zip.GZIPOutputStream;

/**
 * @description:
 * @author: yunfei.zhao
 * @date: Created in 2019/9/18 16:24
 * @version: 0.0.1
 * @modified By:
 */
public class GzipFilter implements Filter {
    @Override
    public void init(FilterConfig filterConfig) throws ServletException {

    }

    @Override
    public void doFilter(ServletRequest servletRequest, ServletResponse servletResponse, FilterChain filterChain) throws IOException, ServletException {
        String headEncoding = ((HttpServletRequest) servletRequest).getHeader("accept-encoding");
        if (headEncoding == null || (headEncoding.indexOf("gzip") == -1)) { // 客户端 不支持 gzip
            filterChain.doFilter(servletRequest, servletResponse);
            System.out.println("----------------该浏览器不支持gzip格式编码-----------------");
        } else { // 支持 gzip 压缩,对数据进行gzip压缩

            HttpServletRequest req = (HttpServletRequest) servletRequest;
            HttpServletResponse resp = (HttpServletResponse) servletResponse;
            ResponseWrapper mResp = new ResponseWrapper(resp); // 包装响应对象 resp 并缓存响应数据
            filterChain.doFilter(req, mResp);

            byte[] bytes = mResp.getBytes(); // 获取缓存的响应数据
            System.out.println("压缩前大小:" + bytes.length);
            System.out.println("压缩前数据:" + new String(bytes, "utf-8"));

            ByteArrayOutputStream bout = new ByteArrayOutputStream();
            GZIPOutputStream gzipOut = new GZIPOutputStream(bout); // 创建 GZIPOutputStream 对象

            gzipOut.write(bytes); // 将响应的数据写到 Gzip 压缩流中
            gzipOut.flush();
            gzipOut.close(); // 将数据刷新到  bout 字节流数组

            byte[] bts = bout.toByteArray();
            System.out.println("压缩后大小:" + bts.length);
            resp.setHeader("Content-Encoding", "gzip"); // 设置响应头信息
            resp.setContentLength(-1);
            resp.getOutputStream().write(bts); // 将压缩数据响应给客户端
        }
    }

    @Override
    public void destroy() {

    }

    /**
     * 从response中得到返回的body要实现HttpServletResponseWrapper
     * 同理从request得到传来的body要实现HttpServletRequestWrapper
     */
    class ResponseWrapper extends HttpServletResponseWra
  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 为了保证消息的安全性,可以采用对称加密算法或非对称加密算法。对称加密算法使用同一密钥进行加密和解密,但是密钥需要在消息传输进行共享,因此需要保证密钥的安全性。非对称加密算法使用公钥进行加密,私钥进行解密,因此不需要共享密钥,但是需要保证私钥的安全性。 另外,为了减少网络传输的开销,可以考虑使用消息压缩技术。消息压缩可以将消息的大小减小,从而减少网络传输的开销。常见的消息压缩技术包括gzip、zlib等。在接收方接收到消息后,可以使用相应的解压缩技术进行解压缩,以得到原始的消息。 需要注意的是,加密和解密、压缩和解压缩都会增加计算量和时间延迟,因此需要在安全性和网络传输效率之间进行权衡。 ### 回答2: 为了确保消息的安全性,可以考虑使用加密算法对消息进行加密和解密。加密可以防止未授权的人员获取到消息内容,确保消息的机密性。常见的加密算法有对称加密算法和非对称加密算法。对称加密算法使用相同的密钥进行加密和解密,传输过程中需要确保密钥的安全性;非对称加密算法使用一对公私钥进行加密和解密,发送方使用接收方的公钥进行加密,接收方使用自己的私钥进行解密。 另外,为了减少网络传输的开销,可以考虑消息的压缩和解压缩。传输过大的消息会占用更多的网络带宽和传输时间,影响系统的性能和效率。使用压缩算法可以将消息进行压缩,减少传输时的数据量。常见的压缩算法有Lempel-Ziv-Welch(LZW)算法和Deflate算法等。发送方在发送消息进行压缩,接收方在接收到消息后进行解压缩,恢复消息的原始内容。 消息队列(MQ)是一种用于消息的传输和交换的中间件,用于解耦发送方和接收方的关系,提高系统的可扩展性和稳定性。在使用MQ时,可以结合加密和压缩技术来确保消息的安全性和减少网络传输的开销。发送方在发送消息对消息进行加密和压缩,接收方在接收到消息后进行解密和解压缩,恢复消息的原始内容。这样可以保护消息的内容不被窃取,同时减少网络传输时的数据量,提高传输效率。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值