SpringMVC上传和解析Excel方法

示例:导入相关数据(Excel文件),相关的文件数据编辑好。

XML文件配置

再spring的xml文件中配置要上传文件的大小

<!-- 上传文件拦截,设置最大上传文件大小  10M=10*1024*1024(B)=10485760 bytes -->
<bean id="multipartResolver" class="org.springframework.web.multipart.commons.CommonsMultipartResolver">
  <property name="maxUploadSize" value="10485760" />
</bean>

Jsp界面配置

<div>
   <form id="sourcefile" name="sourcefile" action="" method="post" enctype="multipart/form-data">
    <input type="button" value="添  加" onClick="addAirLine()" />
    <input style="margin-left: 20px;" id="source_file" name="sourceFile" type="file" value="选择文件" />
    <input style="margin-left: 20px;" data-loading-text="请勿重复提交" type="submit" value="上  传" onClick="upPolicy()">
    <input style="margin-left: 20px;" type="submit" value="下载模板" onClick="return downloadTemplate();">
   </form>
  </div>

js文件

function upPolicy() {
   document.sourcefile.action = "/login/policy/uploadCSV";
   var submitUrl = document.getElementById("sourcefile").attributes["action"].value;
   $.ajax({
    type: "POST",
    url: submitUrl,
    data: $('#sourcefile').serialize(),
    dataType: "json",
    success: function (result) {
     var json = JSON.parse(result);
     if (json.flag == "0" || json.flag == "1") {
      alert(tableJson.success);
      return;
     }
    }
   })
  }

Controller配置

@RequestMapping(value = "/uploadCSV" ,method = RequestMethod.POST)
  @ResponseBody
  public String uploadCSV(@RequestParam("sourceFile") MultipartFile sourceFile, HttpServletRequest request,HttpServletResponse response) throws IOException{

    //判断文件是否为空
    if (sourceFile==null) return null;
    //获取文件名
    String name=sourceFile.getOriginalFilename();
    //进一步判断文件是否为空(即判断其大小是否为0或其名称是否为null)
    long size =sourceFile.getSize();
    if (name==null ||("").equals(name) && size==0) return null;

    //批量导入。参数:文件名,文件。
    boolean b = batchImport(name,sourceFile);
    JSONObject jsonObject=new JSONObject();
    if(b){
      jsonObject.put("flag",0);
      jsonObject.put("success","批量导入EXCEL成功!");
    }else{
      jsonObject.put("flag",1);
      jsonObject.put("success","批量导入EXCEL失败!");
    }
    return jsonObject.toString();
  }

分层没有那么的详细,再Controller中做的处理

public boolean batchImport(String name,MultipartFile file){
    boolean b = false;
    //创建处理EXCEL
    ExcelUtils readExcel=new ExcelUtils();
    //解析excel,获取客户信息集合。
    List<OTAPolicyModel> cpolicyList = readExcel.getExcelInfo(name ,file);

    if(cpolicyList != null){
      b = true;
    }

    //迭代添加信息(注:实际上这里也可以直接将cpolicyList集合作为参数,
       在Mybatis的相应映射文件中使用foreach标签进行批量添加。)
    for(OTAPolicyModel customer:cpolicyList){
      policyDao.insertOTAPolicy(customer);
    }
    return b;
  }

工具类ExcelUtils.java

即上述方法中readExcel.getExcelInfo(name ,file);语句所调用的方法以及其他相关的方法
Apache POI提供API给Java程式对Microsoft Office格式档案读和写的功能。不过这首先得判断Excel的版本而选择不同的Workbook的方式(2003版本对应的是HSSFWorkbook,2007版本及以上对应的是XSSFWorkbook)。此外,一般来说先将在客户端用户上传的文件拷贝一份至服务器的本地磁盘中,然后再从这个拷贝文件中进行读取,这样就避免了因客户端的网络异常或其他状况而在读取时造成的数据流失或损坏的情况。

