jeesite 导入 excel 表格

本贴最后更新于 2285 天前,其中的信息可能已经天翻地覆

1、利用代码生成功能制作好单表增删改查的模块

2、修改前段代码,插入‘导入’按钮并且写好导入弹出框界面,加入复制粘贴用户模块的前段代码

3、修改实体类,加上注释

4、在控制器加入下载模板和导入功能的响应方法

第一步:界面 加入导入按钮

第二步:修改前段代码,如下:

<%@ page contentType="text/html;charset=UTF-8"%> <%@ include file="/WEB-INF/views/include/taglib.jsp"%> <html> <head> <title>课程表管理</title> <meta name="decorator" content="default" /> <script type="text/javascript"> $(document).ready(function() { $("#btnImport").click(function(){ $.jBox($("#importBox").html(), {title:"导入数据", buttons:{"关闭":true}, bottomText:"导入文件不能超过5M,仅允许导入“xls”或“xlsx”格式文件!"}); }); }); function page(n, s) { $("#pageNo").val(n); $("#pageSize").val(s); $("#searchForm").submit(); return false; } </script> </head> <body> <div id="importBox" class="hide"> <form id="importForm" action="${ctx}/jsl/jslCourse/import" method="post" enctype="multipart/form-data" class="form-search" style="padding-left: 20px; text-align: center;" onsubmit="loading('正在导入,请稍等...');"> <br /> <input id="uploadFile" name="file" type="file" style="width: 330px" /> <br /> <br /> <input id="btnImportSubmit" class="btn btn-primary" type="submit" value=" 导 入 " /> <a href="${ctx}/jsl/jslCourse/import/template">下载模板</a> </form> </div> <ul class="nav nav-tabs"> <li class="active"><a href="${ctx}/jsl/jslCourse/">课程表列表</a></li> <shiro:hasPermission name="jsl:jslCourse:edit"> <li><a href="${ctx}/jsl/jslCourse/form">课程表添加</a></li> </shiro:hasPermission> </ul> <form:form id="searchForm" modelAttribute="jslCourse" action="${ctx}/jsl/jslCourse/" method="post" class="breadcrumb form-search"> <input id="pageNo" name="pageNo" type="hidden" value="${page.pageNo}" /> <input id="pageSize" name="pageSize" type="hidden" value="${page.pageSize}" /> <ul class="ul-form"> <li><label>上课教室:</label> <form:input path="classroom" htmlEscape="false" maxlength="64" class="input-medium" /></li> <li><label>任课老师:</label> <form:input path="courseteacher" htmlEscape="false" maxlength="64" class="input-medium" /></li> <li class="btns"><input id="btnSubmit" class="btn btn-primary" type="submit" value="查询" /></li> <li class="btns"><input id="btnImport" class="btn btn-primary" type="button" value="导入" /></li> <li class="clearfix"></li> </ul> </form:form> <sys:message content="${message}" /> <table id="contentTable" class="table table-striped table-bordered table-condensed"> <thead> <tr> <th>归属公司</th> <th>归属部门</th> <th>课程名称</th> <th>上课教室</th> <th>听课老师</th> <th>任课老师</th> <th>专业班级</th> <th>听课时间</th> <th>更新时间</th> <th>备注信息</th> <shiro:hasPermission name="jsl:jslCourse:edit"> <th>操作</th> </shiro:hasPermission> </tr> </thead> <tbody> <c:forEach items="${page.list}" var="jslCourse"> <tr> <td><a href="${ctx}/jsl/jslCourse/form?id=${jslCourse.id}"> ${jslCourse.company.name} </a></td> <td>${jslCourse.office.name}</td> <td>${jslCourse.coursename}</td> <td>${jslCourse.classroom}</td> <td>${jslCourse.listenteacher}</td> <td>${jslCourse.courseteacher}</td> <td>${jslCourse.professionalclass}</td> <td><fmt:formatDate value="${jslCourse.coursetime}" pattern="yyyy-MM-dd HH:mm:ss" /></td> <td><fmt:formatDate value="${jslCourse.updateDate}" pattern="yyyy-MM-dd HH:mm:ss" /></td> <td>${jslCourse.remarks}</td> <shiro:hasPermission name="jsl:jslCourse:edit"> <td><a href="${ctx}/jsl/jslCourse/form?id=${jslCourse.id}">修改</a> <a href="${ctx}/jsl/jslCourse/delete?id=${jslCourse.id}" onclick="return confirmx('确认要删除该课程表吗?', this.href)">删除</a></td> </shiro:hasPermission> </tr> </c:forEach> </tbody> </table> <div class="pagination">${page}</div> </body> </html>

