热门标签 | HotTags
当前位置:  开发笔记 > 前端 > 正文

SpringMVC上传和解析Excel方法

这篇文章主要介绍了SpringMVC上传和解析Excel方法,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

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

XML文件配置

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

 
 
  


Jsp界面配置

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 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 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 customerList=new ArrayList();
  //初始化输入流
  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 getExcelInfo(InputStream is,boolean isExcel2003){
  List 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 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 oTAPolicyModelList=new ArrayList();
  OTAPolicyModel oTAPolicyModel;
  //循环Excel行数,从第二行开始。标题不入库
  for(int r=1;r

工具类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)$");
}
}

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

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

更多精彩内容,请点击 《spring上传下载专题》进行深入学习和研究。

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


推荐阅读
  • Allegro总结:1.防焊层(SolderMask):又称绿油层,PCB非布线层,用于制成丝网印板,将不需要焊接的地方涂上防焊剂.在防焊层上预留的焊盘大小要比实际的焊盘大一些,其差值一般 ... [详细]
  • 本文介绍了在开发Android新闻App时,搭建本地服务器的步骤。通过使用XAMPP软件,可以一键式搭建起开发环境,包括Apache、MySQL、PHP、PERL。在本地服务器上新建数据库和表,并设置相应的属性。最后,给出了创建new表的SQL语句。这个教程适合初学者参考。 ... [详细]
  • 这是原文链接:sendingformdata许多情况下,我们使用表单发送数据到服务器。服务器处理数据并返回响应给用户。这看起来很简单,但是 ... [详细]
  • 本文介绍了使用AJAX的POST请求实现数据修改功能的方法。通过ajax-post技术,可以实现在输入某个id后,通过ajax技术调用post.jsp修改具有该id记录的姓名的值。文章还提到了AJAX的概念和作用,以及使用async参数和open()方法的注意事项。同时强调了不推荐使用async=false的情况,并解释了JavaScript等待服务器响应的机制。 ... [详细]
  • 本文介绍了高校天文共享平台的开发过程中的思考和规划。该平台旨在为高校学生提供天象预报、科普知识、观测活动、图片分享等功能。文章分析了项目的技术栈选择、网站前端布局、业务流程、数据库结构等方面,并总结了项目存在的问题,如前后端未分离、代码混乱等。作者表示希望通过记录和规划,能够理清思路,进一步完善该平台。 ... [详细]
  • iOS超签签名服务器搭建及其优劣势
    本文介绍了搭建iOS超签签名服务器的原因和优势,包括不掉签、用户可以直接安装不需要信任、体验好等。同时也提到了超签的劣势,即一个证书只能安装100个,成本较高。文章还详细介绍了超签的实现原理,包括用户请求服务器安装mobileconfig文件、服务器调用苹果接口添加udid等步骤。最后,还提到了生成mobileconfig文件和导出AppleWorldwideDeveloperRelationsCertificationAuthority证书的方法。 ... [详细]
  • 本文介绍了如何使用JSONObiect和Gson相关方法实现json数据与kotlin对象的相互转换。首先解释了JSON的概念和数据格式,然后详细介绍了相关API,包括JSONObject和Gson的使用方法。接着讲解了如何将json格式的字符串转换为kotlin对象或List,以及如何将kotlin对象转换为json字符串。最后提到了使用Map封装json对象的特殊情况。文章还对JSON和XML进行了比较,指出了JSON的优势和缺点。 ... [详细]
  • Node.js学习笔记(一)package.json及cnpm
    本文介绍了Node.js中包的概念,以及如何使用包来统一管理具有相互依赖关系的模块。同时还介绍了NPM(Node Package Manager)的基本介绍和使用方法,以及如何通过NPM下载第三方模块。 ... [详细]
  • 本文介绍了Java后台Jsonp处理方法及其应用场景。首先解释了Jsonp是一个非官方的协议,它允许在服务器端通过Script tags返回至客户端,并通过javascript callback的形式实现跨域访问。然后介绍了JSON系统开发方法,它是一种面向数据结构的分析和设计方法,以活动为中心,将一连串的活动顺序组合成一个完整的工作进程。接着给出了一个客户端示例代码,使用了jQuery的ajax方法请求一个Jsonp数据。 ... [详细]
  • XMLhttpREquest_Ajax技术总结之XmlHttpRequest
    Ajax1、 什么是ajax   ... [详细]
  • 1、概述首先和大家一起回顾一下Java消息服务,在我之前的博客《Java消息队列-JMS概述》中,我为大家分析了:然后在另一篇博客《Java消息队列-ActiveMq实战》中 ... [详细]
  • 这篇文章给大家讲解如何利用dhtmlxGantt在服务器端集成数据。脚本数据保存如果您已初始化dataProcessor,则用户或以编程方式所做的任何更改都将自动 ... [详细]
  • JDK1.7及之前的JMM先看一张图,很清晰的说明了JAVA内存结构布局:JAVA内存结构主要分为三大块:堆内存、方法区和栈。堆内存是JVM中最大的一块内存,由年轻代和老年代组成。 ... [详细]
  • php生成shtml类用法的简单介绍
    本文目录一览:1、phpcmsv9怎么生成shtml ... [详细]
  • 20155317王新玮《网络对抗技术》实验8 WEB基础实践
    20155317王新玮《网络对抗技术》实验8 WEB基础实践 ... [详细]
author-avatar
汽车之家马甲小宝宝_457
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有