JSP读取客户端文件

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

  

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值