前一段日子應公司的要求寫了一個柱狀圖的程式,但是內容都是要從另一個分析軟體中得到的,那個軟體可以把內容產生表格儲存到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>