jeesite 导入 excel 表格

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

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";
}

}

相关帖子

欢迎来到这里!

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

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

推荐标签 标签

  • B3log

    B3log 是一个开源组织,名字来源于“Bulletin Board Blog”缩写,目标是将独立博客与论坛结合,形成一种新的网络社区体验,详细请看 B3log 构思。目前 B3log 已经开源了多款产品:SymSoloVditor思源笔记

    1063 引用 • 3454 回帖 • 189 关注
  • 七牛云

    七牛云是国内领先的企业级公有云服务商,致力于打造以数据为核心的场景化 PaaS 服务。围绕富媒体场景,七牛先后推出了对象存储,融合 CDN 加速,数据通用处理,内容反垃圾服务,以及直播云服务等。

    27 引用 • 225 回帖 • 163 关注
  • IDEA

    IDEA 全称 IntelliJ IDEA,是一款 Java 语言开发的集成环境,在业界被公认为最好的 Java 开发工具之一。IDEA 是 JetBrains 公司的产品,这家公司总部位于捷克共和国的首都布拉格,开发人员以严谨著称的东欧程序员为主。

    181 引用 • 400 回帖
  • Shell

    Shell 脚本与 Windows/Dos 下的批处理相似,也就是用各类命令预先放入到一个文件中,方便一次性执行的一个程序文件,主要是方便管理员进行设置或者管理用的。但是它比 Windows 下的批处理更强大,比用其他编程程序编辑的程序效率更高,因为它使用了 Linux/Unix 下的命令。

    123 引用 • 74 回帖 • 2 关注
  • MySQL

    MySQL 是一个关系型数据库管理系统,由瑞典 MySQL AB 公司开发,目前属于 Oracle 公司。MySQL 是最流行的关系型数据库管理系统之一。

    692 引用 • 535 回帖
  • C

    C 语言是一门通用计算机编程语言,应用广泛。C 语言的设计目标是提供一种能以简易的方式编译、处理低级存储器、产生少量的机器码以及不需要任何运行环境支持便能运行的编程语言。

    85 引用 • 165 回帖 • 2 关注
  • Bootstrap

    Bootstrap 是 Twitter 推出的一个用于前端开发的开源工具包。它由 Twitter 的设计师 Mark Otto 和 Jacob Thornton 合作开发,是一个 CSS / HTML 框架。

    18 引用 • 33 回帖 • 667 关注
  • 思源笔记

    思源笔记是一款隐私优先的个人知识管理系统,支持完全离线使用,同时也支持端到端加密同步。

    融合块、大纲和双向链接,重构你的思维。

    23014 引用 • 92572 回帖
  • WebComponents

    Web Components 是 W3C 定义的标准,它给了前端开发者扩展浏览器标签的能力,可以方便地定制可复用组件,更好的进行模块化开发,解放了前端开发者的生产力。

    1 引用 • 4 关注
  • Telegram

    Telegram 是一个非盈利性、基于云端的即时消息服务。它提供了支持各大操作系统平台的开源的客户端,也提供了很多强大的 APIs 给开发者创建自己的客户端和机器人。

    5 引用 • 35 回帖
  • Ruby

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

    7 引用 • 31 回帖 • 216 关注
  • Facebook

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

    4 引用 • 15 回帖 • 440 关注
  • Docker

    Docker 是一个开源的应用容器引擎,让开发者可以打包他们的应用以及依赖包到一个可移植的容器中,然后发布到任何流行的操作系统上。容器完全使用沙箱机制,几乎没有性能开销,可以很容易地在机器和数据中心中运行。

    492 引用 • 926 回帖
  • MongoDB

    MongoDB(来自于英文单词“Humongous”,中文含义为“庞大”)是一个基于分布式文件存储的数据库,由 C++ 语言编写。旨在为应用提供可扩展的高性能数据存储解决方案。MongoDB 是一个介于关系数据库和非关系数据库之间的产品,是非关系数据库当中功能最丰富,最像关系数据库的。它支持的数据结构非常松散,是类似 JSON 的 BSON 格式,因此可以存储比较复杂的数据类型。

    90 引用 • 59 回帖 • 1 关注
  • webpack

    webpack 是一个用于前端开发的模块加载器和打包工具,它能把各种资源,例如 JS、CSS(less/sass)、图片等都作为模块来使用和处理。

    41 引用 • 130 回帖 • 253 关注
  • jQuery

    jQuery 是一套跨浏览器的 JavaScript 库,强化 HTML 与 JavaScript 之间的操作。由 John Resig 在 2006 年 1 月的 BarCamp NYC 上释出第一个版本。全球约有 28% 的网站使用 jQuery,是非常受欢迎的 JavaScript 库。

    63 引用 • 134 回帖 • 724 关注
  • JSON

    JSON (JavaScript Object Notation)是一种轻量级的数据交换格式。易于人类阅读和编写。同时也易于机器解析和生成。

    52 引用 • 190 回帖 • 1 关注
  • Vue.js

    Vue.js(读音 /vju ː/,类似于 view)是一个构建数据驱动的 Web 界面库。Vue.js 的目标是通过尽可能简单的 API 实现响应的数据绑定和组合的视图组件。

    265 引用 • 666 回帖 • 1 关注
  • 尊园地产

    昆明尊园房地产经纪有限公司,即:Kunming Zunyuan Property Agency Company Limited(简称“尊园地产”)于 2007 年 6 月开始筹备,2007 年 8 月 18 日正式成立,注册资本 200 万元,公司性质为股份经纪有限公司,主营业务为:代租、代售、代办产权过户、办理银行按揭、担保、抵押、评估等。

    1 引用 • 22 回帖 • 772 关注
  • JetBrains

    JetBrains 是一家捷克的软件开发公司,该公司位于捷克的布拉格,并在俄国的圣彼得堡及美国麻州波士顿都设有办公室,该公司最为人所熟知的产品是 Java 编程语言开发撰写时所用的集成开发环境:IntelliJ IDEA

    18 引用 • 54 回帖
  • Love2D

    Love2D 是一个开源的, 跨平台的 2D 游戏引擎。使用纯 Lua 脚本来进行游戏开发。目前支持的平台有 Windows, Mac OS X, Linux, Android 和 iOS。

    14 引用 • 53 回帖 • 538 关注
  • Solidity

    Solidity 是一种智能合约高级语言,运行在 [以太坊] 虚拟机(EVM)之上。它的语法接近于 JavaScript,是一种面向对象的语言。

    3 引用 • 18 回帖 • 401 关注
  • DevOps

    DevOps(Development 和 Operations 的组合词)是一组过程、方法与系统的统称,用于促进开发(应用程序/软件工程)、技术运营和质量保障(QA)部门之间的沟通、协作与整合。

    51 引用 • 25 回帖
  • 反馈

    Communication channel for makers and users.

    123 引用 • 913 回帖 • 250 关注
  • PostgreSQL

    PostgreSQL 是一款功能强大的企业级数据库系统,在 BSD 开源许可证下发布。

    22 引用 • 22 回帖
  • 大数据

    大数据(big data)是指无法在一定时间范围内用常规软件工具进行捕捉、管理和处理的数据集合,是需要新处理模式才能具有更强的决策力、洞察发现力和流程优化能力的海量、高增长率和多样化的信息资产。

    93 引用 • 113 回帖
  • 房星科技

    房星网,我们不和没有钱的程序员谈理想,我们要让程序员又有理想又有钱。我们有雄厚的房地产行业线下资源,遍布昆明全城的 100 家门店、四千地产经纪人是我们坚实的后盾。

    6 引用 • 141 回帖 • 584 关注