java解析zip文件_java解压zip文件

java解析zip文件_java解压zip文件编写Filter/***GZIP处理Filter*/@WebFilter(filterName=”httpServletGzipFilter”,urlPatterns=”/”)publicclassHttpServletGzipFilterimplementsFilter{@Overridepublicvoiddestroy(){}…

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

编写Filter

/** * GZIP处理Filter */
@WebFilter(filterName = "httpServletGzipFilter", urlPatterns = "/")
public class HttpServletGzipFilter implements Filter { 
   
    @Override
    public void destroy() { 
   }
    @Override
    public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException, ServletException { 
   
        chain.doFilter(new HttpServletRequestWrapper((HttpServletRequest) request), response);
    }
    @Override
    public void init(FilterConfig arg0) throws ServletException { 
   }
}

@Slf4j
class HttpServletRequestWrapper extends javax.servlet.http.HttpServletRequestWrapper { 
   
    private HttpServletRequest request;

    public HttpServletRequestWrapper(HttpServletRequest request) { 
   
        super(request);
        this.request = request;
    }
    
    /** * 根据 request header 的 Content-Encoding 判断是否启用 gzip 解压数据流 * @return * @throws IOException */
    @Override
    public ServletInputStream getInputStream() throws IOException { 
   
        ServletInputStream stream = request.getInputStream();
        String contentEncoding = request.getHeader("Content-Encoding");
        if (null != contentEncoding && contentEncoding.indexOf("gzip") != -1) { 
   
            try { 
   
                final GZIPInputStream gzipInputStream = new GZIPInputStream(stream);
                ServletInputStream newStream = new ServletInputStream() { 
   
                    @Override
                    public int read() throws IOException { 
   
                        return gzipInputStream.read();
                    }

                    @Override
                    public boolean isFinished() { 
   
                        return false;
                    }

                    @Override
                    public boolean isReady() { 
   
                        return false;
                    }

                    @Override
                    public void setReadListener(ReadListener readListener) { 
   }
                };
                return newStream;
            } catch (Exception e) { 
   
                log.error("uncompress content fail.", e);
            }
        }

        return stream;
    }
}

注册Filter交给Spring管理

@Configuration
public class HttpServletFilterConfig { 
   
    /** * 注册 HttpServletFilter * * @return */
    @Bean
    public FilterRegistrationBean filterRegistrationBean() { 
   
        FilterRegistrationBean registrationBean = new FilterRegistrationBean();
        registrationBean.setFilter(new HttpServletGzipFilter());

        List<String> urlPatterns = new ArrayList<>();
        urlPatterns.add("/*");
        registrationBean.setUrlPatterns(urlPatterns);

        return registrationBean;
    }
}

Controller中获取Request body数据

public abstract class BaseController { 
   
    /** * 获取GZIP解压后的消息体 * * @param request * @return */
    protected String getRequestBody(HttpServletRequest request) { 
   
        try { 
   
            ServletInputStream inputStream = request.getInputStream();
            BufferedReader reader = new BufferedReader(new InputStreamReader(inputStream, "UTF-8"));
            StringBuilder sb = new StringBuilder();
            String line;
            while ((line = reader.readLine()) != null) { 
   
                sb.append(line);
            }

            return sb.toString();
        } catch (UnsupportedEncodingException e) { 
   
            e.printStackTrace();
        } catch (IOException e) { 
   
            e.printStackTrace();
        }
        return null;
    }
}

测试验证

编写测试请求处理器,并使用okhttp进行验证。

@RestController
@RequestMapping("/gzip")
public class testController extends BaseController { 
   
    @RequestMapping(value = "/requstData")
    public String requstData(HttpServletRequest request) { 
   
        return getRequestBody(request);
    }
}

编写gzip测试类

public class GzipTest { 
   
    public static final MediaType JSON = MediaType.get("application/json; charset=utf-8");

    @Test
    public void gzipTest() { 
   
        String url = "http://localhost:8080/gzip/requstData";
        String str = "%5-1sdf22322222sedssf测试sdklasdkgnfffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff!@#$%^&****()_+=";
        try { 
   
            String responseData = post(url, str);
            System.out.println(responseData);
        } catch (IOException e) { 
   
            e.printStackTrace();
        }
    }

    public String post(String url, String json) throws IOException { 
   
        OkHttpClient client = new OkHttpClient.Builder()
        		// 通过GzipRequestInterceptor类拦截响应,自动处理gzip解压
                .addInterceptor(new GzipRequestInterceptor())
                .build();

        RequestBody body = RequestBody.create(json, JSON);
        Request request = new Request.Builder()
                .url(url)
                .post(body)
                .build();
        try (Response response = client.newCall(request).execute()) { 
   
            return response.body().string();
        }
    }

    class GzipRequestInterceptor implements Interceptor { 
   
        @Override
        public Response intercept(Chain chain) throws IOException { 
   
            Request originalRequest = chain.request();
            if (originalRequest.body() == null || originalRequest.header("Content-Encoding") != null) { 
   
                return chain.proceed(originalRequest);
            }

            Request compressedRequest = originalRequest.newBuilder()
                    .header("Content-Encoding", "gzip")
                    .method(originalRequest.method(), gzip(originalRequest.body()))
                    .build();
            return chain.proceed(compressedRequest);
        }

        private RequestBody gzip(final RequestBody body) { 
   
            return new RequestBody() { 
   
                @Override
                public MediaType contentType() { 
   
                    return body.contentType();
                }

                @Override
                public long contentLength() { 
   
                    // We don't know the compressed length in advance!
                    return -1;
                }

                @Override
                public void writeTo(BufferedSink sink) throws IOException { 
   
                    BufferedSink gzipSink = Okio.buffer(new GzipSink(sink));
                    body.writeTo(gzipSink);
                    gzipSink.close();
                }
            };
        }
    }
}

测试结果
在这里插入图片描述

参考文献

https://www.jianshu.com/p/a9d861732445
https://blog.csdn.net/aiynmimi/article/details/77453809

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/196427.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 如何制作whl文件「建议收藏」

    如何制作whl文件「建议收藏」wheel文件Wheel和Egg都是python的打包格式,目的是支持不需要编译或制作的安装过程,实际上也是一种压缩文件,将.whl的后缀改为.zip即可可看到压缩包里面的内容。按照官网说法,wheels是发行版Python的新标准并且要取代.egg。Egg格式是由setuptools在2004年引入,而Wheel格式是由PEP427在2012年定义。Wheel现在被认为是Python的二…

    2022年5月7日
    114
  • MySQL中JOIN的用法

    MySQL中JOIN的用法JOIN 用于连表查询 主要有 5 种用法 下面分别演示这 5 种用法随便建 2 张表 结构如下字段 col1 用来使两张表有一个同名字段的 但其实没什么用 一 笛卡尔积 CROSSJOINCRO 使两张表的所有字段直接进行笛卡尔积 假设表 1 有 m 条数据 表 2 有 n 条数据 则结果数量为 m n 条 SELECT FROMtab1CROS 结果二 内连接 INNERJOIN 内连接需要用 ON 来指定两张表需要比较的字段 最终结果只显示满足条件的数据

    2025年9月16日
    3
  • Java审计之SQL注入篇

    Java审计之SQL注入篇0x00前言本篇文章作为JavaWeb审计的一个入门文,也是我的第一篇审计文,后面打算更新一个小系列,来记录一下我的审计学习的成长。0x01JDBC注入分析

    2021年12月12日
    66
  • java分布式(分布式架构)「建议收藏」

    java分布式(分布式架构)「建议收藏」【声明:版权所有,欢迎转载,请勿用于商业用途。联系信箱:feixiaoxing@163.com】开头的话,架构多半和业务关联在一起,如果只是简单的图书管理系统、选课系统或者什么简单的财务系统,用不着分布式。只有大型公司、高并发的业务才需要分布式的帮助。当然,架构本身要和业务模型紧密配合才能发挥作用。很长一段时间,java都是最流行的编程语言。我想,一方面…

    2022年4月30日
    80
  • qmake中文官方文档

    qmake中文官方文档qmakeQMake提供了一个用于管理应用程序,库,其他组件的构建过程的面向工程系统QMake扩展了每个工程文件的信息,生成一个执行编译和连接过程的Makefile本文翻译自Qt4.8官方文档。一、QMake使用QMake提供了一个用于管理应用程序、库、其它组件的构建过程的面向工程系统。QMake扩展了每个工程文件的信息,生成一个执行编译和链接过程的必须命令的MakeFile。1、描述工程工程文件.pro描述了工程信息。工程文件信息会被qmake用于生成包含构建过程中所需的所有命令的Mak

    2022年5月19日
    44
  • Windows 8或不再支持1394接口「建议收藏」

    Windows 8或不再支持1394接口「建议收藏」根据上月底泄露的Windows8开发规划,微软新操作系统将提供对USB3.0、蓝牙3.0+HS等新外设接口的支持,而“古老”的IEEE1394接口却没有丝毫提及。有媒体因此猜测,Windows8很可能将放弃对IEEE1394的支持。  IEEE1394接口标准于1995年颁布,由苹果主持推动,但其中的大部分技术标准来自德州仪器、索尼、DEC、IBM、意法半导体等企…

    2025年7月18日
    4

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号