package com.flight.inter.otaadapter.commons.util;

import com.flight.inter.otaadapter.model.OTAPolicyModel;
import org.apache.poi.hssf.usermodel.HSSFWorkbook;
import org.apache.poi.ss.usermodel.Cell;
import org.apache.poi.ss.usermodel.Row;
import org.apache.poi.ss.usermodel.Sheet;
import org.apache.poi.ss.usermodel.Workbook;
import org.apache.poi.xssf.usermodel.XSSFWorkbook;
import org.springframework.web.multipart.MultipartFile;
import org.springframework.web.multipart.commons.CommonsMultipartFile;

import java.io.*;
import java.math.BigDecimal;
import java.util.ArrayList;
import java.util.Date;
import java.util.List;

/**
 * Created by ling.zhang on 2016/12/29.
 */
public class ExcelUtils {

  //总行数
  private int totalRows = 0;
  //总条数
  private int totalCells = 0;
  //错误信息接收器
  private String errorMsg;
  //构造方法
  public ExcelUtils(){}
  //获取总行数
  public int getTotalRows() { return totalRows;}
  //获取总列数
  public int getTotalCells() { return totalCells;}
  //获取错误信息
  public String getErrorInfo() { return errorMsg; }

  /**
   * 验证EXCEL文件
   * @param filePath
   * @return
   */
  public boolean validateExcel(String filePath){
    if (filePath == null || !(WDWUtil.isExcel2003(filePath) || WDWUtil.isExcel2007(filePath))){
      errorMsg = "文件名不是excel格式";
      return false;
    }
    return true;
  }

