jsp文件下载完整方法 jsp调用js文件方法

第一种:

就是直接给出下载的地址,这种方式很不好,因为会暴露你的地址,带来很多不安全的因素,可以说是千万不要用这种

第二种:

下载页面

<%@ page language="java" import="java.util.*" pageEncoding="GB18030"%>

<html>

<head>

<title>download</title>

</head>

<body>

<a href="xia.jsp?filename=新建文档.txt">新建文档.txt</a>

</body>

</html>

然后编写如下页面

<%@ page contentType="text/html;charset=gbk"%>

<%@ page language="java" import="java.io.*,java.net.*" pageEncoding="gbk"%>

<html>

<head>

<title>test</title>

</head>

<body>

<%

response.setContentType("text/html");

javax.servlet.ServletOutputStream ou = response.getOutputStream();

String filepath="uploadfile/";

String filename=new String(request.getParameter("filename").getBytes("ISO8859_1"),"GB2312").toString();

System.out.println("DownloadFile filepath:" + filepath);

System.out.println("DownloadFile filename:" + filename);

java.io.File file = new java.io.File(filepath + filename);

if (!file.exists()) {

System.out.println(file.getAbsolutePath() + " 文件不存在!");

return;

}

// 读取文件流

java.io.FileInputStream fileInputStream = new java.io.FileInputStream(file);

// 下载文件

// 设置响应头和下载保存的文件名

if (filename != null && filename.length() > 0) {

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

response.setHeader("Content-Disposition", "attachment; filename=" + new String(filename.getBytes("gb2312"),"iso8859-1") + "");

if (fileInputStream != null) {

int filelen = fileInputStream.available();

//文件太大时内存不能一次读出,要循环

byte a[] = new byte[filelen];

fileInputStream.read(a);

ou.write(a);

}

fileInputStream.close();

ou.close();

}

%>

</body>

</html>

第三种方法

使用servlet 首先配置web.xml

<servlet>

<servlet-name>DownloadFile</servlet-name>

<servlet-class>libin123.com.cn.servlet.DownloadFile</servlet-class>

</servlet>

<servlet-mapping>

<servlet-name>DownloadFile</servlet-name>

<url-pattern>/downloadfile</url-pattern>

</servlet-mapping>

编写DownloadFile.java类

package libin123.com.cn.servlet;

import java.io.IOException;

import java.io.PrintWriter;

import javax.servlet.ServletException;

import javax.servlet.http.HttpServlet;

import javax.servlet.http.HttpServletRequest;

import javax.servlet.http.HttpServletResponse;

import com.sun.image.codec.jpeg.ImageFormatException;

import com.sun.image.codec.jpeg.JPEGCodec;

import com.sun.image.codec.jpeg.JPEGImageDecoder;

public class DownloadFile extends HttpServlet {

private static final long serialVersionUID = 1L;

public void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {

response.setContentType("text/html");

javax.servlet.ServletOutputStream out = response.getOutputStream();

String filepath=request.getRealPath("/") + "uploadfile/";

String filename=new String(request.getParameter("filename").getBytes("ISO8859_1"),"GB2312").toString();

System.out.println("DownloadFile filepath:" + filepath);

System.out.println("DownloadFile filename:" + filename);

java.io.File file = new java.io.File(filepath + filename);

if (!file.exists()) {

System.out.println(file.getAbsolutePath() + " 文件不存在!");

return;

}

// 读取文件流

java.io.FileInputStream fileInputStream = new java.io.FileInputStream(file);

// 下载文件

// 设置响应头和下载保存的文件名

if (filename != null && filename.length() > 0) {

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

response.setHeader("Content-Disposition", "attachment; filename=" + new String(filename.getBytes("gb2312"),"iso8859-1") + "");

if (fileInputStream != null) {

int filelen = fileInputStream.available();

//文件太大时内存不能一次读出,要循环

byte a[] = new byte[filelen];

fileInputStream.read(a);

out.write(a);

}

fileInputStream.close();

out.close();

}

}

public void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {

response.setContentType("text/html");

PrintWriter out = response.getWriter();

out.println("<!DOCTYPE HTML PUBLIC -//W3C//DTD HTML 4.01 Transitional//EN>");

out.println("<HTML>");

out.println(" <HEAD><TITLE>A Servlet</TITLE></HEAD>");

out.println(" <BODY>");

out.print(" This is ");

out.print(this.getClass().getName());

out.println(", using the POST method");

out.println(" </BODY>");

out.println("</HTML>");

out.flush();

out.close();

}

}

jsp文件下载完整方法 jsp调用js文件方法
下载页面

<%@ page language="java" import="java.util.*" pageEncoding="GB18030"%>

<html>

<head>

</head>

<body>

<a href="downloadfile?filename=新建文档.txt">新建文档.txt</a>

</body>

</html>

  

爱华网本文地址 » http://www.aihuau.com/a/25101011/88479.html

更多阅读

迅雷怎么设置代理下载 精 迅雷精简版 代理

迅雷怎么设置代理下载 精——简介迅雷是我们通常使用的最多的下载工具,但在一些特定场合或者某些需要,我们不知怎么设置她的代理。比如在公司,公司整个是使用代理服务器上网,迅雷的默认设置不能下载,我们怎么设置呢。现在我们一起来学习

优酷客户端怎么下载视频 优酷用哪个版本好用

优酷客户端怎么下载视频——简介看到好的视频我们总想下载下来,那样即使没网络也一样可以看了。经常使用的优酷视频非常多,可很多人可能并不知道如何下载视频,下面我们介绍几个优酷客户端的视频下载入口,让大家能方便下载优酷客户端视频

如何在html中调用js代码 html5如何调用js文件

如何在html中调用js代码——简介js代码即为javascript代码,可直接在客户端解释执行,在html中调用js代码的方法主要有两种:一、将javascript直接写在html文件中,然后在html中调用js函数等;二、将js代码写一个文件中,然后在html中引用该文件

声明:《jsp文件下载完整方法 jsp调用js文件方法》为网友最爱迩的人是莪分享!如侵犯到您的合法权益请联系我们删除