/**
*application/pdf 设置返回的流的格式
*
*Content-Disposition 设置浏览器对流的处理方式--inline为在浏览器中直接打开,attachment为提供浏览器下载和打开
*
*
*/
HttpServletResponse res=ServletActionContext.getResponse();
res.reset();
res.setContentType("application/pdf;charset=UTF-8");
res.addHeader("Content-Disposition", "inline;filename=\""+pdfName+"\"");
res.addHeader("Content-Disposition","filename="+pdfName);
BufferedOutputStream out=new BufferedOutputStream(res.getOutputStream());
out.write(BASE64.decode(data));
out.close();
不同的ContentType 会影响客户端所看到的效果.默认的ContentType为 text/html 也就是网页格式.
代码如:
<% response.ContentType ="text/html" %>
<!--#i nclude virtual="/ContentType.html" -->
显示的为网页,而
<% response.ContentType ="text/plain" %>
<!--#i nclude virtual="/sscript/ContentType.html" -->
则会显示html原代码.
以下为一些常用的 ContentType
GIF images
<% response.ContentType ="image/gif" %>
<!--#i nclude virtual="/myimage.gif" -->
JPEG images
<% response.ContentType ="image/jpeg" %>
<!--#i nclude virtual="/myimage.jpeg" -->
TIFF images
<% response.ContentType ="image/tiff" %>
<!--#i nclude virtual="/myimage.tiff" -->
MICROSOFT WORD document
<% response.ContentType ="application/msword" %>
<!--#i nclude virtual="/myfile.doc" -->
RTF document
<% response.ContentType ="application/rtf" %>
<!--#i nclude virtual="/myfile.rtf" -->
MICROSOFT EXCEL document
<% response.ContentType ="application/x-excel" %>
<!--#i nclude virtual="/myfile.xls" -->
MICROSOFT POWERPOINT document
<% response.ContentType ="application/ms-powerpoint" %>
<!--#i nclude virtual="/myfile.pff" -->
PDF document
<% response.ContentType ="application/pdf" %>
<!--#i nclude virtual="/myfile.pdf" -->
ZIP document
<% response.ContentType ="application/zip" %>
<!--#i nclude virtual="/myfile.zip" -->
下面是更详细的ContentType
'ez' => 'application/andrew-inset',
'hqx' => 'application/mac-binhex40',
'cpt' => 'application/mac-compactpro',
'doc' => 'application/msword',
'bin' => 'application/octet-stream',
'dms' => 'application/octet-stream',
'lha' => 'application/octet-stream',
'lzh' => 'application/octet-stream',
'exe' => 'application/octet-stream',
'class' => 'application/octet-stream',
'so' => 'application/octet-stream',
'dll' => 'application/octet-stream',
'oda' => 'application/oda',
'pdf' => 'application/pdf',
'ai' => 'application/postscript',
'eps' => 'application/postscript',
'ps' => 'application/postscript',
'smi' => 'application/smil',
'smil' => 'application/smil',
'mif' => 'application/vnd.mif',
'xls' => 'application/vnd.ms-excel',
'ppt' => 'application/vnd.ms-powerpoint',
'wbxml' => 'application/vnd.wap.wbxml',
'wmlc' => 'application/vnd.wap.wmlc',
'wmlsc' => 'application/vnd.wap.wmlscriptc',
'bcpio' => 'application/x-bcpio',
'vcd' => 'application/x-cdlink',
'pgn' => 'application/x-chess-pgn',
'cpio' => 'application/x-cpio',
'csh' => 'application/x-csh',
'dcr' => 'application/x-director',
'dir' => 'application/x-director',
'dxr' => 'application/x-director',
'dvi' => 'application/x-dvi',
'spl' => 'application/x-futuresplash',
'gtar' => 'application/x-gtar',
'hdf' => 'application/x-hdf',
'js' => 'application/x-javascript',
'skp' => 'application/x-koan',
'skd' => 'application/x-koan',
'skt' => 'application/x-koan',
'skm' => 'application/x-koan',
'latex' => 'application/x-latex',
'nc' => 'application/x-netcdf',
'cdf' => 'application/x-netcdf',
'sh' => 'application/x-sh',
'shar' => 'application/x-shar',
'swf' => 'application/x-shockwave-flash',
'sit' => 'application/x-stuffit',
'sv4cpio' => 'application/x-sv4cpio',
'sv4crc' => 'application/x-sv4crc',
'tar' => 'application/x-tar',
'tcl' => 'application/x-tcl',
'tex' => 'application/x-tex',
'texinfo' => 'application/x-texinfo',
'texi' => 'application/x-texinfo',
't' => 'application/x-troff',
'tr' => 'application/x-troff',
'roff' => 'application/x-troff',
'man' => 'application/x-troff-man',
'me' => 'application/x-troff-me',
'ms' => 'application/x-troff-ms',
'ustar' => 'application/x-ustar',
'src' => 'application/x-wais-source',
'xhtml' => 'application/xhtml+xml',
'xht' => 'application/xhtml+xml',
'zip' => 'application/zip',
'au' => 'audio/basic',
'snd' => 'audio/basic',
'mid' => 'audio/midi',
'midi' => 'audio/midi',
'kar' => 'audio/midi',
'mpga' => 'audio/mpeg',
'mp2' => 'audio/mpeg',
'mp3' => 'audio/mpeg',
'aif' => 'audio/x-aiff',
'aiff' => 'audio/x-aiff',
'aifc' => 'audio/x-aiff',
'm3u' => 'audio/x-mpegurl',
'ram' => 'audio/x-pn-realaudio',
'rm' => 'audio/x-pn-realaudio',
'rpm' => 'audio/x-pn-realaudio-plugin',
'ra' => 'audio/x-realaudio',
'wav' => 'audio/x-wav',
'pdb' => 'chemical/x-pdb',
'xyz' => 'chemical/x-xyz',
'bmp' => 'image/bmp',
'gif' => 'image/gif',
'ief' => 'image/ief',
'jpeg' => 'image/jpeg',
'jpg' => 'image/jpeg',
'jpe' => 'image/jpeg',
'png' => 'image/png',
'tiff' => 'image/tiff',
'tif' => 'image/tiff',
'djvu' => 'image/vnd.djvu',
'djv' => 'image/vnd.djvu',
'wbmp' => 'image/vnd.wap.wbmp',
'ras' => 'image/x-cmu-raster',
'pnm' => 'image/x-portable-anymap',
'pbm' => 'image/x-portable-bitmap',
'pgm' => 'image/x-portable-graymap',
'ppm' => 'image/x-portable-pixmap',
'rgb' => 'image/x-rgb',
'xbm' => 'image/x-xbitmap',
'xpm' => 'image/x-xpixmap',
'xwd' => 'image/x-xwindowdump',
'igs' => 'model/iges',
'iges' => 'model/iges',
'msh' => 'model/mesh',
'mesh' => 'model/mesh',
'silo' => 'model/mesh',
'wrl' => 'model/vrml',
'vrml' => 'model/vrml',
'css' => 'text/css',
'html' => 'text/html',
'htm' => 'text/html',
'asc' => 'text/plain',
'txt' => 'text/plain',
'rtx' => 'text/richtext',
'rtf' => 'text/rtf',
'sgml' => 'text/sgml',
'sgm' => 'text/sgml',
'tsv' => 'text/tab-separated-values',
'wml' => 'text/vnd.wap.wml',
'wmls' => 'text/vnd.wap.wmlscript',
'etx' => 'text/x-setext',
'xsl' => 'text/xml',
'xml' => 'text/xml',
'mpeg' => 'video/mpeg',
'mpg' => 'video/mpeg',
'mpe' => 'video/mpeg',
'qt' => 'video/quicktime',
'mov' => 'video/quicktime',
'mxu' => 'video/vnd.mpegurl',
'avi' => 'video/x-msvideo',
'movie' => 'video/x-sgi-movie',
'ice' => 'x-conference/x-cooltalk'
分享到:
相关推荐
总的来说,通过Java Servlet,我们可以方便地处理文件下载和在线预览的需求,无论是PDF还是其他类型的文件。在实际应用中,还需要考虑文件安全、权限控制、错误处理等复杂情况,确保服务的稳定性和安全性。
在网页中实现通过JavaScript调用后台方法来打开.doc文件并在浏览器中查看,是Web开发中的一个常见需求。这种功能主要用于在线文档预览,方便用户无需下载文件就能直接在浏览器窗口内阅读内容。以下将详细解释这个...
"C# 下载不在浏览器打开"这个主题主要关注如何让用户下载文件时,文件不通过浏览器直接打开,而是保存到本地。这通常涉及到HTTP响应头的设置,以及如何触发浏览器的下载行为。以下是对这个主题的详细阐述: 1. **...
在实际应用中,用户可以通过浏览器直接访问这个API地址(例如:http://localhost:60560/download/get_demo_file)来触发文件下载。此外,也可以在网页中添加一个链接,点击后调用这个API,实现下载功能。 总结一下...
在网页中,我们经常需要提供文件下载功能,特别是图片和视频。然而,浏览器有时会根据文件类型自动进行预览,而不是触发下载。针对这一问题,我们可以利用JavaScript和第三方库download.js来实现无论何种文件格式都...
对于文件下载,我们需要设置为"attachment",并提供一个文件名,这样浏览器会知道这是一个需要保存的文件,而不是直接在当前页面上显示。 5. **Content-Type**: 另一个重要的响应头是`Content-Type`,它定义了文件...
接着,设置Content-Type响应头,以指示文件的MIME类型,并设置Content-Disposition响应头,以便浏览器知道如何处理这个文件(如作为附件下载或直接在新窗口中打开)。 以下是一些关键知识点: 1. **C# WebAPI基础*...
在本文档中,我们探讨了如何在Vue.js应用中通过阿里云OSS(Object Storage Service)的URL直接下载文件,并在下载过程中修改文件名。在尝试通过HTML的`<a>`标签直接设置`download`属性来实现重命名失败后,作者选择...
- 使用`<a>`元素的`download`属性来告诉浏览器这是一个文件下载请求,而不是打开一个新的页面。 - 清理操作,通过`window.URL.revokeObjectURL(url)`来释放创建的URL对象。 在实现异步下载文件功能时,开发者需要...
在文件下载场景中,`Content-Type`应设置为对应的文件类型,如"application/pdf",确保浏览器知道这是一个需要下载的文件,而非在当前窗口中打开。 此外,`Authorization`头在认证过程中起到关键作用。当访问受保护...
在处理文件下载请求时,需要设置HTTP响应头,以告诉浏览器接收的数据类型以及如何处理这些数据。代码如下所示: ```java response.setContentType("application/zip"); response.setHeader("Content-Disposition", ...
在Java编程环境中,HttpClient库是Apache HTTP Components项目的一部分,它为开发者提供了强大的HTTP客户端功能,可以...通过理解HttpClient的工作原理和提供的API,开发者可以构建出稳定、高效的文件下载解决方案。
首先,读取TXT文件的基本步骤包括打开文件、读取内容和关闭文件。在ASP.NET中,我们可以使用System.IO命名空间下的StreamReader类来完成这个任务。以下是一个简单的示例: ```csharp using System.IO; public ...
标题“ie直接打开pdf、图片”涉及到的是在Internet Explorer(IE)浏览器中直接预览PDF文件和图片的技术实现。在Web开发中,提供这样的功能可以提高用户体验,避免用户需要下载文件后再用专门的软件打开。这里我们将...
filename=filename.ext`,这样浏览器就会提示用户保存文件,而不是直接在浏览器中打开。 5. **响应体**:将文件流写入到`ResponseEntity`的body中,然后返回这个实体。 **安全考虑** 在处理文件上传和下载时,...
在Struts中实现文件下载是一项常见的功能,尤其在处理用户请求获取服务器上的静态或动态资源时。这篇博文将深入探讨如何在Struts框架下实现文件下载的功能。 首先,我们需要了解文件下载的基本原理。当用户点击下载...
为了实现上述文件下载功能,通常会在Ant Design Pro项目中编写对应的API接口函数和服务。例如,在`src/service/api.js`中定义数据请求的API: ```javascript import request from '@/utils/request'; export async...
本源代码实现了B/S(浏览器/服务器)架构下的文件下载功能,适应于ASP.NET开发环境,能够支持多种文件格式,并且可以直接运行。 在ASP.NET中,文件下载通常涉及到以下几个关键知识点: 1. **HTTP协议**:文件下载...
以下是一篇关于如何在Android中实现Http文件下载的详细讲解。 首先,我们需要理解Http协议。Http(超文本传输协议)是互联网上应用最广泛的一种网络协议,用于从Web服务器传输超文本到本地浏览器。在Android中,...
在这个场景中,我们将探讨如何使用CGI来实现在网页上提供文件下载的功能。 一、CGI基础 1. CGI原理:当用户通过浏览器访问一个特定的CGI程序时,Web服务器会接收请求并转发给CGI应用。CGI应用处理请求,生成响应...