程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> 網頁編程 >> JSP編程 >> 關於JSP >> JSP下載服務器文件的方法,jsp服務器文件

JSP下載服務器文件的方法,jsp服務器文件

編輯:關於JSP

JSP下載服務器文件的方法,jsp服務器文件


本文實例講述了JSP下載服務器文件的方法。分享給大家供大家參考,具體如下:

<%@page import="java.io.FileInputStream"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<%@page language="java" contentType="text/html; charset=UTF-8"%>
<%@page import="com.ecc.emp.core.Context" %>
<%@page import="java.io.File" %>
<%@ include file="http://www.xxxx.com/head.jsp"%>
<%
  boolean loadFlag = false;
  ServletOutputStream ou = null;
  FileInputStream fis = null;
  try{  
    Context context=(Context)request.getAttribute("context");
    String accountFilePath = (String)context.getDataValue("accountFilePath");
    //String accountFilePath ="E:/ComeBack/Acc_BOS_CM/WebContent/upload/product/1336873410414custormerStatement.txt";
    //String accountFileName = (String)context.getDataValue("accountFileName");
    String displayFileName = (String)context.getDataValue("displayFileName");
    //String displayFileName ="custormerStatement.txt";
    String fullPath =accountFilePath;
    response.reset();
      response.setContentType("charset=UTF-8");
    response.setContentType("text/HTML");
    //response.setContentType("application/vnd.ms-excel");    
    String filename = new String(displayFileName.getBytes("gb2312"), "ISO8859-1");
    response.setHeader("Content-Disposition","attachment; filename=" + filename);
    //解決HTTPS不能下載的問題
    response.setHeader("Cache-Control","public");    
    ou = response.getOutputStream();
    File file = new File(fullPath);
    fis = new FileInputStream(file);    
    try {
      if (fis != null) {
        int filelen = fis.available();
        byte a[] = new byte[filelen];
        fis.read(a);
        ou.write(a);
        ou.flush();
      }      
      loadFlag=true;
    } catch (Exception e) {
      System.out.println("Excel is not exist!");
    }
    out = pageContext.pushBody();
  }catch(Exception e){
    e.printStackTrace();
  }finally{
    try {
      fis.close();
      ou.close();
      ou = null;
      response.flushBuffer();
    } catch (Exception e) {
      // TODO 自動生成 catch 塊
      e.printStackTrace();
    }
  }
%>

希望本文所述對大家JSP程序設計有所幫助。

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved