您好,欢迎来到六九路网。
搜索
您的当前位置:首页js下载文件的实现方法一

js下载文件的实现方法一

来源:六九路网
js下载文件的实现方法一

f8b js下载文件的实现方法及注意

js中实现文件下载 (一)

最简单的方式是在页上做超级链接如:<a href="music/abc.m3">下载</a>。

但是这样服务器上的目录资源会直接暴露给最终用户会给站带来一些不安全的因素。

因此可以采用其它方式实现下载可以采用:

1、RequestDisatcher的方式进行;

2、采用文件流输出的方式下载。(推荐)

1、采用RequestDisatcher的方式进行 Js代码 <%

resonse.setContentTye("alication/x-download");//设置为下载alication/x-download

String filedownload = "/要下载的文件名";//即将下载的文件的相对径

String filedislay = "最终要显示给用户的保存文件名";//下载文件时显示的文件保存名称

String filenamedislay = URLEncoder.encode(filedislay,"UTF-8"); resonse.addHeader("Content-Disosition","attachment;filename=" + filedislay); try {

RequestDisatcher dis = alication.getRequestDisatcher(filedownload);

if(dis!= null) {

dis.forward(request,resonse); }

resonse.flushBuffer(); }

catch(Excetion e) {

e.rintStackTrace(); } finally { } %> <%

resonse.setContentTye("alication/x-download");//设置为下载alication/x-download

String filedownload = "/要下载的文件名";//即将下载的文件的相对径

String filedislay = "最终要显示给用户的保存文件名";//下载文件时显示的文件保存名称

String filenamedislay = URLEncoder.encode(filedislay,"UTF-8"); resonse.addHeader("Content-Disosition","attachment;filename=" + filedislay); try {

RequestDisatcher dis = alication.getRequestDisatcher(filedownload); if(dis!= null) {

dis.forward(request,resonse); }

resonse.flushBuffer(); }

catch(Excetion e) {

e.rintStackTrace(); } finally { } %>

2、采用文件流输出的方式下载 Js代码 <%age

language="java"

contentTye="alication/x-msdownload" ageEncoding="gb2312"%> <%

//关于文件下载时采用文件流输出的方式处理:

//加上resonse.reset()并且所有的%>后面不要换行包括最后一个;

resonse.reset();//可以加也可以不加

resonse.setContentTye("alication/x-download");

//alication.getRealath("/main/mvlayer/CaSetu.msi");获取的物理径

String filedownload = "想办法找到要提下载的文件的物理径+文件名";

String filedislay = "给用户提的下载文件名";

String filedislay = URLEncoder.encode(filedislay,"UTF-8"); resonse.addHeader("Content-Disosition","attachment;filename=" + filedislay);

java.io.OututStream out =

null; java.io.FileInutStream in = null; try {

out = resonse.getOututStream();

in = new FileInutStream(filenamedownload);

byte[] b = new byte[1024]; int i = 0;

while((i = in.read(b)) > 0)

{

out.write(b, 0, i); } // out.flush();

//要加以下两句话否则会报错

//java.lang.IllegalStateExcetion: getOututStream() has already been called for //this resonse out.clear();

out = ageContext.ushBody(); }

