在进行Web开发时,可能遇到遇到以下几种需求:
l 希望某类或者某已知MIME 类型的文件(比如:*.gif;*.txt;*.htm)能够在访问时弹出“文件下载”对话框。
l 希望客户端下载时以指定文件名显示。
l 希望某文件直接在浏览器上显示而不是弹出文件下载对话框。
对于上面的需求,使用Content-Disposition属性就可以解决。下面是代码示例:
response.setHeader("Content-disposition", "attachment;filename=" + fileName)
//Content-disposition为属性名。
//attachment表示以附件方式下载。如果要在页面中打开,则改为inline。
//filename如果为中文,则会出现乱码。解决办法有两种:
//1、使用fileName = new String(fileName.getBytes(), "ISO8859-1")语句
//2、使用fileName = HttpUtility.UrlEncode(filename, System.Text.Encoding.UTF8)语句
---------------------------------------------------------------------------------------------------------------------------
当代码里面使用Content-Disposition来确保浏览器弹出下载对话框的时候。
response.addHeader("Content-Disposition","attachment");
一定要保证
没有做过关于
禁止浏览器缓存的操作。
response.setHeader("Pragma", "No-cache");
response.setHeader("Cache-Control", "No-cache");
response.setDateHeader("Expires", 0);
不然你会像我一样,发现下载功能在opera和firefox里面好好的没问题,在IE下面就是不行,就是找不到文件。死IE,气死我了,调试了一整天!
分享到:
相关推荐
本文将深入探讨Content-Disposition的使用方法及其注意事项,帮助开发者更好地理解和应用这一技术。 一、Content-Disposition的作用 1. 控制文件下载:当设置为 "attachment" 时,浏览器会弹出“文件下载”对话框,...
Content-Disposition: disposition-type [";" disposition-parm] 其中,disposition-type指定了内容应该如何展示,主要有以下几种: - attachment:通常用于指示内容应该被下载,并且在下载时保存为文件,用户通常...
npm install content-dispositionAPI var contentDisposition = require ( 'content-disposition' )contentDisposition(文件名,选项) 使用给定的文件名(如果提供)创建附件Content-Disposition标头值。...
$ npm install content-disposition-parser 用法 const parser = require ( 'content-disposition-parser' ) parser ( 'content-disposition: inline; filename=example.pdf' ) //-> { filename: 'example.pdf', ...
解决这个问题的方法是使用 email 附件名编码方法对文件名进行编码。可以使用 javax.mail.internet.* 包的 MimeUtility.encodeWord("中文.txt") 方法进行编码。例如: response.setHeader("Content-Disposition", ...
标题 "bug-chromium-pdf-content-disposition-encoding" 暗示了一个与 Chromium 浏览器相关的 PDF 文件处理问题,特别是涉及到 `Content-Disposition` 和编码方面。`Content-Disposition` 是一个 HTTP 头部字段,...
MIME使用Internet Assigned Numbers Authority (IANA)作为中心的注册机制来管理Content-Type头域的值,以确保这些值在一个有序而且公开的状态下开发。 在Web开发中,Content-Type头域非常重要,因为它决定了浏览器...
添加头信息Content-Disposition “attachment;”会使浏览器强制下载: 代码如下: #表示浏览器内嵌显示一个文件 Content-disposition: inline; filename=foobar.pdf #表示会下载文件,如火狐浏览器中 Content-...
Content-Disposition: form-data; name=“projectName” testProject ----------------------------904587217962624105581666 Content-Disposition: form-data; name=“clientName” aaa ------------------------...
由于IIS6.0总是采用第一个`Content-Disposition`中的值作为接收参数,因此可以通过发送多次`Content-Disposition`头部来尝试绕过。例如: ```bash ------WebKitFormBoundary2smpsxFB3D0KbA7D Content-Disposition: ...
将数据导出到Excel源代码及方法:response.setContentType("application/vnd.ms-... response.addHeader("Content-Disposition", "attachment;filename=logininfo.xls"); String name = request.getParameter("name");
在标签中提到的“源码”可能意味着该博文或rfc 2183的讨论涉及到实际代码实现,可能是解析或生成Content-Disposition头字段的方法。而“工具”可能指的是有相关的开发工具或者库支持这一标准。 关于rfc 2183的知识...
self.send_header('Content-Disposition', 'attachment; filename=' + self.path[1:]) self.end_headers() with open(self.path[1:], 'rb') as f: self.wfile.write(f.read()) else: self.send_error(404, '...
<< "Content-Disposition: form-data; name=\"key\"\r\n\r\n" << "--" << boundary << "--\r\n"; request = "POST " + url + " HTTP/1.1\r\n" "Host: " + host + "\r\n" "Content-Type: multipart/form-data;...
图形测量题目则让学生学会使用合适的数学工具和方法,去计算图形的周长和面积。此外,统计与概率的基础知识也是测试的一部分,这对于学生理解日常生活中的数据和信息非常重要。 英语学科方面,测试卷会涉及字母书写...
const disposition = response.headers.get('content-disposition'); if (disposition) { const filenameRegex = /filename[^;=\n]*=((['"]).*?\2|[^;\n]*)/; const matches = disposition.match(filenameRegex)...
这段代码检查用户代理字符串,如果检测到是IE浏览器,就使用URLEncoder对文件名进行UTF-8编码,并设置到`Content-Disposition`头中。 然而,非IE浏览器,如Chrome、Firefox等,它们可能不接受这种编码方式,而是更...
这里,“--boundary123456789”定义了数据包之间的边界,“Content-Disposition”头指定了字段名称及是否包含文件名。 #### 三、实现步骤 1. **引入必要的库**: - `commons-fileupload`:用于解析`multipart/...