一.配置文件名称、路径、内容:

 <bean id="multipartResolver" class="org.springframework.web.multipart.commons.CommonsMultipartResolver">
<property name="defaultEncoding" value="utf-8"></property>
<property name="maxUploadSize" value="104857600"></property><!-- 最大上传文件大小:100M -->
<property name="maxInMemorySize" value="10240"></property>
</bean>

二.controller

 @RequestMapping(value = "/importAccountManager")
@ResponseBody
public ModelAndView importAccountManager(HttpServletRequest request, HttpServletResponse response,
@RequestParam("file") CommonsMultipartFile file) {
ModelAndView mav = new ModelAndView(new MappingJackson2JsonView());
try (InputStream inputXls = file.getInputStream();
InputStream inputXML = new BufferedInputStream(getClass().getClassLoader().getResourceAsStream(ACCOUNT_TEMPLATE_PATH));) {
XLSReader mainReader = ReaderBuilder.buildFromXML(inputXML);
List<AccountManagerModel> dataList = new ArrayList<>();
Map<String, Object> params = new HashMap<>();
params.put("dataList", dataList);
mainReader.read(inputXls, params);
String message = accountManagerService.importAccountManager(dataList);
if(StringUtils.isNotBlank(message)) {
mav.addObject("success", false);
} else {
mav.addObject("success", true);
}
mav.addObject("message", message);
} catch (Throwable e) {
LOGGER.error("importAccountManager causes inner exception:", e);
mav.addObject("success", false);
mav.addObject("message", e.getMessage());
}
return mav;
}

三.service

//serviceImpl
@Override
public String importAccountManager(List<AccountManagerModel> accountList) throws Exception {
List<OrgModel> orgList = orgMapper.queryOrg();
String message = validate(accountList, orgList);
if(message == null) {
for(AccountManagerModel account : accountList) {
String consNo = account.getConsNo();
AccountManagerModel oldAccount = accountManagerMapper.queryByConsNo(consNo);
if(oldAccount == null) {
insertAccountManager(account);
} else {
editAccountManager(account, oldAccount);
}
}
}
return message;
}
//interface
/**
* 导入客户数据
*
* @param accountList
* @return
* @throws Exception
*/
public String importAccountManager(List<AccountManagerModel> accountList) throws Exception;

四.mapper

//interface
/**
* 通过客户号查询企业
*
* @param consNo
* @return
* @throws throws Exception
*/
public AccountManagerModel queryByConsNo(String consNo) throws Exception;
//mapper映射xml
<select id="queryByConsNo" parameterType="java.lang.String" resultMap="AccountManagerResultMap">
select
a.cons_id,
a.cons_no,
a.cons_name,
a.cons_address,
a.legal_person,
a.legal_person_phone,
a.bill_person,
a.bill_person_phone,
a.electric_person,
a.electric_person_phone,
a.entrusted_person,
a.entrusted_person_phone,
a.cons_state,
a.org_no,
b.org_name
from be_cons_info a, o_org b
where a.org_no = b.org_no
and a.cons_no = #{consNo}
</select>

五.Html

<div class="tool_wrapper">
<button class="ui-btn ui-btn-primary" onclick="addAccountManager();">新增</button>
<button class="ui-btn ui-btn-primary left20" onclick="editAccountManager();">修改</button>
<!-- <button class="ui-btn ui-btn-primary left20" onclick="cancelAccountManager();">注销</button> -->
<button class="ui-btn ui-btn-primary left20 fileinput-button">
<span>导入Excel</span>
<input id="fileupload" type="file" name="file" accept="application/vnd.ms-excel">
</button>
<button class="ui-btn ui-btn-primary left20" onclick="exportXls()">导出Excel</button>
<button class="ui-btn ui-btn-primary left20" onclick="downloadXlsTemplate()">下载模板</button>
</div>

六.js

function bindFileUploadEvent() {
$('#fileupload').fileupload({
url: basePath + 'accountManager/importAccountManager',
type: 'post',
dataType: 'json',
beforeSend: function(xhr){
xhr.setRequestHeader(header, token);
},
send: function(e, data) {
var file = data.files[0];
var fileName = file.name;
var fileSize = file.size;
var errorMsg = "请选择Excel文件!";
var pass = validateFileName(fileName, ".xls");
if(pass && fileSize >= 10485760) {
pass = false;
errorMsg = "选择的Excel文件须小于10M!";
}
if(!pass) {
$('#fileupload').val('');
errorDialog(errorMsg);
} else {
if(parent.progress) {
parent.progress.show();
}
}
return pass;
},
done: function(e, data) {
var result = data.result;
if(result.success) {
queryAccountManager();
succDialog("客户数据导入成功!");
} else {
errorDialog(result.message);
}
},
fail: function(e, data) {
if(data.textStatus != null) {
errorDialog("系统发生故障,请联系系统管理员或稍后重试!");
}
},
always: function(e, data) {
if(parent.progress) {
parent.progress.hide();
}
}
});
}