catch(Excetion e) {

System.out.rintln("Error!"); e.rintStackTrace(); } finally {

if(in != null) { in.close(); in = null;

}

//这里不能关闭 //if(out != null) //{

//out.close(); //out = null; //} } %> <%age

language="java"

contentTye="alication/x-msdownload" ageEncoding="gb2312"%> <%

//关于文件下载时采用文件流输出的方式处理:

//加上resonse.reset()并且所有的%>后面不要换行包括最后一个;

resonse.reset();//可以加也可以不加

resonse.setContentTye("alication/x-download");

//alication.getRealath("/main/mvlayer/CaSetu.msi");获取的物理径

String filedownload = "想办法找到要提下载的文件的物理径+文件名"; String fi fc1

ledislay = "给用户提的下载文件名";

String filedislay = URLEncoder.encode(filedislay,"UTF-8"); resonse.addHeader("Content-Disosition","attachment;filename=" + filedislay);

java.io.OututStream out = null; java.io.FileInutStream in = null; try {

out = resonse.getOututStream();

in = new FileInutStream(filenamedownload);

byte[] b = new byte[1024]; int i = 0;

while((i = in.read(b)) > 0) {

out.write(b, 0, i);

} // out.flush();

//要加以下两句话否则会报错

//java.lang.IllegalStateExcetion: getOututStream() has already been called for //this resonse out.clear();

out = ageContext.ushBody(); }

catch(Excetion e) {

System.out.rintln("Error!"); e.rintStackTrace(); } finally {

if(in != null) { in.close(); in = null; }

//这里不能关闭

//if(out != null) //{

//out.close(); //out = null; //} } %>

对于第二种方法我认为应该是比较常用的。不过有几个地方是值得我们注意的:

一、采用第二种方法的主要优点是实际文件的存放径对客户端来说是透明的。

这个文件可以存在于任何你的服务器能够取得到的地方而客户端不一定能直接得到。例如文件来自于数据库或者内部络的一个FT服务器。还句话说这种方式可以实现隐藏实际文件的URL。

二、为了防止客户端浏览器直接打开目标文件(例如在装了MS Office套

件的Windows

中的IE浏览器可能就会直接在IE浏览器中打开你想下载的doc或者xls文件)你必须在响应头里加入强制下载的MIME类型:

resonse.setContentTye("alication/force-download");//设置为下载alication/force-download

这样就可以保证在用户下载链接的时候浏览器一定会弹出提示窗口来询问你是下载还是直接打开并允许你选择要打开的应用程序除非你设置了浏览器的一些默认行为。

或者你想让客户端自行处理各种不同的文件类型你可以在服务器的配置文件中配置MIME类型映射通过简单的判断文件后缀名来处理。例如在Tomcat中设置MIME响应类型:

如果文件在客户端中的响应程序类型和期望不一致修改$TOMCAT_HOME\\conf\\web.xml文件中的如下部分: <mime-maing>

<extension>zi</extension> <mime-tye>alication/zi</mime-tye> </mime-maing> <mime-maing>

<extension>mht</extension>

<mime-tye>message/rfc822</mime-tye> </mime-maing> ……

三、在响应头中尽量不要设置浏览器缓存期限。

有时候用户在了下载链接后在弹出窗口中用户想直接“打开”而不想保存到指定径。这时候如果我们在响应头中了不允许使用浏览器缓存(即总是刷新)在IE浏览器中我们将无法直接打开该文件。因为了不允许使用缓存浏览器无法将文件保存到临时文件夹(即缓存)。 也就是说在响应头中不要进行如下的设置(已注释):

//resonse.addHeader("ragma","NO-cache"); //resonse.addHeader("Cache-Control","no-cache"); //resonse.addDateHeader("Exries",0);

四、文件名为中文或其他unicode字符时的处理。

有时候提下载的文件名中包含中文字符或者其他unicode字符会导致浏览器无法正确的采用默认的文件名保存文件。我们应该记住在响应头中包含filename字段并采用ISO8859-1编码(推荐)或者采用UTF-8编码: resonse.setHeader("Content-disosition","attachment; filename="+new

String(filename.getBytes("UTF-8"),"iso8859-1")); //采用ISO8859-1编码

resonse.setHeader("Content-disosition","attachment; filename="+URLEncoder.encode(filename, "UTF-8")); //采用UTF-8编码

但是这种方式在不同的浏览器中表现也有所不同。例如在IE和Firefox中采用ISO8859-1编码可以正确显示文件名而在Oera中不管采用那种编码默认保存的文件名都无法做到正确显示。

所以最好的方法其实就是尽量在文件名中使用ascii编码。

五、由于采用流的方式进行输入输出我们必须保证在使用完毕后关闭流的资源。

一般我们把关闭流的操作放在finally块中以保证在程序段结束前一定会关闭流的资源:

InutStream is = null;

ServletOututStream sos = null; try { is

= ...; //通过某种方式读进数据到输入流 sos = resonse.getOututStream(); //打开输入流

byte[] buff = new byte[2048]; int bytesRead;

while(-1 != (bytesRead = bis.read(buff, 0, buff.length))) { sos.write(buff,0,bytesRead); sos.flush(); }

} catch(IOExcetion ex) {

//TODO something with IOExcetion } catch(Excetion ex) { //TODO somethin 9b

g with Excetion } finally { if(is != null) {

is.close(); //关闭输入流 }

if(sos != null) {

sos.close(); //关闭输入流 } }

0

因篇幅问题不能全部显示,请点此查看更多更全内容

Copyright © 2019- 69lv.com 版权所有 湘ICP备2023021910号-1

违法及侵权请联系:TEL:199 1889 7713 E-MAIL:2724546146@qq.com

本站由北京市万商天勤律师事务所王兴未律师提供法律服务