第三步:实体类中凡是要通过 excel 导入的字段都需要在实体类的字段的 get()方法添加注释

/** * Copyright &copy; 2012-2016 <a href="https://github.com/thinkgem/jeesite">JeeSite</a> All rights reserved. */ package com.thinkgem.jeesite.modules.jsl.entity; import com.thinkgem.jeesite.modules.sys.entity.Office; import javax.validation.constraints.NotNull; import org.hibernate.validator.constraints.Length; import java.util.Date; import com.fasterxml.jackson.annotation.JsonFormat; import com.fasterxml.jackson.annotation.JsonIgnore; import com.thinkgem.jeesite.common.persistence.DataEntity; import com.thinkgem.jeesite.common.utils.excel.annotation.ExcelField; /** * 课程表管理Entity * @author jsl * @version 2017-10-21 */ public class JslCourse extends DataEntity<JslCourse> { private static final long serialVersionUID = 1L; private Office company; // 归属公司 private Office office; // 归属部门 private String coursename; // 课程名称 private String classroom; // 上课教室 private String listenteacher; //听课老师 private String courseteacher; // 任课老师 private String professionalclass; // 专业班级 private Date coursetime; // 听课时间 public JslCourse() { super(); } public JslCourse(String id){ super(id); } @JsonIgnore @NotNull(message="归属公司不能为空") @ExcelField(title="归属公司", align=2, sort=20) public Office getCompany() { return company; } public void setCompany(Office company) { this.company = company; } @JsonIgnore @NotNull(message="归属部门不能为空") @ExcelField(title="归属部门", align=2, sort=25) public Office getOffice() { return office; } public void setOffice(Office office) { this.office = office; } @Length(min=0, max=64, message="课程名长度必须介于 1 和 64之间") @ExcelField(title="课程名", align=2, sort=30) public String getCoursename() { return coursename; } public void setCoursename(String coursename) { this.coursename = coursename; } @ExcelField(title="课室", align=2, sort=35) @Length(min=0, max=64, message="上课教室长度必须介于 0 和 64 之间") public String getClassroom() { return classroom; } public void setClassroom(String classroom) { this.classroom = classroom; } @ExcelField(title="听课老师", align=2, sort=40) @Length(min=0, max=64, message="听课老师长度必须介于 0 和 64 之间") public String getListenteacher() { return listenteacher; } public void setListenteacher(String listenteacher) { this.listenteacher = listenteacher; } @ExcelField(title="任课老师", align=2, sort=45) @Length(min=0, max=64, message="任课老师长度必须介于 0 和 64 之间") public String getCourseteacher() { return courseteacher; } public void setCourseteacher(String courseteacher) { this.courseteacher = courseteacher; } @ExcelField(title="专业班级", align=2, sort=50) @Length(min=0, max=64, message="专业班级长度必须介于 0 和 64 之间") public String getProfessionalclass() { return professionalclass; } public void setProfessionalclass(String professionalclass) { this.professionalclass = professionalclass; } @ExcelField(title="听课时间", align=2, sort=55) @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss") public Date getCoursetime() { return coursetime; } public void setCoursetime(Date coursetime) { this.coursetime = coursetime; } }

第四步:在控制层添加响应导入按钮的操作,主要有两个部分,一个是下载模板、一个是导入响应

/** * Copyright &copy; 2012-2016 <a href="https://github.com/thinkgem/jeesite">JeeSite</a> All rights reserved. */ package com.thinkgem.jeesite.modules.jsl.web; import java.util.List; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import javax.validation.ConstraintViolationException; import org.apache.shiro.authz.annotation.RequiresPermissions; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Controller; import org.springframework.ui.Model; import org.springframework.web.bind.annotation.ModelAttribute; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RequestMethod; import org.springframework.web.bind.annotation.RequestParam; import org.springframework.web.multipart.MultipartFile; import org.springframework.web.servlet.mvc.support.RedirectAttributes; import com.google.common.collect.Lists; import com.thinkgem.jeesite.common.beanvalidator.BeanValidators; import com.thinkgem.jeesite.common.config.Global; import com.thinkgem.jeesite.common.persistence.Page; import com.thinkgem.jeesite.common.web.BaseController; import com.thinkgem.jeesite.common.utils.StringUtils; import com.thinkgem.jeesite.common.utils.excel.ExportExcel; import com.thinkgem.jeesite.common.utils.excel.ImportExcel; import com.thinkgem.jeesite.modules.jsl.entity.JslCourse; import com.thinkgem.jeesite.modules.jsl.service.JslCourseService; /** * 课程表管理Controller * @author jsl * @version 2017-10-21 */ @Controller @RequestMapping(value = "${adminPath}/jsl/jslCourse") public class JslCourseController extends BaseController { @Autowired private JslCourseService jslCourseService; @ModelAttribute public JslCourse get(@RequestParam(required=false) String id) { JslCourse entity = null; if (StringUtils.isNotBlank(id)){ entity = jslCourseService.get(id); } if (entity == null){ entity = new JslCourse(); } return entity; } @RequiresPermissions("jsl:jslCourse:view") @RequestMapping(value = {"index"}) public String index(JslCourse jslCourse, Model model) { return "modules/jsl/jslCourseIndex"; } @RequiresPermissions("jsl:jslCourse:edit") @RequestMapping(value = "import", method=RequestMethod.POST) public String importFile(MultipartFile file, RedirectAttributes redirectAttributes){ try { int successNum=0; int failureNum=0; StringBuilder failureMsg=new StringBuilder(); ImportExcel ei=new ImportExcel(file, 1, 0); List<JslCourse> list=ei.getDataList(JslCourse.class); for(JslCourse jslCourse:list){ try { jslCourseService.save(jslCourse); successNum++; addMessage(redirectAttributes, "已成功导入 "+successNum+" 条用户"+failureMsg); } catch (ConstraintViolationException ex) { failureMsg.append("<br/>课程名 "+jslCourse.getCoursename()+" 导入失败:"); List<String> messageList = BeanValidators.extractPropertyAndMessageAsList(ex, ": "); for (String message : messageList){ failureMsg.append(message+"; "); failureNum++; } }catch (Exception ex) { failureMsg.append("<br/>课程名 "+jslCourse.getCoursename()+" 导入失败:"+ex.getMessage()); } } if (failureNum>0){ failureMsg.insert(0, ",失败 "+failureNum+" 条用户,导入信息如下:"); } addMessage(redirectAttributes, "已成功导入 "+successNum+" 条课程"+failureMsg); } catch (Exception e) { addMessage(redirectAttributes, "导入课程表失败!失败信息:"+e.getMessage()); } return "redirect:" + adminPath + "/jsl/jslCourse?repage"; } /** * 下载导入课程表数据模板 * @param response * @param redirectAttributes * @return */ @RequiresPermissions("jsl:jslCourse:view") @RequestMapping(value = "import/template") public String importFileTemplate(HttpServletResponse response, RedirectAttributes redirectAttributes) { try { String fileName = "课程表数据导入模板.xlsx"; List<JslCourse> list = Lists.newArrayList(); list.add(new JslCourse()); new ExportExcel("课程表数据", JslCourse.class, 2).setDataList(list).write(response, fileName).dispose(); return null; } catch (Exception e) { addMessage(redirectAttributes, "导入模板下载失败!失败信息:"+e.getMessage()); } return "redirect:" + adminPath + "/jsl/jslCourse?repage"; } @RequiresPermissions("jsl:jslCourse:view") @RequestMapping(value = {"list", ""}) public String list(JslCourse jslCourse, HttpServletRequest request, HttpServletResponse response, Model model) { Page<JslCourse> page = jslCourseService.findPage(new Page<JslCourse>(request, response), jslCourse); model.addAttribute("page", page); return "modules/jsl/jslCourseList"; } @RequiresPermissions("jsl:jslCourse:view") @RequestMapping(value = "form") public String form(JslCourse jslCourse, Model model) { model.addAttribute("jslCourse", jslCourse); return "modules/jsl/jslCourseForm"; } @RequiresPermissions("jsl:jslCourse:edit") @RequestMapping(value = "save") public String save(JslCourse jslCourse, Model model, RedirectAttributes redirectAttributes) { if (!beanValidator(model, jslCourse)){ return form(jslCourse, model); } jslCourseService.save(jslCourse); addMessage(redirectAttributes, "保存课程表成功"); return "redirect:"+Global.getAdminPath()+"/jsl/jslCourse/?repage"; } @RequiresPermissions("jsl:jslCourse:edit") @RequestMapping(value = "delete") public String delete(JslCourse jslCourse, RedirectAttributes redirectAttributes) { jslCourseService.delete(jslCourse); addMessage(redirectAttributes, "删除课程表成功"); return "redirect:"+Global.getAdminPath()+"/jsl/jslCourse/?repage"; } }

相关帖子

欢迎来到这里!

我们正在构建一个小众社区,大家在这里相互信任,以平等 • 自由 • 奔放的价值观进行分享交流。最终,希望大家能够找到与自己志同道合的伙伴,共同成长。

注册 关于
请输入回帖内容 ...

推荐标签 标签

  • 域名

    域名(Domain Name),简称域名、网域,是由一串用点分隔的名字组成的 Internet 上某一台计算机或计算机组的名称,用于在数据传输时标识计算机的电子方位(有时也指地理位置)。

    43 引用 • 208 回帖
  • PWA

    PWA(Progressive Web App)是 Google 在 2015 年提出、2016 年 6 月开始推广的项目。它结合了一系列现代 Web 技术,在网页应用中实现和原生应用相近的用户体验。

    14 引用 • 69 回帖 • 176 关注
  • 智能合约

    智能合约(Smart contract)是一种旨在以信息化方式传播、验证或执行合同的计算机协议。智能合约允许在没有第三方的情况下进行可信交易,这些交易可追踪且不可逆转。智能合约概念于 1994 年由 Nick Szabo 首次提出。

    1 引用 • 11 回帖 • 2 关注
  • 钉钉

    钉钉,专为中国企业打造的免费沟通协同多端平台, 阿里巴巴出品。

    15 引用 • 67 回帖 • 296 关注
  • Markdown

    Markdown 是一种轻量级标记语言,用户可使用纯文本编辑器来排版文档,最终通过 Markdown 引擎将文档转换为所需格式(比如 HTML、PDF 等)。

    169 引用 • 1527 回帖 • 1 关注
  • 笔记

    好记性不如烂笔头。

    310 引用 • 794 回帖
  • SendCloud

    SendCloud 由搜狐武汉研发中心孵化的项目,是致力于为开发者提供高质量的触发邮件服务的云端邮件发送平台,为开发者提供便利的 API 接口来调用服务,让邮件准确迅速到达用户收件箱并获得强大的追踪数据。

    2 引用 • 8 回帖 • 487 关注
  • Facebook

    Facebook 是一个联系朋友的社交工具。大家可以通过它和朋友、同事、同学以及周围的人保持互动交流,分享无限上传的图片,发布链接和视频,更可以增进对朋友的了解。

    4 引用 • 15 回帖 • 444 关注
  • TensorFlow

    TensorFlow 是一个采用数据流图(data flow graphs),用于数值计算的开源软件库。节点(Nodes)在图中表示数学操作,图中的线(edges)则表示在节点间相互联系的多维数据数组,即张量(tensor)。

    20 引用 • 19 回帖 • 1 关注
  • 设计模式

    设计模式(Design pattern)代表了最佳的实践,通常被有经验的面向对象的软件开发人员所采用。设计模式是软件开发人员在软件开发过程中面临的一般问题的解决方案。这些解决方案是众多软件开发人员经过相当长的一段时间的试验和错误总结出来的。

    200 引用 • 120 回帖
  • JRebel

    JRebel 是一款 Java 虚拟机插件,它使得 Java 程序员能在不进行重部署的情况下,即时看到代码的改变对一个应用程序带来的影响。

    26 引用 • 78 回帖 • 676 关注
  • Firefox

    Mozilla Firefox 中文俗称“火狐”(正式缩写为 Fx 或 fx,非正式缩写为 FF),是一个开源的网页浏览器,使用 Gecko 排版引擎,支持多种操作系统,如 Windows、OSX 及 Linux 等。

    7 引用 • 30 回帖 • 396 关注
  • SSL

    SSL(Secure Sockets Layer 安全套接层),及其继任者传输层安全(Transport Layer Security,TLS)是为网络通信提供安全及数据完整性的一种安全协议。TLS 与 SSL 在传输层对网络连接进行加密。

    70 引用 • 193 回帖 • 413 关注
  • Ruby

    Ruby 是一种开源的面向对象程序设计的服务器端脚本语言,在 20 世纪 90 年代中期由日本的松本行弘(まつもとゆきひろ/Yukihiro Matsumoto)设计并开发。在 Ruby 社区,松本也被称为马茨(Matz)。

    7 引用 • 31 回帖 • 253 关注
  • frp

    frp 是一个可用于内网穿透的高性能的反向代理应用,支持 TCP、UDP、 HTTP 和 HTTPS 协议。

    20 引用 • 7 回帖
  • 外包

    有空闲时间是接外包好呢还是学习好呢?

    26 引用 • 233 回帖 • 2 关注
  • Logseq

    Logseq 是一个隐私优先、开源的知识库工具。

    Logseq is a joyful, open-source outliner that works on top of local plain-text Markdown and Org-mode files. Use it to write, organize and share your thoughts, keep your to-do list, and build your own digital garden.

    7 引用 • 69 回帖 • 1 关注
  • 单点登录

    单点登录(Single Sign On)是目前比较流行的企业业务整合的解决方案之一。SSO 的定义是在多个应用系统中,用户只需要登录一次就可以访问所有相互信任的应用系统。

    9 引用 • 25 回帖 • 3 关注
  • SMTP

    SMTP(Simple Mail Transfer Protocol)即简单邮件传输协议,它是一组用于由源地址到目的地址传送邮件的规则,由它来控制信件的中转方式。SMTP 协议属于 TCP/IP 协议簇,它帮助每台计算机在发送或中转信件时找到下一个目的地。

    4 引用 • 18 回帖 • 636 关注
  • Sublime

    Sublime Text 是一款可以用来写代码、写文章的文本编辑器。支持代码高亮、自动完成,还支持通过插件进行扩展。

    10 引用 • 5 回帖 • 2 关注
  • JavaScript

    JavaScript 一种动态类型、弱类型、基于原型的直译式脚本语言,内置支持类型。它的解释器被称为 JavaScript 引擎,为浏览器的一部分,广泛用于客户端的脚本语言,最早是在 HTML 网页上使用,用来给 HTML 网页增加动态功能。

    729 引用 • 1278 回帖
  • V2EX

    V2EX 是创意工作者们的社区。这里目前汇聚了超过 400,000 名主要来自互联网行业、游戏行业和媒体行业的创意工作者。V2EX 希望能够成为创意工作者们的生活和事业的一部分。

    16 引用 • 236 回帖 • 279 关注
  • Postman

    Postman 是一款简单好用的 HTTP API 调试工具。

    4 引用 • 3 回帖
  • FFmpeg

    FFmpeg 是一套可以用来记录、转换数字音频、视频,并能将其转化为流的开源计算机程序。

    23 引用 • 32 回帖
  • Sandbox

    如果帖子标签含有 Sandbox ,则该帖子会被视为“测试帖”,主要用于测试社区功能,排查 bug 等,该标签下内容不定期进行清理。

    426 引用 • 1250 回帖 • 599 关注
  • Thymeleaf

    Thymeleaf 是一款用于渲染 XML/XHTML/HTML5 内容的模板引擎。类似 Velocity、 FreeMarker 等,它也可以轻易的与 Spring 等 Web 框架进行集成作为 Web 应用的模板引擎。与其它模板引擎相比,Thymeleaf 最大的特点是能够直接在浏览器中打开并正确显示模板页面,而不需要启动整个 Web 应用。

    11 引用 • 19 回帖 • 382 关注
  • 星云链

    星云链是一个开源公链,业内简单的将其称为区块链上的谷歌。其实它不仅仅是区块链搜索引擎,一个公链的所有功能,它基本都有,比如你可以用它来开发部署你的去中心化的 APP,你可以在上面编写智能合约,发送交易等等。3 分钟快速接入星云链 (NAS) 测试网

    3 引用 • 16 回帖 • 1 关注