Java实现导入Excel文件的更多相关文章

  1. java如何导入Excel文件

    Java使用POI导入Excel文件,操作起来比较简单,支持xlsx格式. 下载POI资源包 从官网https://poi.apache.org/下载POI,笔者选择的是版本是3.17,下载后文件名是 ...

  2. Java解析导入Excel文件后台代码实现

    使用MultipartFile上传Excel文件后端代码实现:(springmvc下的spring-webmvc (MultipartFile )上传) 由于POST一个包含文件上传的Form会以mu ...

  3. Java POI导入Excel文件

    今天在公司需要做个导入Excel文件的功能,所以研究了一下,参考网上的一些资料总算是做出来了,在此记录一下防止以后忘记怎么弄. 本人用的是poi3.8,所以需要的JAR包如下: poi-3.8.jar ...

  4. Java jxl导入excel文件,导入的数字、身份证号码、手机号变成了科学计数法,解决方案

    原文出自:https://blog.csdn.net/seesun2012 这是一个execl文件导入数据库操作,使用jxl解析execl导入数据库过程出现了科学计数法,与想要导入的数据不匹配,以下是 ...

  5. .Net MVC 导入导出Excel总结(三种导出Excel方法,一种导入Excel方法) 通过MVC控制器导出导入Excel文件(可用于java SSH架构)

    .Net MVC  导入导出Excel总结(三种导出Excel方法,一种导入Excel方法) [原文地址] 通过MVC控制器导出导入Excel文件(可用于java SSH架构)   public cl ...

  6. java后端导入excel模板和导入excel文件去读数据

    模板转载地址:https://www.cnblogs.com/zhangyangtao/p/9802948.html 直接上代码(我是基于ssm写的demo,导入文件目前只能读取.xls后缀的exce ...

  7. springMVC(5)---导入excel文件数据到数据库

    springMVC(5)---导入excel文件数据到数据库 上一篇文章写了从数据库导出数据到excel文件,这篇文章悄悄相反,写的是导入excel文件数据到数据库.上一篇链接:springMVC(4 ...

  8. 利用kettle组件导入excel文件到数据库

    利用kettle组件导入excel文件到数据库 1.     实现目标 把excel文件内容导入到目标表中:然后用java调用kettle的转换.excel文件的内容仅仅有两列,示比例如以下: wat ...

  9. java上传excel文件及解析

      java上传excel文件及解析 CreateTime--2018年3月5日16:25:14 Author:Marydon 一.准备工作 1.1 文件上传插件:swfupload: 1.2 文件上 ...

随机推荐

  1. 目录已存在导致Jenkins项目构建失败的解决方法

    Jenkins中的项目在下载源代码时,如果Working Directory中存在未加入版本控制的文件或者目录已经存在于SVN库中,会导致更新失败,整个构建终止,解决方法是将SVN的检出策略由&quo ...

  2. 从零开始的Java RASP实现(二)

    目录 2 RASP-demo 2.1 类加载机制 双亲委派 BootStrap ClassLoader 2.2 Instrumentation介绍 Instrumentation类中常用方法 Inst ...

  3. 如何请求一个需要登陆才能访问的接口(基于cookie)---apipost

    在后台在开发.调试接口时,常常会遇到需要登陆才能请求的接口. 比如:获取登陆用户的收藏列表,此时,我们就需要模拟登陆状态进行接口调试了.如图: 今天,我们讲解利用ApiPost的环境变量,解决这种需要 ...

  4. Java Swing 空布局

    Swing 空布局 试了盒布局,说实话不太会用,很多地方都没法更加的细节,又翻了翻资料,知道了还有一个空布局,一看,真不错,很适合我这种菜鸡 用坐标就可以完成界面的布局,不错 话不多说,直接代码 pa ...

  5. Git(9)-- 远程仓库的使用

    @ 目录 1.查看远程仓库:git remote 2.添加远程仓库:git remote add 3.从远程仓库中抓取与拉取:git fetch和 git pull 4.推送到远程仓库:git pus ...

  6. Django ORM记录的增删改查结合web端

    模版语法分配变量 在views.py文件中定义一个视图函数show_data: def show_data(request): # 定义一个字典 并将它展示在前端HTML文件 user_dic = { ...

  7. Docker运行PostgreSQL

    docker-compose.yml version: '3.1' services: db: image: postgres restart: always ports: - 5432:5432 e ...

  8. 简单实现 nodejs koa2 mysql 增删改查 制作接口

    1.首先 在电脑上安装 nodejs (此处略过) 2.全局安装 koa2 (这里使用的淘宝镜像cnpm,有兴趣的同学可以自行搜索下) cnpm install koa-generator -g 3. ...

  9. COM组件的使用方法

    https://prismlibrary.com/docs/wpf/converting-from-7.html Requirement: 1.创建myCom.dll,该COM只有一个组件,两个接口I ...

  10. 在ASP.NET Core调用WebService

    一.前言 现实生产中,有一些比较老的系统对外提供的接口都是WebService形式的,如果是使用.NET Framework创建的项目调用WebService非常方便,网上有很多代码示例,这里不在讲解 ...