如何通过一个文件的下载链接(url)获取到需要下载的文件名称是我们经常要遇到的一个问题。本文提供两种解决办法,基本上这两种解决办法结合可以处理大部分情况。
一、获取header字段Content-Disposition
Content-disposition 是 MIME 协议的扩展,MIME 协议指示 MIME 用户代理如何显示附加的文件。Content-disposition其实可以控制用户请求所得的内容存为一个文件的时候提供一个默认的文件名,文件直接在浏览器上显示或者在访问时弹出文件下载对话框。
该字段包含了两种返回值:
1、inline:将文件内容直接显示在页面
Content-Disposition: inline;filename=hello.jpg
2、attachment:弹出对话框让用户下载
Content-Disposition: attachment;filename=hello.jpg
可以看出无论是哪种返回值,其中都包括了filename,“=”后面就是我们需要的文件名称。
这里会出现一个问题,获取到的文件名称可能会出现中文乱码的情况。
具体原因可查看:https://blog.robotshell.org/2012/deal-with-http-header-encoding-for-file-download/
二、通过Url.getFile()获取
Url中的fil