Java下载文件的四种方式详细代码

//下载前端代码
function docDownload(path){

    var url = appName+'/minIOExtend/download.do';
    window.open(url+"?path="+path);
}

1.以流的方式下载

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

public HttpServletResponse download(String path, HttpServletResponse response) {

        try {

            // path是指欲下载的文件的路径。

            File file = new File(path);

            // 取得文件名。

            String filename = file.getName();

            // 取得文件的后缀名。

            String ext = filename.substring(filename.lastIndexOf(".") + 1).toUpperCase();

  

            // 以流的形式下载文件。

            InputStream fis = new BufferedInputStream(new FileInputStream(path));

            byte[] buffer = new byte[fis.available()];

            fis.read(buffer);

            fis.close();

            // 清空response

            response.reset();

            // 设置response的Header

            response.addHeader("Content-Disposition", "attachment;filename=" + new String(filename.getBytes()));

            response.addHeader("Content-Length", "" + file.length());

            OutputStream toClient = new BufferedOutputStream(response.getOutputStream());

            response.setContentType("application/octet-stream");

            toClient.write(buffer);

            toClient.flush();

            toClient.close();

        } catch (IOException ex) {

            ex.printStackTrace();

        }

        return response;

    }

2.下载本地文件

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

public void downloadLocal(HttpServletResponse response) throws FileNotFoundException {

        // 下载本地文件

        String fileName = "Operator.doc".toString(); // 文件的默认保存名

        // 读到流中

        InputStream inStream = new FileInputStream("c:/Operator.doc");// 文件的存放路径

        // 设置输出的格式

        response.reset();

        response.setContentType("bin");

        response.addHeader("Content-Disposition", "attachment; filename=\"" + fileName + "\"");

        // 循环取出流中的数据

        byte[] b = new byte[100];

        int len;

        try {

            while ((len = inStream.read(b)) > 0)

                response.getOutputStream().write(b, 0, len);

            inStream.close();

        } catch (IOException e) {

            e.printStackTrace();

        }

    }

3.下载网络文件

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

public void downloadNet(HttpServletResponse response) throws MalformedURLException {

        // 下载网络文件

        int bytesum = 0;

        int byteread = 0;

  

        URL url = new URL("windine.blogdriver.com/logo.gif");

  

        try {

            URLConnection conn = url.openConnection();

            InputStream inStream = conn.getInputStream();

            FileOutputStream fs = new FileOutputStream("c:/abc.gif");

  

            byte[] buffer = new byte[1204];

            int length;

            while ((byteread = inStream.read(buffer)) != -1) {

                bytesum += byteread;

                System.out.println(bytesum);

                fs.write(buffer, 0, byteread);

            }

        } catch (FileNotFoundException e) {

            e.printStackTrace();

        } catch (IOException e) {

            e.printStackTrace();

        }

    }

4.支持在线打开的方式

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

public void downLoad(String filePath, HttpServletResponse response, boolean isOnLine) throws Exception {

        File f = new File(filePath);

        if (!f.exists()) {

            response.sendError(404, "File not found!");

            return;

        }

        BufferedInputStream br = new BufferedInputStream(new FileInputStream(f));

        byte[] buf = new byte[1024];

        int len = 0;

  

        response.reset(); // 非常重要

        if (isOnLine) { // 在线打开方式

            URL u = new URL("file:///" + filePath);

            response.setContentType(u.openConnection().getContentType());

            response.setHeader("Content-Disposition", "inline; filename=" + f.getName());

            // 文件名应该编码成UTF-8

        } else { // 纯下载方式

            response.setContentType("application/x-msdownload");

            response.setHeader("Content-Disposition", "attachment; filename=" + f.getName());

        }

        OutputStream out = response.getOutputStream();

        while ((len = br.read(buf)) > 0)

            out.write(buf, 0, len);

        br.close();

        out.close();

    }

### 构建任务失败解决方案 当遇到 `Execution failed for task ':app:shrinkReleaseRes'` 错误时,这通常意味着资源压缩过程中出现了问题。此错误可能由多种原因引起,包括但不限于配置不正确、依赖冲突或特定于项目的其他因素。 #### 可能的原因分析 1. **ProGuard 或 R8 配置不当** ProGuard R8 是用于优化混淆代码以及减少 APK 大小的工具。如果这些工具的配置存在问题,可能会导致资源无法正常处理[^1]。 2. **重复资源** 如果项目中有多个模块定义了相同的资源名称,可能导致冲突并引发该错误。检查是否存在重名的 drawable、string 等资源文件[^2]。 3. **第三方库兼容性** 某些第三方库可能当前使用的 Gradle 插件版本或其他库存在兼容性问题,从而影响到资源打包过程中的行为[^3]。 4. **Gradle 缓存问题** 有时旧缓存数据会干扰新编译的结果,尝试清理本地仓库重新同步项目可以帮助排除此类潜在障碍[^4]。 #### 推荐的操作方法 为了有效解决问题,建议按照以下步骤逐一排查: ```bash # 清理项目构建目录 ./gradlew clean # 删除 .gradle 文件夹下的所有内容以清除缓存 rm -rf ~/.gradle/caches/ ``` 调整 `build.gradle` 中的相关设置也是一个重要环节: ```groovy android { ... buildTypes { release { minifyEnabled true // 是否启用代码缩减 shrinkResources true // 是否开启资源压缩 proguardFiles getDefaultProguardFile('proguard-android-optimize.txt'), 'proguard-rules.pro' // 尝试禁用 shrinkResources 来测试是否为资源压缩引起的错误 // shrinkResources false } } } ``` 此外,在 `proguard-rules.pro` 文件内添加必要的保留规则,防止关键类被意外移除: ```text -keep class com.example.yourpackage.** { *; } # 替换为你自己的包路径 -dontwarn androidx.**,com.google.** # 忽略警告信息 ``` 最后,确保所使用的 Android Studio 版本是最新的稳定版,并且已经应用了所有的补丁更新。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值