Java web项目 Jxl 读取excel 并保存到数据库,(从eclipse上移动到tomact服务器上,之路径更改,)

最开始在eclipse中测试的时候,并没有上传到服务器上,后来发现,想要读取数据必须上传服务器然后把文件删除就可以了,服务器不可以直接读取外地的文件。用到jxl

1.上传到服务器

前端

<form action="${pageContext.request.contextPath}/UploadUsingExcelServlet" method="post" enctype="multipart/form-data">
        上传excel<input type="file" name="file1">
         <input type="submit" value="提交">
        </form>
        
//显示数据插入数据库之后的结果的,后台返回一个jsonObject,然后在这里只把失败的显示出来 <div class="page"> <div class="conShow" id="res"></div> <c:forEach items="${sessionScope.usingexcel.sy}" var="u"> <c:if test="${u.res==0}"> <span style="color:red">${u.pronum}>>${u.id}失败</span><br> </c:if> </c:forEach> <c:remove var="usingexcel" scope="session"/> </div>

2.上传文件后台

protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { //得到上传文件的保存目录,将上传的文件存放于WEB-INF目录下,不允许外界直接访问,保证上传文件的安全
        HttpSession session =request.getSession();
        String fileString = "";
        String savePath = this.getServletContext().getRealPath("/WEB-INF/upload");
         //上传时生成的临时文件保存目录
         String tempPath = this.getServletContext().getRealPath("/WEB-INF/temp");
         File tmpFile = new File(tempPath);
         if (!tmpFile.exists()) {
          //创建临时目录
          tmpFile.mkdir();
         }
         log.info(savePath);
        // System.out.println(tempPath);
         //消息提示
         String message = "";
         try{
          //使用Apache文件上传组件处理文件上传步骤:
          //1、创建一个DiskFileItemFactory工厂
          DiskFileItemFactory factory = new DiskFileItemFactory();
          //设置工厂的缓冲区的大小,当上传的文件大小超过缓冲区的大小时,就会生成一个临时文件存放到指定的临时目录当中。
          factory.setSizeThreshold(1024*100);//设置缓冲区的大小为100KB,如果不指定,那么缓冲区的大小默认是10KB
          //设置上传时生成的临时文件的保存目录
          factory.setRepository(tmpFile);
          //2、创建一个文件上传解析器
          ServletFileUpload upload = new ServletFileUpload(factory);
          //监听文件上传进度
          upload.setProgressListener(new ProgressListener(){
           public void update(long pBytesRead, long pContentLength, int arg2) {
               log.info("文件大小为:" + pContentLength + ",当前已处理:" + pBytesRead);
            /**
            * 文件大小为:14608,当前已处理:4096
             文件大小为:14608,当前已处理:7367
             文件大小为:14608,当前已处理:11419
             文件大小为:14608,当前已处理:14608
            */
           }
          });
          //解决上传文件名的中文乱码
          upload.setHeaderEncoding("UTF-8"); 
          //3、判断提交上来的数据是否是上传表单的数据
          if(!ServletFileUpload.isMultipartContent(request)){
           //按照传统方式获取数据
           return;
          }
           
          //设置上传单个文件的大小的最大值,目前是设置为1024*1024字节,也就是1MB
          upload.setFileSizeMax(1024*1024);
          //设置上传文件总量的最大值,最大值=同时上传的多个文件的大小的最大值的和,目前设置为10MB
          upload.setSizeMax(1024*1024*10);
          //4、使用ServletFileUpload解析器解析上传数据,解析结果返回的是一个List<FileItem>集合,每一个FileItem对应一个Form表单的输入项
          List<FileItem> list = upload.parseRequest(request);
          for(FileItem item : list){
           //如果fileitem中封装的是普通输入项的数据
           if(item.isFormField()){
            String name = item.getFieldName();
            //解决普通输入项的数据的中文乱码问题
            String value = item.getString("UTF-8");
            //value = new String(value.getBytes("iso8859-1"),"UTF-8");
            log.info(name + "=" + value);
           }else{//如果fileitem中封装的是上传文件
            //得到上传的文件名称,
            String filename = item.getName();
            log.info(filename);
            if(filename==null || filename.trim().equals("")){
             continue;
            }
            //注意:不同的浏览器提交的文件名是不一样的,有些浏览器提交上来的文件名是带有路径的,如: c:a1.txt,而有些只是单纯的文件名,如:1.txt
            //处理获取到的上传文件的文件名的路径部分,只保留文件名部分
            filename = filename.substring(filename.lastIndexOf("\")+1);
            //得到上传文件的扩展名
            String fileExtName = filename.substring(filename.lastIndexOf(".")+1);
            //如果需要限制上传的文件类型,那么可以通过文件的扩展名来判断上传的文件类型是否合法
            log.info("上传的文件的扩展名是:"+fileExtName);
            //获取item中的上传文件的输入流
            InputStream in = item.getInputStream();
            //得到文件保存的名称
            String saveFilename = makeFileName(filename);
            //得到文件的保存目录
            String realSavePath = makePath(saveFilename, savePath);
            //创建一个文件输出流
            FileOutputStream out = new FileOutputStream(realSavePath + "\" + saveFilename);
            fileString = realSavePath + "\" + saveFilename;
           //创建一个缓冲区
            byte buffer[] = new byte[1024];
            //判断输入流中的数据是否已经读完的标识      
            int len = 0;
            //循环将输入流读入到缓冲区当中,(len=in.read(buffer))>0就表示in里面还有数据
            while((len=in.read(buffer))>0){
             //使用FileOutputStream输出流将缓冲区的数据写入到指定的目录(savePath + "\" + filename)当中
             out.write(buffer, 0, len);
            }
            //关闭输入流
            in.close();
            //关闭输出流
            out.close();        //删除处理文件上传时生成的临时文件        //item.delete();        message = "文件上传成功!";
           }
          }
         }catch (FileUploadBase.FileSizeLimitExceededException e) {
          e.printStackTrace();
          session.setAttribute("flag", "单个文件超出最大值!!!"); 
          request.getRequestDispatcher("muju/usingexcel.jsp").forward(request, response);
          return;
         }catch (FileUploadBase.SizeLimitExceededException e) {
          e.printStackTrace();
          session.setAttribute("flag", "上传文件的总的大小超出限制的最大值!!!");
          request.getRequestDispatcher("muju/usingexcel.jsp").forward(request, response);
          return;
         }catch (Exception e) {
          message= "文件上传失败!";
          session.setAttribute("flag",message);
          e.printStackTrace();
         }
       //  session.setAttribute("flag",message);
        // System.out.println(fileString);
       //  request.getRequestDispatcher("UsingExcelServlet?filename="+fileString).forward(request, response);
        // response.setCharacterEncoding("utf-8");
         response.sendRedirect("UsingExcelServlet?filename="+fileString);//读取excel的servlet
    }


/**
 * @Description: 生成上传文件的文件名,文件名以:uuid+"_"+文件的原始名称
 * @param filename 文件的原始名称
 * @return uuid+"_"+文件的原始名称
 */
 private String makeFileName(String filename){ //2.jpg
  //为防止文件覆盖的现象发生,要为上传文件产生一个唯一的文件名
  return UUID.randomUUID().toString() + "_" + filename;
 }  
 /**
 * 为防止一个目录下面出现太多文件,要使用hash算法打散存储
 *
 * @param filename 文件名,要根据文件名生成存储目录
 * @param savePath 文件存储路径
 * @return 新的存储目录
 */
private String makePath(String filename,String savePath){
  //得到文件名的hashCode的值,得到的就是filename这个字符串对象在内存中的地址
  int hashcode = filename.hashCode();
  int dir1 = hashcode&0xf; //0--15
  int dir2 = (hashcode&0xf0)>>4; //0-15
  //构造新的保存目录
  String dir = savePath + "\" + dir1 + "\" + dir2; //upload23 upload35
  //File既可以代表文件也可以代表目录  
  File file = new File(dir);
 //如果目录不存在
  if(!file.exists()){
   //创建目录
   file.mkdirs();
 }
  return dir;
}

3.解析数据类

package com.rfx.servlet;

import java.io.File;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;

import jxl.Cell;
import jxl.Sheet;
import jxl.Workbook;

public class ReadUsingExcel {
    public static List<Map<String, String>> readExcel(File file) {
        List<Map<String, String>> list = new ArrayList<Map<String, String>>();
        try {
            // 判断文件是否存在
            // 创建工作簿
            Workbook workbook = Workbook.getWorkbook(file);
            // 获得第一个工作表sheet1
            Sheet sheet = workbook.getSheet(0);
            // 获得数据
            System.out.println("行数" + sheet.getRows());
            System.out.println("列数" + sheet.getColumns());
            for (int i = 1; i < sheet.getRows(); i++) {// sheet.getRows():获得表格文件行数
                if (sheet.getCell(0, i).getContents().equals("")) {
                    break;
                }
                Map<String, String> map = new HashMap<String, String>();
                for (int j = 0; j < sheet.getColumns(); j++) {// sheet.getColumns():获得表格文件列数
                    Cell cell = sheet.getCell(j, i);
                    map.put(sheet.getCell(j, 0).getContents(),
                            cell.getContents());
                    // (列,行)
                }
                list.add(map);
            }
            // System.out.println("");// 换行
            // 调用方法进行数据库的操作
            // .......
            System.out.println(list);
            workbook.close();// 关闭
        } catch (Exception e) {
            e.printStackTrace();
        }
        return list;
    }
}

4.存到数据库

protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
    //    request.setCharacterEncoding("utf-8");
        //System.out.println("jinru");
        String filename=request.getParameter("filename");
    //    System.out.println(filename);
        log.info("读取excel的地址"+filename);
        File file = new File(filename);
        JSONObject jsonObject = new JSONObject();
        JSONArray jsonArray = new JSONArray();
        //记录一下文件是否存在
        if (file.exists()) {
            List<Map<String, String>>list=ReadUsingExcel.readExcel(file);
            MuJUService mjService = new MuJUService();
                for (Map<String, String> map : list) {
                    jsonObject  = mjService.addShiYongJiLu(map);
                }
                jsonObject.put("existfile", 1);
        } else {
            log.error("文件不存在");
            jsonObject.put("existfile", 0);
        }
        String str=jsonObject.toJSONString();
    //    System.out.println("结果"+str);
        log.info("使用次数:"+str);
        response.setCharacterEncoding("utf-8");
        String string=filename.substring(0, filename.lastIndexOf('\'));
        string=string.substring(0, string.lastIndexOf('\'));
        boolean flag = deleteDirectory(string);
        HttpSession session = request.getSession();
        session.setAttribute("usingexcel", jsonObject);
        if (flag) {
            log.info("文件删除成功");
            response.sendRedirect("muju/usingexcel.jsp");
        }else {
            log.info("文件删除失败");
            response.sendRedirect("muju/usingexcel.jsp");
        }
        
        /*
        PrintWriter out= response.getWriter();
        out.write(str);
        out.close();*/
    
    }
     public  boolean delete(String fileName){     
            File file = new File(fileName);     
            if(!file.exists()){     
                log.info("删除文件失败:"+fileName+"文件不存在");     
                return false;     
            }else{     
                if(file.isFile()){     
                         
                    return deleteFile(fileName);     
                }else{     
                    return deleteDirectory(fileName);     
                }     
            }     
        }     
             
        /**   
         * 删除单个文件   
         * @param   fileName    被删除文件的文件名   
         * @return 单个文件删除成功返回true,否则返回false   
         */    
        public  boolean deleteFile(String fileName){     
            File file = new File(fileName);     
            if(file.isFile() && file.exists()){     
                file.delete();     
                log.info("删除单个文件"+fileName+"成功!");     
                return true;     
            }else{     
                log.info("删除单个文件"+fileName+"失败!");     
                return false;     
            }     
        }     
    public  boolean deleteDirectory(String dir){  
        //如果dir不以文件分隔符结尾,自动添加文件分隔符     
        if(!dir.endsWith(File.separator)){     
            dir = dir+File.separator;     
        }     
        File dirFile = new File(dir);     
        //如果dir对应的文件不存在,或者不是一个目录,则退出     
        if(!dirFile.exists() || !dirFile.isDirectory()){     
            log.info("删除目录失败"+dir+"目录不存在!");     
            return false;     
        }     
        boolean flag = true;     
        //删除文件夹下的所有文件(包括子目录)     
        File[] files = dirFile.listFiles();     
        for(int i=0;i<files.length;i++){     
            //删除子文件     
            if(files[i].isFile()){     
                flag = deleteFile(files[i].getAbsolutePath());     
                if(!flag){     
                    break;     
                }     
            }     
            //删除子目录     
            else{     
                flag = deleteDirectory(files[i].getAbsolutePath());     
                if(!flag){     
                    break;     
                }     
            }     
        }     
             
        if(!flag){     
            log.info("删除目录失败");     
            return false;     
        }     
             
        //删除当前目录     
        if(dirFile.delete()){     
            log.info("删除目录"+dir+"成功!");     
            return true;     
        }else{     
            log.info("删除目录"+dir+"失败!");     
            return false;     
        }     
    }  
    
原文地址:https://www.cnblogs.com/stepbystepwhx/p/7782872.html