  /**
   * 读EXCEL文件,获取客户信息集合
   * @param
   * @return
   */
  public List<OTAPolicyModel> getExcelInfo(String fileName, MultipartFile Mfile){

    //把spring文件上传的MultipartFile转换成CommonsMultipartFile类型
    CommonsMultipartFile cf= (CommonsMultipartFile)Mfile; //获取本地存储路径
    File file = new File("D:\\fileupload");
    //创建一个目录 (它的路径名由当前 File 对象指定,包括任一必须的父路径。)
    if (!file.exists()) file.mkdirs();
    //新建一个文件
    File file1 = new File("D:\\fileupload" + new Date().getTime() + ".xlsx");
    //将上传的文件写入新建的文件中
    try {
      cf.getFileItem().write(file1);
    } catch (Exception e) {
      e.printStackTrace();
    }

    //初始化客户信息的集合
    List<OTAPolicyModel> customerList=new ArrayList<OTAPolicyModel>();
    //初始化输入流
    InputStream is = null;
    try{
      //验证文件名是否合格
      if(!validateExcel(fileName)){
        return null;
      }
      //根据文件名判断文件是2003版本还是2007版本
      boolean isExcel2003 = true;
      if(WDWUtil.isExcel2007(fileName)){
        isExcel2003 = false;
      }
      //根据新建的文件实例化输入流
      is = new FileInputStream(file1);
      //根据excel里面的内容读取客户信息
      customerList = getExcelInfo(is, isExcel2003);
      is.close();
    }catch(Exception e){
      e.printStackTrace();
    } finally{
      if(is !=null)
      {
        try{
          is.close();
        }catch(IOException e){
          is = null;
          e.printStackTrace();
        }
      }
    }
    return customerList;
  }
  /**
   * 根据excel里面的内容读取客户信息
   * @param is 输入流
   * @param isExcel2003 excel是2003还是2007版本
   * @return
   * @throws IOException
   */
  public List<OTAPolicyModel> getExcelInfo(InputStream is,boolean isExcel2003){
    List<OTAPolicyModel> customerList=null;
    try{
      /** 根据版本选择创建Workbook的方式 */
      Workbook wb = null;
      //当excel是2003时
      if(isExcel2003){
        wb = new HSSFWorkbook(is);
      }
      else{//当excel是2007时
        wb = new XSSFWorkbook(is);
      }
      //读取Excel里面客户的信息
      customerList=readExcelValue(wb);
    }
    catch (IOException e) {
      e.printStackTrace();
    }
    return customerList;
  }
  /**
   * 读取Excel里面客户的信息
   * @param wb
   * @return
   */
  private List<OTAPolicyModel> readExcelValue(Workbook wb){
    //得到第一个shell
    Sheet sheet=wb.getSheetAt(0);

    //得到Excel的行数
    this.totalRows=sheet.getPhysicalNumberOfRows();

    //得到Excel的列数(前提是有行数)
    if(totalRows>=1 && sheet.getRow(0) != null){
      this.totalCells=sheet.getRow(0).getPhysicalNumberOfCells();
    }

    List<OTAPolicyModel> oTAPolicyModelList=new ArrayList<OTAPolicyModel>();
    OTAPolicyModel oTAPolicyModel;
    //循环Excel行数,从第二行开始。标题不入库
    for(int r=1;r<totalRows;r++){
      Row row = sheet.getRow(r);
      if (row == null) continue;
      oTAPolicyModel = new OTAPolicyModel();
      try {
        Thread.currentThread().sleep(1);
      }catch (InterruptedException e){
        e.printStackTrace();
      }
      oTAPolicyModel.setPolicyid(System.currentTimeMillis());
      //循环Excel的列
      for(int c = 0; c <this.totalCells; c++){
        Cell cell = row.getCell(c);
        if (null != cell){
          if(c==0){
            oTAPolicyModel.setSource(cell.getStringCellValue());//供应商
          }else if(c==1){
            oTAPolicyModel.setVendee(cell.getStringCellValue());//输出渠道
          }else if(c==2){
            int triptype=0;
            if (cell.getStringCellValue()=="全部"){
              triptype=0;
            }else if (cell.getStringCellValue().equals("单程")){
              triptype=10;
            }else if (cell.getStringCellValue().equals("往返")){
              triptype=20;
            }else if (cell.getStringCellValue().equals("单程直飞")){
              triptype=11;
            }else if (cell.getStringCellValue().equals("单程中转")){
              triptype=12;
            }else if (cell.getStringCellValue().equals("往返直飞")){
              triptype=21;
            }else if (cell.getStringCellValue().equals("往返中转")){
              triptype=22;
            }
            oTAPolicyModel.setTriptype(triptype);//行程类型
          }else if(c==3){
            oTAPolicyModel.setCarrier(cell.getStringCellValue());//航司代码
          }else if(c==4){
            oTAPolicyModel.setDepcity(cell.getStringCellValue());//起飞城市
          }else if(c==5){
            oTAPolicyModel.setArrcity(cell.getStringCellValue());//降落城市
          }else if(c==6){
            oTAPolicyModel.setSalebegindatel(new BigDecimal(cell.getNumericCellValue()).setScale(0,BigDecimal.ROUND_HALF_DOWN).longValue());//销售开始日期
          }else if(c==7){
            oTAPolicyModel.setSaleenddatel(new BigDecimal(cell.getNumericCellValue()).setScale(0,BigDecimal.ROUND_HALF_DOWN).longValue());//销售结束日期
          }else if(c==8){
            oTAPolicyModel.setTravelbegindatel(new BigDecimal(cell.getNumericCellValue()).setScale(0,BigDecimal.ROUND_HALF_DOWN).longValue());//旅行开始日期
          }else if(c==9){
            oTAPolicyModel.setTravelenddatel(new BigDecimal(cell.getNumericCellValue()).setScale(0,BigDecimal.ROUND_HALF_DOWN).longValue());//旅行结束日期
          }else if(c==10){
            int cabintype=9;
            if (cell.getStringCellValue().equals("全部")){
              cabintype=9;
            }else if (cell.getStringCellValue().equals("经济舱")){
              cabintype=1;
            }else if (cell.getStringCellValue().equals("商务")){
              cabintype=2;
            }else if (cell.getStringCellValue().equals("头等")){
              cabintype=3;
            }
            oTAPolicyModel.setCabintype(cabintype);//舱位等级
          }else if(c==11){

            oTAPolicyModel.setFdtype(cell.getStringCellValue().equals("按价格区间")?1:2);//返点类型
          }else if(c==12){
            oTAPolicyModel.setCabin(cell.getStringCellValue());//舱位
          }else if(c==13){
            oTAPolicyModel.setPricebegin(cell.getNumericCellValue());//最低价格
          }else if(c==14){
            oTAPolicyModel.setPriceend(cell.getNumericCellValue());//最高价格
          }else if(c==15){
            oTAPolicyModel.setLmoney(cell.getNumericCellValue());//留钱
          }else if(c==16){
            oTAPolicyModel.setFpercent(cell.getNumericCellValue());//全价返点
          }else if(c==17){
            oTAPolicyModel.setFtpercent(cell.getNumericCellValue());//票面返点
          }else if(c==18){
            int carrierlimit=2;
            if (cell.getStringCellValue().equals("是")){
              carrierlimit=1;
            }else if (cell.getStringCellValue().equals("否")){
              carrierlimit=0;
            }else if (cell.getStringCellValue().equals("无")){
              carrierlimit=2;
            }
            oTAPolicyModel.setCarrierlimit(carrierlimit);//开票航司限制
          }else if(c==19){
            int transport=2;
            if (cell.getStringCellValue().equals("是")){
              transport=1;
            }else if (cell.getStringCellValue().equals("否")){
              transport=0;
            }else if (cell.getStringCellValue().equals("无限制")){
              transport=2;
            }
            oTAPolicyModel.setTransport(transport);//支持联运
          }else if(c==20){
            int sharedflight=2;
            if (cell.getStringCellValue().equals("是")){
              sharedflight=1;
            }else if (cell.getStringCellValue().equals("否")){
              sharedflight=0;
            }else if (cell.getStringCellValue().equals("无")){
              sharedflight=2;
            }
            oTAPolicyModel.setSharedflight(sharedflight);//支持共享航班
          }else if(c==21){
            oTAPolicyModel.setPstatus(cell.getStringCellValue().equals("有效")?1:2);//状态
          }else if(c==22){
            int faretype=0;
            if (cell.getStringCellValue().equals("私有")){
              faretype=1;
            }else if (cell.getStringCellValue().equals("公布")){
              faretype=2;
            }else if (cell.getStringCellValue().equals("全部")){
              faretype=0;
            }
            oTAPolicyModel.setFaretype(faretype);//运价类型
          }else if(c==23){
            oTAPolicyModel.setLimitprice(new BigDecimal(cell.getNumericCellValue()).setScale(0,BigDecimal.ROUND_HALF_DOWN).longValue());//加价限制
          }else if(c==24){
            int limittransit=2;
            if (cell.getStringCellValue().equals("全部")){
              limittransit=2;
            }else if (cell.getStringCellValue().equals("适用")){
              limittransit=0;
            }else if (cell.getStringCellValue().equals("不适用")){
              limittransit=1;
            }
            oTAPolicyModel.setLimittransit(limittransit);//中转限制
          }else if(c==25){
            oTAPolicyModel.setArrcity(cell.getStringCellValue());//中转城市
          }else if(c==26){
            int limitnation=2;
            if (cell.getStringCellValue().equals("全部")){
              limitnation=2;
            }else if (cell.getStringCellValue().equals("适用")){
              limitnation=0;
            }else if (cell.getStringCellValue().equals("不适用")){
              limitnation=1;
            }
            oTAPolicyModel.setLimitnation(limitnation);//国籍限制
          }else if(c==27){
            oTAPolicyModel.setArrcity(cell.getStringCellValue());//国籍
          }else if (c==28){
            oTAPolicyModel.setUsername(cell.getStringCellValue());//用户名
          }

        }
      }
      //添加客户
      oTAPolicyModelList.add(oTAPolicyModel);
    }
    return oTAPolicyModelList;
  }

}

