easyexcel安全扫描报php,easyExcel使用以及踩过的坑

easyExcel介绍:

Java解析、生成Excel比较有名的框架有Apache poi、jxl。但他们都存在一个严重的问题就是非常的耗内存,poi有一套SAX模式的API可以一定程度的解决一些内存溢出的问题,但POI还是有一些缺陷,比如07版Excel解压缩以及解压后存储都是在内存中完成的,内存消耗依然很大。easyexcel重写了poi对07版Excel的解析,能够原本一个3M的excel用POI sax依然需要100M左右内存降低到KB级别,并且再大的excel不会出现内存溢出,03版依赖POI的sax模式。在上层做了模型转换的封装,让使用者更加简单方便

需求分析:

需要实现一个订单导入的功能,用户通过excel将订单导入到我们系统中,(在实际系统中,一个订单可能对应多个运单),此次订单导入不考虑,一个订单只能对应1个运单

实现过程:

步骤1.引入依赖

com.alibaba

easyexcel

1.1.2-beta5

步骤2.添加实体类,如下图

0bbd5aad7bb42ecfa579e2ad8da92ebd.png

该实体类用于接收excel表中的数据,value值对应excel中的表头,index表示excel中列的索引,索引从0开始

必须要继承BaseRowModel类,否则接收不到数据

28b63400b52c3faac58bc753331dc30c.png

需要注意的两个问题:

1.该实体类不支持嵌套实体类,比如 订单中包含运单实体类,只能用一个实体类接收

2.如果是date类型的字段,excel中对应的列,单元格格式要设置为常规,这样javaModel中才能接收到

项目中的导入导出使用了以下工具类ExcelUtil,ExcelListener,ExcelWriterFactroy,ExcelException,大家直接搜索easyExcel工具类都可以搜到,

下面简单介绍一下 excelUtil工具类中用到的该方法

8b8552e23738c786a927b4ff6f962ea0.png

因为需求不是太复杂,读取某个sheet就可以了,插入数据的方式有两种:

1.根据readexcel方法返回的list集合来插入数据

2.调用readExcel方法时,每次读取数据都会调用excelListener中的invoke方法,可以在这里做数据插入或者数据校验等其他操作

e84db38799e72e64a1e8f4ce3c19363f.png

如果数据有误的话,我会把错误信息返回到实体类的failMsg字段中,将该实体类写回去,再将该文件上传到文件服务器,将文件url返回,供用户下载失败的文件

linux服务器环境会遇到一个问题:

java.lang.NullPointerException: null

at sun.awt.FontConfiguration.getVersion(FontConfiguration.java:1264) ~[?:1.8.0_151],

后来在github上找到了解决方案,地址如下

https://github.com/alibaba/easyexcel/issues/157,

需要安装一个字体,安装完就可以了

使用感受:easyexcel封装了很多,感觉导入导出简单的场景非常的好用,不需要关注excel的样式,会有默认样式,其他复杂的场景暂时没遇到过,有兴趣的可以一起讨论下

觉得有用的小伙伴可以帮忙点个赞!

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

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

相关文章

python selenium下载,在python中通过Selenium Webdriver下载文件

