JSP讀取用戶端檔案

來源:互聯網
上載者:User

前一段日子應公司的要求寫了一個柱狀圖的程式,但是內容都是要從另一個分析軟體中得到的,那個軟體可以把內容產生表格儲存到txt檔案,沒辦法,我只好用讀取檔案的方法擷取資料,程式都寫完後才發現當程式放到伺服器後用戶端檔案無法讀取了。。。。。我才發現自己有點蠢。。。。路徑肯定會有問題的。。。

於是重新想辦法,查了下資料,最終放棄,因為沒有任何一種語言可以直接實現伺服器讀取用戶端檔案的,要達到目的只能另想辦法。於是想到了上傳>>讀取>>刪除的方法。。。。。

接著即開始動手構造代碼,哈哈哈~寫完後小嘗試了一下,發現無法刪除檔案。。。不過馬上找到了原因。。。只要在刪除檔案前關閉檔案的輸出資料流即可,因為檔案在讀取狀態,所以才會導致最終刪不掉,由於之前在網上查相關資料的時候也沒找到詳細的方法,於是現在想到了把我自己的方法貢獻出來。。。。

以下是步驟:
================================================================================
一、首先我們需要實現上傳檔案的功能,這個我以前做過,所以比較得心應手
1.到下面的地址去下載UploadBean組件
http://www.javazoom.net/jzservlets/uploadbean/uploadbean.html
2.到下面的地址去下UploadBean的外掛程式——FileMover
http://www.javazoom.net/jzservlets/uploadbean/uploadbeantools.html
3.把其中的三個包cos.jar,uploadbean.jar,filemover.jar放到web程式的目錄WEB-INF/lib下
4.上傳配置完畢

二、客戶選擇檔案上傳的表單代碼
<form name=go action=readtxt.jsp method=post CTYPE="multipart/form-data">
    <input type=file name=url><br>
    <input type=submit value="提交並讀取>>">
</form>

三、實現上傳>>讀取>>存入資料庫>>刪除的主要代碼readtxt.jsp[註:我用的是UTF-8編碼,具體要根據實際情況調節]
<%@ page language="java" pageEncoding="UTF-8"%>
<%@ page import="java.io.*,
    connect.Conn,
    javazoom.upload.*,
    uploadutilities.FileMover,
    java.util.*"
%>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312">
<title>讀取檔案中</title>
</head>
<body>
<%
 request.setCharacterEncoding("UTF-8");//設定編碼格式,就不用一個個轉碼了
 FileMover fileMover = new FileMover();//建立一個FileMover對象,並執行個體化fileMover
 UploadBean upBean = new UploadBean();//建立一個UploadBean對象,並執行個體化upBean
 MultipartFormDataRequest mrequest = null;
 Hashtable files = null;//建立一個容器,其空間在後面將用來存放上傳檔案
 
 if (MultipartFormDataRequest.isMultipartFormData(request))
 {
  mrequest = new MultipartFormDataRequest(request,null,100*1024*1024,MultipartFormDataRequest.COSPARSER,"UTF-8");//注意這裡也要設定編碼參數,實現上面表單中的multipart/form-data
  files = mrequest.getFiles();//得到表單提交的檔案
 }
 
 String sWebRootPath = getServletContext().getRealPath("/");//得到web應用的根。
 String sPath=sWebRootPath+"temp";//聲明上傳路徑為根目錄中的temp目錄下
 String sServerFileName="";
 String sLocalFileName = "";
 //檔案擷取
 if ( (files != null) || (!files.isEmpty()))
 { 
  UploadFile file = (UploadFile) files.get("url");
  sLocalFileName=file.getFileName();
  int ii= sLocalFileName.indexOf("."); 
  String sExt = sLocalFileName.substring(ii,sLocalFileName.length());//取檔案名稱的尾碼
  //得到不重複的檔案名稱,這一步是為了防止同時上傳兩個同檔案名稱的txt而做的,避免檔案名稱重複
  java.util.Date dt = new java.util.Date(System.currentTimeMillis());
  SimpleDateFormat fmt = new SimpleDateFormat("yyyyMMddHHmmssSSS");
  sServerFileName= fmt.format(dt);
  sServerFileName =sServerFileName + sExt;
  //如果不存在該目錄,則建立一個
  File dir =new File(sPath);
  if (!dir.exists())
  {
   dir.mkdirs();
  }
  upBean.setFolderstore(sPath);//建立要上傳的目錄
  upBean.addUploadListener(fileMover);//增加filMover監聽
  fileMover.setNewfilename(sServerFileName);//設定伺服器上的檔案名稱
  upBean.store(mrequest, "url");//上傳
 }
 
 
 Conn db=new Conn();//串連資料庫,這是我自己寫的javabean,實際運用中請使用其他串連資料庫的代碼替換
 String sql="";
 FileReader fr=new FileReader(sPath+"/"+sServerFileName);//建立FileReader對象,並執行個體化為fr
   BufferedReader br=new BufferedReader(fr);//建立BufferedReader對象,並執行個體化為br
   String Line=br.readLine();//從檔案讀取一行字串
   while(reader.ready())
   {
       Line=br.readLine();
   }
   out.print(Line);//輸出從檔案中讀取到的內容
   //這裡可以插入對讀取到的內容篩選,然後用下面的sql語句插入資料
   sql="";//這裡寫sql語句
   db.Update(sql);//執行sql語句
   fr.close();//關閉檔案輸出資料流,不關閉的話,將無法執行最後一步的刪除
   File txtfile=new File(sPath+"/"+sServerFileName);//建立File對象,並獲得要操作的檔案路徑
   txtfile.delete();//刪除檔案
   out.print("檔案讀取完畢...");
%>
</body>
</html>

 

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.