前一段日子应公司的要求写了一个柱状图的程序,但是内容都是要从另一个分析软件中得到的,那个软件可以把内容生成表格保存到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>