示例:导入相关数据(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)$");
}
}
说明:上面的代码为了阅读便利而先贴的是父方法,后贴的是子方法,而在实际的代码编辑中一般是先编辑子方法,后编辑父方法,如上面应该是先编辑工具类的代码,再编辑服务层的代码,最后编辑控制器的代码。
这样,整个流程就可以了,赶紧拿去测试吧
更多精彩内容,请点击 《spring上传下载专题》进行深入学习和研究。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
# SpringMVC上传解析Excel
# SpringMVC上传Excel
# SpringMVC解析Excel
# 详解SpringMVC使用MultipartFile实现文件的上传
# SpringMVC 文件上传配置
# 多文件上传
# 使用的MultipartFile的实例
# SpringMVC文件上传 多文件上传实例
# SpringMVC 上传文件 MultipartFile 转为 File的方法
# SpringMVC中MultipartFile上传获取图片的宽度和高度详解
# jquery.form.js框架实现文件上传功能案例解析(springmvc)
# SpringMVC上传图片与访问
# SpringMvc MultipartFile实现图片文件上传示例
# SpringMVC+Ajax实现文件批量上传和下载功能实例代码
# SpringMVC按Ctrl上传多个文件的方法
# 的是
# 行数
# 而在
# 返点
# 上传
# 错误信息
# 不适用
# 为空
# 直飞
# 上传文件
# 客户端
# 是有
# 第一个
# 将在
# 请点击
# 然后再
# 可以直接
# 或其他
# 盘中
# 转换成
相关文章:
建站主机功能解析:服务器选择与快速搭建指南
网站制作多少钱一个,建一个论坛网站大约需要多少钱?
如何在建站之星绑定自定义域名?
建站之星在线版空间:自助建站+智能模板一键生成方案
5种Android数据存储方式汇总
高端建站如何打造兼具美学与转化的品牌官网?
大连网站制作费用,大连新青年网站,五年四班里的视频怎样下载啊?
天河区网站制作公司,广州天河区如何办理身份证?需要什么资料有预约的网站吗?
建站VPS推荐:2025年高性能服务器配置指南
,想在网上投简历,哪几个网站比较好?
建站之星五站合一营销型网站搭建攻略,流量入口全覆盖优化指南
如何基于PHP生成高效IDC网络公司建站源码?
东莞专业网站制作公司有哪些,东莞招聘网站哪个好?
动图在线制作网站有哪些,滑动动图图集怎么做?
php json中文编码为null的解决办法
小建面朝正北,A点实际方位是否存在偏差?
如何选择可靠的免备案建站服务器?
javascript基本数据类型及类型检测常用方法小结
建站之星后台密码遗忘如何找回?
如何通过万网虚拟主机快速搭建网站?
建站之星如何取消后台验证码生成?
已有域名如何免费搭建网站?
建站主机服务器选购指南:轻量应用与VPS配置解析
为什么Go需要go mod文件_Go go mod文件作用说明
建站主机SSH密钥生成步骤及常见问题解答?
小型网站建站如何选择虚拟主机?
网站制作说明怎么写,简述网页设计的流程并说明原因?
建站主机解析:虚拟主机配置与服务器选择指南
如何高效生成建站之星成品网站源码?
建站之星代理如何优化在线客服效率?
如何在宝塔面板中创建新站点?
c# await 一个已经完成的Task会发生什么
如何在阿里云完成域名注册与建站?
如何快速生成专业多端适配建站电话?
如何高效利用200m空间完成建站?
建站之星如何保障用户数据免受黑客入侵?
如何通过虚拟主机快速搭建个人网站?
,网页ppt怎么弄成自己的ppt?
详解jQuery中基本的动画方法
网站制作怎么样才能赚钱,用自己的电脑做服务器架设网站有什么利弊,能赚钱吗?
网站制作费用多少钱,一个网站的运营,需要哪些费用?
广州网站制作的公司,现在专门做网站的公司有没有哪几家是比较好的,性价比高,模板也多的?
如何在企业微信快速生成手机电脑官网?
免费制作小说封面的网站有哪些,怎么接网站批量的封面单?
广东企业建站网站优化与SEO营销核心策略指南
北京企业网站设计制作公司,北京铁路集团官方网站?
建站之星与建站宝盒如何选择最佳方案?
如何在宝塔面板中修改默认建站目录?
清单制作人网站有哪些,近日“兴风作浪的姑奶奶”引起很多人的关注这是什么事情?
香港服务器选型指南:免备案配置与高效建站方案解析
*请认真填写需求信息,我们会在24小时内与您取得联系。