response导出本地文件

转载自:Response 输出方式,输出字符和文件流_ZxmSeed

private void downloadFile(HttpServletRequest request, HttpServletResponse response)

            throws Exception {

        String wechatUrl = request.getParameter("wechatUrl");

        String access_token = request.getParameter("access_token");

        String mediaId = request.getParameter("media_id");

        System.out.println("===>mediaId:" + mediaId);

        StringBuffer sb = new StringBuffer();

        sb.append(wechatUrl).append("?access_token=").append(access_token).append("&media_id=").append(mediaId);

        URL _url = new URL(sb.toString());

        HttpURLConnection conn = (HttpURLConnection) _url.openConnection();

        // 连接超时

        conn.setConnectTimeout(25000);

        // 读取超时 --服务器响应比较慢,增大时间

        conn.setReadTimeout(25000);

        conn.setRequestMethod("POST");

        conn.setRequestProperty("Content-Type""Keep-Alive");

        conn.setRequestProperty("User-Agent", HttpRequest.DEFAULT_USER_AGENT);

        conn.setDoOutput(true);

        conn.setDoInput(true);

        conn.connect();

        String ds = conn.getHeaderField("Content-disposition");

        response.setHeader("Content-disposition", ds);

        OutputStream outputStream = null;

        try {

            outputStream = response.getOutputStream();

            InputStream istram = conn.getInputStream();

            int read;

            while ((read = istram.read()) != -1) {

                outputStream.write(read);

            }

            outputStream.flush();

        catch (Exception e) {

        finally {

            if (outputStream != null) {

                try {

                    outputStream.close();

                catch (IOException e) {

                    e.printStackTrace();

                }

            }

            if (conn != null) {

                conn.disconnect();

            }

        }

    }

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
EasyExcel是一个基于Java的Excel操作工具,支持读取、写入、复制、合并、样式设置等操作,同时支持大数据量的读写和导出。 如果要使用EasyExcel导出文件到本地,可以按照以下步骤进行操作: 1. 添加依赖:在pom.xml中添加EasyExcel的依赖: ```xml <dependency> <groupId>com.alibaba</groupId> <artifactId>easyexcel</artifactId> <version>2.2.6</version> </dependency> ``` 2. 创建Excel文件:使用EasyExcel提供的注解标记数据模型,并创建ExcelWriter对象,指定输出文件路径。 ```java // 1. 创建输出流 OutputStream out = new FileOutputStream("output.xlsx"); // 2. 创建 ExcelWriter 对象 ExcelWriter writer = new ExcelWriter(out, ExcelTypeEnum.XLSX); // 3. 构造要写入的数据 List<DemoData> dataList = new ArrayList<>(); dataList.add(new DemoData("张三", 18)); dataList.add(new DemoData("李四", 20)); // 4. 指定 Sheet 名称 Sheet sheet1 = new Sheet(1, 0, DemoData.class); sheet1.setSheetName("第一个Sheet"); // 5. 写入数据 writer.write(dataList, sheet1); // 6. 关闭资源 writer.finish(); out.close(); ``` 3. 下载Excel文件:通过Java的文件IO操作,将Excel文件下载到本地。 ```java // 1. 打开文件流 InputStream inputStream = new FileInputStream("output.xlsx"); // 2. 设置响应头 response.setContentType("application/octet-stream"); response.setHeader("Content-disposition", "attachment;filename=output.xlsx"); // 3. 下载文件到本地 ServletOutputStream outputStream = response.getOutputStream(); byte[] bytes = new byte[1024]; int len; while ((len = inputStream.read(bytes)) != -1) { outputStream.write(bytes, 0, len); } outputStream.close(); inputStream.close(); ```

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值