jeecgboot 新建子模块 使用@EXCEL实现实现导入导出功能

一,用框架生成增删改查模块 

二,在实体类entity 需要导入导出的字段上加上注解@Excel

三,在controller类上继承jeecgboot通用controller     

JeecgController

并且在JeecgController里增加导出模板的方法

/*** 导出excel空模板** @param request*/protected ModelAndView exportTemplateXls(HttpServletRequest request, T object, Class<T> clazz, String title) {// Step.1 组装查询条件LoginUser sysUser = (LoginUser) SecurityUtils.getSubject().getPrincipal();// Step.2 获取空模板List<T> exportList = new ArrayList<T>();// Step.3 AutoPoi 导出ExcelModelAndView mv = new ModelAndView(new JeecgEntityExcelView());//此处设置的filename无效 ,前端会重更新设置一下mv.addObject(NormalExcelConstants.FILE_NAME, title);mv.addObject(NormalExcelConstants.CLASS, clazz);//update-begin--Author:liusq  Date:20210126 for:图片导出报错,ImageBasePath未设置--------------------ExportParams exportParams=new ExportParams(title + "电价配置导入模板表", "导出人:" + sysUser.getRealname(), title);exportParams.setImageBasePath(jeecgBaseConfig.getPath().getUpload());//update-end--Author:liusq  Date:20210126 for:图片导出报错,ImageBasePath未设置----------------------mv.addObject(NormalExcelConstants.PARAMS,exportParams);mv.addObject(NormalExcelConstants.DATA_LIST, exportList);return mv;}

四,在Controller实现导入导出的接口  把POJO替换成加了@Excel的entity实体类

/*** 导出excel** @param request* @param */@RequestMapping(value = "/exportXls")@ApiOperation("导出excel")public ModelAndView exportXls(HttpServletRequest request, POJO pojo) {return super.exportXls(request, POJO , POJO.class, "表的名字");}/*** 导出excel模板** @param request* @param tbElectrovalence*/@RequestMapping(value = "/exportTemplateXls")@ApiOperation("导出excel模板")public ModelAndView exportTemplateXls(HttpServletRequest request, POJO pojo) {return super.exportTemplateXls(request, POJO , POJO.class, "表的名字");}/*** 通过excel导入数据** @param request* @param response* @return*/@RequestMapping(value = "/importExcel", method = RequestMethod.POST)@ApiOperation("通过excel导入数据")public Result<?> importExcel(HttpServletRequest request, HttpServletResponse response) {return super.importExcel(request, response, POJO.class);}

五,测试导入导出成功

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/731205.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

HTML:用对 preload、prefetch提升网页加载速度

在网页加载和数据获取方面&#xff0c;“preload” 和 “prefetch” 都是用来优化性能和用户体验的技术手段&#xff0c;但它们有一些区别。 Preload&#xff08;预加载&#xff09;&#xff1a; preload 用于指示浏览器在解析当前文档时预先加载指定资源&#xff08;如 CSS …

专业140+总430+电子科技大学858信号与系统考研经验成电电子信息与通信工程,电科大,真题,大纲,参考书。

今年考研成绩出来&#xff0c;初试专业课858信号与系统140&#xff0c;总分430&#xff0c;其余各门分数都比较平稳&#xff0c;总分好于自己估分&#xff0c;应群里很多同学要求&#xff0c;我总结一下自己的复习经验。首先我是一个大冤种&#xff0c;专业课资料学长给了一套&…

Linux select开发服务端

多路IO技术&#xff1a;select,同时监听多个文件描述符&#xff0c;将监控的操作交给内核去处理。 数据类型fd_set:文件描述符集合。 int select(int nfds, fd_set *readfds, fd_set *writefds, fd_set *exceptfds, struct timeval *timeout); 函数介绍&am…

态势感知的扭曲

态势感知中的扭曲是指由于各种原因导致对某些信息的感知出现偏差或错误的情况。扭曲可能是由于观察者的主观因素、信息来源的局限性、信息传递的失真等引起的。 在态势感知中&#xff0c;观察者的主观因素可能导致扭曲。例如&#xff0c;观察者的个人偏见、情绪状态、经验背景等…

5.53 BCC工具之dbslower.py解读

一,工具简介 dbstat用于追踪由MySQL或PostgreSQL数据库进程执行的查询,并显示查询延迟的直方图。 二,代码示例 #!/usr/bin/env pythonfrom bcc import BPF, USDT import argparse import subprocess from time import sleep, strftimeexamples = """dbsta…

挑战杯 基于深度学习的视频多目标跟踪实现

文章目录 1 前言2 先上成果3 多目标跟踪的两种方法3.1 方法13.2 方法2 4 Tracking By Detecting的跟踪过程4.1 存在的问题4.2 基于轨迹预测的跟踪方式 5 训练代码6 最后 1 前言 &#x1f525; 优质竞赛项目系列&#xff0c;今天要分享的是 基于深度学习的视频多目标跟踪实现 …

软考高级:系统工程生命周期方法(计划驱动方法、渐进迭代式方法等)概念和例子

作者&#xff1a;明明如月学长&#xff0c; CSDN 博客专家&#xff0c;大厂高级 Java 工程师&#xff0c;《性能优化方法论》作者、《解锁大厂思维&#xff1a;剖析《阿里巴巴Java开发手册》》、《再学经典&#xff1a;《Effective Java》独家解析》专栏作者。 热门文章推荐&am…

如何在Ubuntu系统部署DbGate数据库管理工具并结合cpolar内网穿透远程访问

文章目录 1. 安装Docker2. 使用Docker拉取DbGate镜像3. 创建并启动DbGate容器4. 本地连接测试5. 公网远程访问本地DbGate容器5.1 内网穿透工具安装5.2 创建远程连接公网地址5.3 使用固定公网地址远程访问 本文主要介绍如何在Linux Ubuntu系统中使用Docker部署DbGate数据库管理工…

web组态

演示地址 &#xff1a;by组态[web组态插件] 这是一款可以嵌入到任何项目组态插件&#xff0c;功能全面&#xff0c;可根据自己的项目需要进行二次开发&#xff0c;能大大的节省在组态上的开发时间&#xff0c;代码简单易懂。 一、数据流向图及嵌入原理 数据流向 嵌入原理 …

IPD是流程界的阳明先生

这个说法是不是很有趣呢&#xff01;IPD&#xff08;Integrated Product Development&#xff0c;集成产品开发&#xff09;是一种在产品开发领域广泛应用的流程方法&#xff0c;它强调跨职能团队的协作、迭代开发和以市场需求为导向的设计。 将 IPD 与阳明先生进行类比&#…

深度神经网络 基本知识 记录

资料&#xff1a;https://www.bilibili.com/video/BV1K94y1Z7wn/?spm_id_from333.337.search-card.all.click&vd_source14a476de9132ba6b2c3cbc2221750b99 计划&#xff1a;3~4天 注&#xff1a;网课讲的内容比较糅杂&#xff0c;记录的内容可能会出现重复 杂 人工智能…

c++ primer中文版第五版作业第十七章

仓库地址 文章目录 17.117.217.317.417.517.617.717.817.917.1017.1117.1217.1317.1417.1517.1617.1717.1817.1917.2017.2117.2217.2317.2417.2517.2617.2717.2817.2917.3017.3117.3217.3317.3417.3517.3617.3717.3817.39 17.1 tuple<int,int,int> it(10,20,30) 17.2 …

安全加速SCDN是服务器防御攻击较佳方案

国家互联网应急中心的数据研究显示&#xff0c;基于漏洞、病毒、未知威胁的攻击正日益频繁且智能化&#xff0c;网络安全的防护难度也与日俱增&#xff0c;未来应用层攻击将成为主流。互联网飞速发展之余&#xff0c;对于网络安全的需求也越来越大&#xff0c;网络攻击的手段也…

<商务世界>《第8课 Leads——MQL——SQL——商机——成交》

1 各种概念 英文缩写概念Traffic流量Leads潜在客户&#xff0c;销售线索&#xff1b;简称潜在线索MQLMarketing-Qualified Leads市场认可线索SQLSales-Qualified Leads销售认可线索OPPOpportunity商机Account成单客户 2 线索到商机 一般企业会把自身线索进行如下的划分&…

【电工学笔记】上册第一、二章

电工学 上次考试败在了单位&#xff0c;这次单位 一定要记熟。 第一章 电源或信号源的电压或电流称为激励,它推动电路工作; 由激励所产生的电压和电流称为响应。 复杂电路中,一般无法事先判断某个支路电流的 实际方向或者某个电路元件电压的实际方向 140V/4算不出总电阻的 …

Linux setup命令教程:如何配置系统设置和硬件(附实例详解和注意事项)

Linux setup命令介绍 setup 命令用于配置系统的硬件和软件设置。它允许用户在安装后更改系统设置&#xff0c;例如键盘布局、时区、网络配置等。此命令通常在安装新系统后运行&#xff0c;但也可以在之后随时使用。 Linux setup命令适用的Linux版本 setup 命令在不同的Linux…

数据结构面试常见问题

数据结构面试常见问题 什么是 AVL 树&#xff1f;什么是红黑树&#xff1f;AVL 树和红黑树的区别&#xff1f;B 树和B 树的区别&#xff1f;排序有哪些分类&#xff1f;直接插入排序的原理&#xff1f;希尔排序的原理&#xff1f;直接选择排序的原理&#xff1f;堆排序的原理&a…

vue3的开发小技巧

「总之岁月漫长&#xff0c;然而值得等待。」 目录 父组件调用子组件函数如何访问全局api 父组件调用子组件函数 ref, defineExpose //父组件 代码 <child ref"ch">this.$refs.ch.fn();//子组件 函数抛出 const fn () > { }; defineExpose({ fn });如何…

考研复习C语言初阶(3)

目录 一.函数是什么? 二.C语言中函数的分类 2.1库函数 2.2自定义函数 三.函数的参数 3.1实际参数&#xff08;实参&#xff09; 3.2 形式参数&#xff08;形参&#xff09; 四.函数的调用 4.1 传值调用 4.2 传址调用 五. 函数的嵌套调用和链式访问 5.1 嵌套调用 5…

瑞芯微 | I2S-音频基础分享

1. 音频常用术语 名称含义ADC&#xff08;Analog to Digit Conversion&#xff09;模拟信号转换为数字信号AEC&#xff08;Acoustic Echo Cancellor&#xff09;回声消除AGC&#xff08;Automatic Gain Control&#xff09;自动增益补偿&#xff0c;调整MIC收音量ALSA&#xf…