工具类WDWUtil.java

package com.flight.inter.otaadapter.commons.util;

/**
* Created by ling.zhang on 2016/12/29.
*/
public class WDWUtil {
// @描述:是否是2003的excel,返回true是2003
public static boolean isExcel2003(String filePath) {
return filePath.matches(“^.+\.(?i)(xls)$”);
}

//@描述:是否是2007的excel,返回true是2007
public static boolean isExcel2007(String filePath) {
  return filePath.matches("^.+\\.(?i)(xlsx)$");
}
}

    说明:上面的代码为了阅读便利而先贴的是父方法,后贴的是子方法,而在实际的代码编辑中一般是先编辑子方法,后编辑父方法,如上面应该是先编辑工具类的代码,再编辑服务层的代码,最后编辑控制器的代码。

这样,整个流程就可以了,赶紧拿去测试吧

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

(0)

相关推荐

  • SpringMvc导出Excel实例代码

    前言 相信很多朋友在实际工作中都会要将数据导出成Excel的需求,通常这样的做法有两种. 一是采用JXL来生成Excel,之后保存到服务器,然后在生成页面之后下载该文件. 二是使用POI来生成Excel,之后使用Stream的方式输出到前台直接下载(ps:当然也可以生成到服务器中再下载.).这里我们讨论第二种. Struts2的方式 通常我会将已经生成好的HSSFWorkbook放到一个InputStream中,然后再到xml配置文件中将返回结果更改为stream的方式.如下: private

  • 详解poi+springmvc+springjdbc导入导出excel实例

    工作中常遇到导入导出excel的需求,本獂有一简答实例与大家分享. 废话不多说, 1.所需jar包: 2.前端代码: ieport.jsp: <%@page import="java.util.Date"%> <%@ page language="java" contentType="text/html; charset=utf-" pageEncoding="utf-"%> <!DOCTYPE

  • Springboot使用POI实现导出Excel文件示例

    前面讲述了使用POI导出Word文件和读取Excel文件,这两个例子都相对简单,接下来要讲述的使用POI导出Excel文件要复杂得多,内容也会比较长. 创建表头信息 表头信息用于自动生成表头结构及排序 public class ExcelHeader implements Comparable<ExcelHeader>{ /** * excel的标题名称 */ private String title; /** * 每一个标题的顺序 */ private int order; /** * 说对

  • Spring 实现excel及pdf导出表格示例

    整理文档,搜刮出一个Spring 实现excel及pdf导出表格的代码,稍微整理精简一下做下分享. excel 导出: package light.mvc.utils.excel; import java.util.Date; import java.util.List; import java.util.Map; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse

  • 基于Spring Mvc实现的Excel文件上传下载示例

    最近工作遇到一个需求,需要下载excel模板,编辑后上传解析存储到数据库.因此为了更好的理解公司框架,我就自己先用spring mvc实现了一个样例. 基础框架 之前曾经介绍过一个最简单的spring mvc的项目如何搭建,传送门在这里. 这次就基于这个工程,继续实现上传下载的小例子.需要做下面的事情: 1 增加index.html,添加form提交文件 2 引入commons-fileupload.commons-io.jxl等工具包 3 创建upload download接口 4 注入mul

  • SpringMVC上传和解析Excel方法

    示例:导入相关数据(Excel文件),相关的文件数据编辑好. XML文件配置 再spring的xml文件中配置要上传文件的大小 <!-- 上传文件拦截,设置最大上传文件大小 10M=10*1024*1024(B)=10485760 bytes --> <bean id="multipartResolver" class="org.springframework.web.multipart.commons.CommonsMultipartResolver&qu

  • SpringMVC上传文件FileUpload使用方法详解

    本文实例为大家分享了SpringMVC上传文件FileUpload的具体代码,供大家参考,具体内容如下 我是在已经搭建好的springMVC环境下,maven工程中的pom.xml所需要的jar包(其中spring上传文件的两个主要jar:commons-fileupload.jar和commons-io.jar): <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.o

  • springboot实现上传并解析Excel过程解析

    添加pom依赖 <!-- excel解析包 --> <!-- https://mvnrepository.com/artifact/org.apache.poi/poi --> <!--处理2003 excel--> <dependency> <groupId>org.apache.poi</groupId> <artifactId>poi</artifactId> <version>3.16<

  • Java对Excel表格的上传和下载处理方法

    Excel表格文件的上传和下载,java中涉及到文件肯定会有io流的知识. 而excel文件就要涉及到poi技术,而excel的版本包括:2003-2007和2010两个版本, 即excel的后缀名为:xls和xlsx. 这里我是按照正规的项目流程做的案例,所以可能会比网上的一些Demo复杂一些.不过文件的上传和下载基本都是一套固定的流程,只是每个人的实现方式不太相同. 数据库我用的是MySql. 下面是我的项目目录: 按照正常的项目做了分层处理,文件上传的业务我放到了service处理,而文件

  • SpringMVC上传文件的两种方法

    在该示例中,阐述了SpringMVC如何上传文件. 1.上传页面upload.jsp <body> <form action="/TestSpringMVC3/data/uploadfile" enctype="multipart/form-data" method="post"> file:<input type="file" name="file"><br>

  • SpringMVC 上传文件 MultipartFile 转为 File的方法

    在使用 SpringMVC 上传文件时,接收到的文件格式为 MultipartFile,但是在很多场景下使用都需要File格式的文件,记录下以便日后使用. 以下mFile为MultipartFile文件 此方法会在本地产生临时文件,使用完毕需要删除 在网上搜索未发现可直接使用的不产生临时文件的方法,查到几个本地测试皆无法通过,如哪位有不产生临时文件的方法,请多多指教

  • SpringMVC上传文件的三种实现方式

    SpringMVC上传文件的三种实现方式,直接上代码吧,大伙一看便知 前台: <%@ page language="java" contentType="text/html; charset=utf-8" pageEncoding="utf-8"%> <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.

  • Spring Boot 文件上传原理解析

    首先我们要知道什么是Spring Boot,这里简单说一下,Spring Boot可以看作是一个框架中的框架--->集成了各种框架,像security.jpa.data.cloud等等,它无须关心配置可以快速启动开发,有兴趣可以了解下自动化配置实现原理,本质上是 spring 4.0的条件化配置实现,深抛下注解,就会看到了. 说Spring Boot 文件上传原理 其实就是Spring MVC,因为这部分工作是Spring MVC做的而不是Spring Boot,那么,SpringMVC又是怎么

  • SpringMVC上传文件的简单实例

    SpringMVC上传文件的简单实例 在使用springMVC进行系统实现时,springMVC默认的解析器里面是没有加入对文件上传的解析的,这可以方便我们实现自己的文件上传.但如果你想使用springMVC对文件上传的解析器来处理文件上传的时候就需要在spring的applicationContext里面加上springMVC提供的MultipartResolver的申明.这样之后,客户端每次进行请求的时候,springMVC都会检查request里面是否包含多媒体信息,如果包含了就会使用Mu

  • PHP使用PHPExcel实现批量上传到数据库的方法

    此例子只使用execel2003的.xls文档,若使用的是其他版本,可以保存格式为"Execel 97-2003 工作簿(*.xls)"即.xls文件类型即可! 功能说明:只能上传Excel2003类型的xls文件,大小不超过5M.可下载例子模板添加数据后即可上传! 前台test.php页面 <!DOCTYPE html> <html> <head> <title></title> </head> <meta

随机推荐