在使用新的FirefoxProfile时,使用set_preference方法来配置配置文件,这样就可以单击Save和{},并且在下载过程中不会被中断。您可以按如下方式设置配置:profile webdriver.FirefoxProfile()profile.set_preference("browser.…

用python做人脸识别的程序怎么做,10分钟学会使用python实现人脸识别(附源码)

前言今天,我们用Python实现简单的人脸识别技术!Python里,简单的人脸识别有很多种方法可以实现,依赖于python胶水语言的特性,我们通过调用包可以快速准确的达成这一目的。这里介绍的是准确性比较高的一种。一、首先梳理…

matlab是那个国家,这是一个老外写的利用曲率来识别硬币的MATLAB程序。作者所在国家的硬币偏黄色,拍摄的时候反光比较少...

这是一个老外写的利用曲率来识别硬币的MATLAB程序。作者所在国家的硬币偏黄色,拍摄的时候反光比较少2016-08-22 0 0 0 暂无评分其他1积分下载如何获取积分?这是一个老外写的利用曲率来识别硬币的MATLAB程序。作者所在国家的硬币偏黄色,拍摄的…

oracle中12523,【Oracle】静态监听导致的ORA-12523错误

今天配置完共享服务器模式之后发现登录过程中报错ORA-12523,排查错误之后发现是静态监听惹的祸。本机之上有两个监听,一个静态监今天配置完共享服务器模式之后发现登录过程中报错ORA-12523,排查错误之后发现是静态监听惹的祸。本机之上有两个…

线性回归中oracle性质,66.Oracle数据库SQL开发之 高级查询——使用线性回归函数...

66.Oracle数据库SQL开发之 高级查询——使用线性回归函数线性回归函数可以用普通最小平方回归曲线拟合一组数值对。线性回归函数可用于聚合、串口或报表函数。如下图1:例如:storePDB1> selectprd_type_id,regr_avgx(amount,month) as avgx,regr_avgy(…

angularjs php 实例下载,AngularJS Eclipse 1.2.0 插件下载

【实例简介】AngularJS Eclipse 插件为Eclipse提供对AngularJS的支持【实例截图】【核心代码】org.eclipse.angularjs.category-1.2.0├── artifacts.jar├── content.jar├── features│ ├── angularjs-eclipse-feature.source_1.2.0.201606160950.jar│ ├── …

oracle asm磁盘回收步骤,【翻译自mos文章】回收 asm磁盘空间的方法

回收 asm磁盘空间的方法参考原文:How To Reclaim Asm Disk Space? (Doc ID 351866.1)适用于:Oracle Database - Enterprise Edition - Version 10.2.0.1 and laterInformation in this document applies to any platform.***Checked for relevance on 1…

Oracle 4dae,如何处理Python-CXOracle中未知词的错误报告问题,pythoncxOracle,查询,到,生僻字,报错...

关于编码GBK编码是GB2312编码的超集,向下完全兼容GB2312,同时GBK收录了Unicode基本多文种平面中的所有CJK汉字。GB18030编码向下兼容GBK和GB2312,兼容的含义是不仅字符兼容,而且相同字符的编码也相同。GB18030收录了所有Unicode3.…

impala写入oracle,dataframe 写入 impala 语法错误,怎么解决?

dataframe写入impala出现语法错误,错误:Exception in thread "main" java.sql.SQLException: [Simba]ImpalaJDBCDriver ERROR processing query/statement. Error Code: 0, SQL state: TStatus(statusCode:ERROR_STATUS, sqlState:HY000, erro…

php windows 64下载地址,VSCode Windows 64位 下载

微软推出的免费、功能强大的一款IDE编辑器教程:其它版本推荐:vscode简介:vscode是一个运行于 Mac OS X、Windows和 Linux 之上的,针对于编写现代 Web 和云应用的跨平台源代码编辑器。该编辑器也集成了所有一款现代编辑器所应该具备…

linux 源码目录结构,分析Android 源代码编译前后的目录结构

我们看没有编译前的项目目录大致的情况如下 :在树结构中我们可以了解的有如下一些信息分析:1. getSplashy 项目名称;2. src 项目程式;3. com 早…

linux vps 运行exe文件夹,在centos环境下运行.exe文件

首先要了解一下Wine:Wine (“Wine Is Not an Emulator” 的首字母缩写)是一个能够在多种 POSIX-compliant 操作系统(诸如 Linux,Mac OSX 及 BSD 等)上运行 Windows 应用的兼容层。Wine (Wine Is Not an Emulator)[即Wine不是一个模拟器]是一个在Linux和U…

linux运行时命令找不到,linux - 在运行Bash脚本时找不到命令,但是在直接运行命令时有效 - 堆栈内存溢出...

我一直在使用letencrypt为我的网站生成SSL证书,更具体地说是letencrypt_webfaction。 当我在项目中运行此命令时,它可以工作letsencrypt_webfaction --letsencrypt_account_email --domains --public --username --password 但是,当我在bash脚…

linux iconv命令详解,iconv命令

iconv命令:Convert encoding of given files from one encoding to another,更改文件的编码格式语法格式:iconv -f encoding -t encoding inputfile常用选项:-f encoding :把字符从encoding编码开始转换-t encoding :把字符转换到…

linux服务器u盘启动项检测不到,将U盘设置为第一启动项之后却检测不到U盘怎么办?...

对于如何使用U盘装系统,想必看过小编之前介绍的朋友应该大致都清楚了吧?虽然说咱们使用U盘装系统的操作步骤还是比较简单的,但是却必须要满足一个条件,那便是将咱们的U盘设置为第一启动项,那么如何进行设置呢?这便需要在咱们win…

linux内核io源码,Linux Kernel do_io_submit()函数整数溢出漏洞

发布日期:2010-09-21更新日期:2010-09-27受影响系统:Linux kernel 2.6.x不受影响系统:Linux kernel 2.6.36-rc4描述:--------------------------------------------------------------------------------BUGTRAQ ID: …

linux6无法启动iscsi服务,RHEL6下安装配置ISCSI服务器

1.安装所需软件:yum –y install scsi-target-utils iscsi-initiator-utils功能说明:scsi-target-utils:用来将 Linux 系统仿真成为 iSCSI target 的功能;iscsi-initiator-utils:挂载来自 target 的磁盘到 Linux 本机上。2.target的设定:----…

linux查看r的安装路径,在Linux CentOS 6.5版上安装R3.1.1的问题(检查LDFLAGS以获取Fortran库的路径)...

我正在尝试从CentOS 6.5上安装R3.1.1..configure引发以下错误(...)checking whether we can compute C Make dependencies... yes,using $(CC) -MMchecking whether gcc -stdgnu99 supports -c -o FILE.lo... yeschecking for gcc -stdgnu99 option to support OpenMP... -fope…

linux weblogic 内存溢出,weblogic 安装升级补丁出现内存溢出问题解决

执行weblogic升级命令时,出现内存溢出问题:d:\Oracle\Middleware\utils\bsu>bsu.cmd -install -patch_download_dird:\Oracle\Middleware\utils\bsu\cache_dir -patchlistFMJJ -prod_dird:\Oracle\Middleware\wlserver_10.3Exception in thread "main"…

linux脚本vrrp_script,keepalived 的 vrrp_script

[rootcentos01 keepalived]# cat check_httpd.sh 脚本需要有执行权限 通常情况下,利用keepalived做热备,其中一台设置为master,一台设置为backup。当master出现异常后,backup自动切换为master。当backup成为master后,m…