commit
						9b2a897759
					
				 758 changed files with 2912194 additions and 0 deletions
			
			
		@ -0,0 +1,58 @@ | 
				
			|||
# Built application files and Maven | 
				
			|||
target/ | 
				
			|||
pom.xml.tag | 
				
			|||
pom.xml.releaseBackup | 
				
			|||
pom.xml.versionsBackup | 
				
			|||
pom.xml.next | 
				
			|||
release.properties | 
				
			|||
dependency-reduced-pom.xml | 
				
			|||
buildNumber.properties | 
				
			|||
.mvn/timing.properties | 
				
			|||
  | 
				
			|||
# Compiled class files | 
				
			|||
*.class | 
				
			|||
  | 
				
			|||
# Log Files | 
				
			|||
*.log | 
				
			|||
  | 
				
			|||
# About IntelliJ | 
				
			|||
*.iml | 
				
			|||
/.idea/ | 
				
			|||
/out/ | 
				
			|||
  | 
				
			|||
# BlueJ files | 
				
			|||
*.ctxt | 
				
			|||
  | 
				
			|||
# Mobile Tools for Java (J2ME) | 
				
			|||
.mtj.tmp/ | 
				
			|||
  | 
				
			|||
# macOS | 
				
			|||
.DS_Store | 
				
			|||
  | 
				
			|||
# Package Files | 
				
			|||
*.jar | 
				
			|||
*.war | 
				
			|||
*.ear | 
				
			|||
*.tar.gz | 
				
			|||
*.rar | 
				
			|||
  | 
				
			|||
# CMake | 
				
			|||
cmake-build-debug/ | 
				
			|||
  | 
				
			|||
# File-based project format | 
				
			|||
*.iws | 
				
			|||
  | 
				
			|||
# mpeltonen/sbt-idea plugin | 
				
			|||
.idea_modules/ | 
				
			|||
  | 
				
			|||
# JIRA plugin | 
				
			|||
atlassian-ide-plugin.xml | 
				
			|||
  | 
				
			|||
# Crashlytics plugin (for Android Studio and IntelliJ) | 
				
			|||
com_crashlytics_export_strings.xml | 
				
			|||
crashlytics.properties | 
				
			|||
crashlytics-build.properties | 
				
			|||
fabric.properties | 
				
			|||
  | 
				
			|||
# virtual machine crash logs, see http://www.java.com/en/download/help/error_hotspot.xml | 
				
			|||
hs_err_pid* | 
				
			|||
@ -0,0 +1,191 @@ | 
				
			|||
Apache License | 
				
			|||
Version 2.0, January 2004 | 
				
			|||
http://www.apache.org/licenses/ | 
				
			|||
 | 
				
			|||
TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION | 
				
			|||
 | 
				
			|||
1. Definitions. | 
				
			|||
 | 
				
			|||
"License" shall mean the terms and conditions for use, reproduction, and | 
				
			|||
distribution as defined by Sections 1 through 9 of this document. | 
				
			|||
 | 
				
			|||
"Licensor" shall mean the copyright owner or entity authorized by the copyright | 
				
			|||
owner that is granting the License. | 
				
			|||
 | 
				
			|||
"Legal Entity" shall mean the union of the acting entity and all other entities | 
				
			|||
that control, are controlled by, or are under common control with that entity. | 
				
			|||
For the purposes of this definition, "control" means (i) the power, direct or | 
				
			|||
indirect, to cause the direction or management of such entity, whether by | 
				
			|||
contract or otherwise, or (ii) ownership of fifty percent (50%) or more of the | 
				
			|||
outstanding shares, or (iii) beneficial ownership of such entity. | 
				
			|||
 | 
				
			|||
"You" (or "Your") shall mean an individual or Legal Entity exercising | 
				
			|||
permissions granted by this License. | 
				
			|||
 | 
				
			|||
"Source" form shall mean the preferred form for making modifications, including | 
				
			|||
but not limited to software source code, documentation source, and configuration | 
				
			|||
files. | 
				
			|||
 | 
				
			|||
"Object" form shall mean any form resulting from mechanical transformation or | 
				
			|||
translation of a Source form, including but not limited to compiled object code, | 
				
			|||
generated documentation, and conversions to other media types. | 
				
			|||
 | 
				
			|||
"Work" shall mean the work of authorship, whether in Source or Object form, made | 
				
			|||
available under the License, as indicated by a copyright notice that is included | 
				
			|||
in or attached to the work (an example is provided in the Appendix below). | 
				
			|||
 | 
				
			|||
"Derivative Works" shall mean any work, whether in Source or Object form, that | 
				
			|||
is based on (or derived from) the Work and for which the editorial revisions, | 
				
			|||
annotations, elaborations, or other modifications represent, as a whole, an | 
				
			|||
original work of authorship. For the purposes of this License, Derivative Works | 
				
			|||
shall not include works that remain separable from, or merely link (or bind by | 
				
			|||
name) to the interfaces of, the Work and Derivative Works thereof. | 
				
			|||
 | 
				
			|||
"Contribution" shall mean any work of authorship, including the original version | 
				
			|||
of the Work and any modifications or additions to that Work or Derivative Works | 
				
			|||
thereof, that is intentionally submitted to Licensor for inclusion in the Work | 
				
			|||
by the copyright owner or by an individual or Legal Entity authorized to submit | 
				
			|||
on behalf of the copyright owner. For the purposes of this definition, | 
				
			|||
"submitted" means any form of electronic, verbal, or written communication sent | 
				
			|||
to the Licensor or its representatives, including but not limited to | 
				
			|||
communication on electronic mailing lists, source code control systems, and | 
				
			|||
issue tracking systems that are managed by, or on behalf of, the Licensor for | 
				
			|||
the purpose of discussing and improving the Work, but excluding communication | 
				
			|||
that is conspicuously marked or otherwise designated in writing by the copyright | 
				
			|||
owner as "Not a Contribution." | 
				
			|||
 | 
				
			|||
"Contributor" shall mean Licensor and any individual or Legal Entity on behalf | 
				
			|||
of whom a Contribution has been received by Licensor and subsequently | 
				
			|||
incorporated within the Work. | 
				
			|||
 | 
				
			|||
2. Grant of Copyright License. | 
				
			|||
 | 
				
			|||
Subject to the terms and conditions of this License, each Contributor hereby | 
				
			|||
grants to You a perpetual, worldwide, non-exclusive, no-charge, royalty-free, | 
				
			|||
irrevocable copyright license to reproduce, prepare Derivative Works of, | 
				
			|||
publicly display, publicly perform, sublicense, and distribute the Work and such | 
				
			|||
Derivative Works in Source or Object form. | 
				
			|||
 | 
				
			|||
3. Grant of Patent License. | 
				
			|||
 | 
				
			|||
Subject to the terms and conditions of this License, each Contributor hereby | 
				
			|||
grants to You a perpetual, worldwide, non-exclusive, no-charge, royalty-free, | 
				
			|||
irrevocable (except as stated in this section) patent license to make, have | 
				
			|||
made, use, offer to sell, sell, import, and otherwise transfer the Work, where | 
				
			|||
such license applies only to those patent claims licensable by such Contributor | 
				
			|||
that are necessarily infringed by their Contribution(s) alone or by combination | 
				
			|||
of their Contribution(s) with the Work to which such Contribution(s) was | 
				
			|||
submitted. If You institute patent litigation against any entity (including a | 
				
			|||
cross-claim or counterclaim in a lawsuit) alleging that the Work or a | 
				
			|||
Contribution incorporated within the Work constitutes direct or contributory | 
				
			|||
patent infringement, then any patent licenses granted to You under this License | 
				
			|||
for that Work shall terminate as of the date such litigation is filed. | 
				
			|||
 | 
				
			|||
4. Redistribution. | 
				
			|||
 | 
				
			|||
You may reproduce and distribute copies of the Work or Derivative Works thereof | 
				
			|||
in any medium, with or without modifications, and in Source or Object form, | 
				
			|||
provided that You meet the following conditions: | 
				
			|||
 | 
				
			|||
You must give any other recipients of the Work or Derivative Works a copy of | 
				
			|||
this License; and | 
				
			|||
You must cause any modified files to carry prominent notices stating that You | 
				
			|||
changed the files; and | 
				
			|||
You must retain, in the Source form of any Derivative Works that You distribute, | 
				
			|||
all copyright, patent, trademark, and attribution notices from the Source form | 
				
			|||
of the Work, excluding those notices that do not pertain to any part of the | 
				
			|||
Derivative Works; and | 
				
			|||
If the Work includes a "NOTICE" text file as part of its distribution, then any | 
				
			|||
Derivative Works that You distribute must include a readable copy of the | 
				
			|||
attribution notices contained within such NOTICE file, excluding those notices | 
				
			|||
that do not pertain to any part of the Derivative Works, in at least one of the | 
				
			|||
following places: within a NOTICE text file distributed as part of the | 
				
			|||
Derivative Works; within the Source form or documentation, if provided along | 
				
			|||
with the Derivative Works; or, within a display generated by the Derivative | 
				
			|||
Works, if and wherever such third-party notices normally appear. The contents of | 
				
			|||
the NOTICE file are for informational purposes only and do not modify the | 
				
			|||
License. You may add Your own attribution notices within Derivative Works that | 
				
			|||
You distribute, alongside or as an addendum to the NOTICE text from the Work, | 
				
			|||
provided that such additional attribution notices cannot be construed as | 
				
			|||
modifying the License. | 
				
			|||
You may add Your own copyright statement to Your modifications and may provide | 
				
			|||
additional or different license terms and conditions for use, reproduction, or | 
				
			|||
distribution of Your modifications, or for any such Derivative Works as a whole, | 
				
			|||
provided Your use, reproduction, and distribution of the Work otherwise complies | 
				
			|||
with the conditions stated in this License. | 
				
			|||
 | 
				
			|||
5. Submission of Contributions. | 
				
			|||
 | 
				
			|||
Unless You explicitly state otherwise, any Contribution intentionally submitted | 
				
			|||
for inclusion in the Work by You to the Licensor shall be under the terms and | 
				
			|||
conditions of this License, without any additional terms or conditions. | 
				
			|||
Notwithstanding the above, nothing herein shall supersede or modify the terms of | 
				
			|||
any separate license agreement you may have executed with Licensor regarding | 
				
			|||
such Contributions. | 
				
			|||
 | 
				
			|||
6. Trademarks. | 
				
			|||
 | 
				
			|||
This License does not grant permission to use the trade names, trademarks, | 
				
			|||
service marks, or product names of the Licensor, except as required for | 
				
			|||
reasonable and customary use in describing the origin of the Work and | 
				
			|||
reproducing the content of the NOTICE file. | 
				
			|||
 | 
				
			|||
7. Disclaimer of Warranty. | 
				
			|||
 | 
				
			|||
Unless required by applicable law or agreed to in writing, Licensor provides the | 
				
			|||
Work (and each Contributor provides its Contributions) on an "AS IS" BASIS, | 
				
			|||
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied, | 
				
			|||
including, without limitation, any warranties or conditions of TITLE, | 
				
			|||
NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A PARTICULAR PURPOSE. You are | 
				
			|||
solely responsible for determining the appropriateness of using or | 
				
			|||
redistributing the Work and assume any risks associated with Your exercise of | 
				
			|||
permissions under this License. | 
				
			|||
 | 
				
			|||
8. Limitation of Liability. | 
				
			|||
 | 
				
			|||
In no event and under no legal theory, whether in tort (including negligence), | 
				
			|||
contract, or otherwise, unless required by applicable law (such as deliberate | 
				
			|||
and grossly negligent acts) or agreed to in writing, shall any Contributor be | 
				
			|||
liable to You for damages, including any direct, indirect, special, incidental, | 
				
			|||
or consequential damages of any character arising as a result of this License or | 
				
			|||
out of the use or inability to use the Work (including but not limited to | 
				
			|||
damages for loss of goodwill, work stoppage, computer failure or malfunction, or | 
				
			|||
any and all other commercial damages or losses), even if such Contributor has | 
				
			|||
been advised of the possibility of such damages. | 
				
			|||
 | 
				
			|||
9. Accepting Warranty or Additional Liability. | 
				
			|||
 | 
				
			|||
While redistributing the Work or Derivative Works thereof, You may choose to | 
				
			|||
offer, and charge a fee for, acceptance of support, warranty, indemnity, or | 
				
			|||
other liability obligations and/or rights consistent with this License. However, | 
				
			|||
in accepting such obligations, You may act only on Your own behalf and on Your | 
				
			|||
sole responsibility, not on behalf of any other Contributor, and only if You | 
				
			|||
agree to indemnify, defend, and hold each Contributor harmless for any liability | 
				
			|||
incurred by, or claims asserted against, such Contributor by reason of your | 
				
			|||
accepting any such warranty or additional liability. | 
				
			|||
 | 
				
			|||
END OF TERMS AND CONDITIONS | 
				
			|||
 | 
				
			|||
APPENDIX: How to apply the Apache License to your work | 
				
			|||
 | 
				
			|||
To apply the Apache License to your work, attach the following boilerplate | 
				
			|||
notice, with the fields enclosed by brackets "{}" replaced with your own | 
				
			|||
identifying information. (Don't include the brackets!) The text should be | 
				
			|||
enclosed in the appropriate comment syntax for the file format. We also | 
				
			|||
recommend that a file or class name and description of purpose be included on | 
				
			|||
the same "printed page" as the copyright notice for easier identification within | 
				
			|||
third-party archives. | 
				
			|||
 | 
				
			|||
   Copyright 2019-2020 Zheng Jie | 
				
			|||
 | 
				
			|||
   Licensed under the Apache License, Version 2.0 (the "License"); | 
				
			|||
   you may not use this file except in compliance with the License. | 
				
			|||
   You may obtain a copy of the License at | 
				
			|||
 | 
				
			|||
     http://www.apache.org/licenses/LICENSE-2.0 | 
				
			|||
 | 
				
			|||
   Unless required by applicable law or agreed to in writing, software | 
				
			|||
   distributed under the License is distributed on an "AS IS" BASIS, | 
				
			|||
   WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | 
				
			|||
   See the License for the specific language governing permissions and | 
				
			|||
   limitations under the License. | 
				
			|||
@ -0,0 +1,85 @@ | 
				
			|||
 | 
				
			|||
###主要特性 | 
				
			|||
- 高效率开发,代码生成器可一键生成前后端代码 | 
				
			|||
- 支持数据字典,可方便地对一些状态进行管理 | 
				
			|||
- 支持接口级别的功能权限与数据权限,可自定义操作 | 
				
			|||
- 自定义权限注解与匿名接口注解,可快速对接口拦截与放行 | 
				
			|||
- 前后端统一异常拦截处理,统一输出异常,避免繁琐的判断 | 
				
			|||
 | 
				
			|||
### 系统功能 | 
				
			|||
- 用户管理:提供用户的相关配置 | 
				
			|||
- 角色管理:对权限与菜单进行分配 | 
				
			|||
- 菜单管理:已实现菜单动态路由 | 
				
			|||
- 职位管理:配置各个部门的职位 | 
				
			|||
- 字典管理:可维护常用一些固定的数据,如:状态,性别等 | 
				
			|||
- 系统日志:记录用户操作日志与异常日志,方便开发人员定位排错 | 
				
			|||
- 定时任务:整合Quartz做定时任务,加入任务日志,任务运行情况一目了然 | 
				
			|||
- 代码生成:高灵活度生成前后端代码,减少大量重复的工作任务 | 
				
			|||
 | 
				
			|||
### 项目结构 | 
				
			|||
项目采用按功能分模块的开发方式,结构如下 | 
				
			|||
 | 
				
			|||
- `auto-poi` 提供Excel导入导出服务 | 
				
			|||
 | 
				
			|||
- `base-common` 提供常用基础类抽象与封装 | 
				
			|||
 | 
				
			|||
- `module-system` 核心业务代码 | 
				
			|||
 | 
				
			|||
### 部署 | 
				
			|||
#### 1. 编写启动配置文件 | 
				
			|||
CentOS 7 主服务器配置文件: /home/monitor/gas-monitor.service | 
				
			|||
``` | 
				
			|||
[Unit] | 
				
			|||
Description=Gas Monitor | 
				
			|||
After=network.target | 
				
			|||
 | 
				
			|||
[Service] | 
				
			|||
User=root | 
				
			|||
Group=root | 
				
			|||
WorkingDirectory=/home/monitor | 
				
			|||
ExecStart=/usr/bin/java -jar /home/monitor/monitor.jar --spring.profiles.active=prod | 
				
			|||
Restart=always | 
				
			|||
 | 
				
			|||
[Install] | 
				
			|||
WantedBy=multi-user.target | 
				
			|||
``` | 
				
			|||
 | 
				
			|||
CentOS 7 备用服务器配置文件: /home/monitor/gas-monitor.service | 
				
			|||
``` | 
				
			|||
[Unit] | 
				
			|||
Description=Gas Monitor | 
				
			|||
After=network.target | 
				
			|||
 | 
				
			|||
[Service] | 
				
			|||
User=root | 
				
			|||
Group=root | 
				
			|||
WorkingDirectory=/home/monitor | 
				
			|||
ExecStart=/usr/bin/java -jar /home/monitor/monitor.jar --spring.profiles.active=prodb | 
				
			|||
Restart=always | 
				
			|||
 | 
				
			|||
[Install] | 
				
			|||
WantedBy=multi-user.target | 
				
			|||
``` | 
				
			|||
 | 
				
			|||
#### 2. 配置开机自启动 | 
				
			|||
``` | 
				
			|||
sudo systemctl enable /home/monitor/gas-monitor.service | 
				
			|||
``` | 
				
			|||
 | 
				
			|||
#### 3. 启动服务器 | 
				
			|||
``` | 
				
			|||
sudo systemctl start gas-monitor | 
				
			|||
``` | 
				
			|||
 | 
				
			|||
#### 4. 其它常用命令 | 
				
			|||
``` | 
				
			|||
# 重启 | 
				
			|||
sudo systemctl restart gas-monitor | 
				
			|||
 | 
				
			|||
# 停止服务 | 
				
			|||
sudo systemctl stop gas-monitor | 
				
			|||
 | 
				
			|||
# 查看服务状态 | 
				
			|||
sudo systemctl status gas-monitor | 
				
			|||
``` | 
				
			|||
 | 
				
			|||
@ -0,0 +1,59 @@ | 
				
			|||
# Built application files and Maven | 
				
			|||
target/ | 
				
			|||
pom.xml.tag | 
				
			|||
pom.xml.releaseBackup | 
				
			|||
pom.xml.versionsBackup | 
				
			|||
pom.xml.next | 
				
			|||
release.properties | 
				
			|||
dependency-reduced-pom.xml | 
				
			|||
buildNumber.properties | 
				
			|||
.mvn/timing.properties | 
				
			|||
  | 
				
			|||
# Compiled class files | 
				
			|||
*.class | 
				
			|||
  | 
				
			|||
# Log Files | 
				
			|||
*.log | 
				
			|||
  | 
				
			|||
# About IntelliJ | 
				
			|||
*.iml | 
				
			|||
/.idea/ | 
				
			|||
/out/ | 
				
			|||
  | 
				
			|||
# BlueJ files | 
				
			|||
*.ctxt | 
				
			|||
  | 
				
			|||
# Mobile Tools for Java (J2ME) | 
				
			|||
.mtj.tmp/ | 
				
			|||
  | 
				
			|||
# macOS | 
				
			|||
.DS_Store | 
				
			|||
  | 
				
			|||
# Package Files | 
				
			|||
*.jar | 
				
			|||
*.war | 
				
			|||
*.ear | 
				
			|||
*.zip | 
				
			|||
*.tar.gz | 
				
			|||
*.rar | 
				
			|||
  | 
				
			|||
# CMake | 
				
			|||
cmake-build-debug/ | 
				
			|||
  | 
				
			|||
# File-based project format | 
				
			|||
*.iws | 
				
			|||
  | 
				
			|||
# mpeltonen/sbt-idea plugin | 
				
			|||
.idea_modules/ | 
				
			|||
  | 
				
			|||
# JIRA plugin | 
				
			|||
atlassian-ide-plugin.xml | 
				
			|||
  | 
				
			|||
# Crashlytics plugin (for Android Studio and IntelliJ) | 
				
			|||
com_crashlytics_export_strings.xml | 
				
			|||
crashlytics.properties | 
				
			|||
crashlytics-build.properties | 
				
			|||
fabric.properties | 
				
			|||
  | 
				
			|||
# virtual machine crash logs, see http://www.java.com/en/download/help/error_hotspot.xml | 
				
			|||
hs_err_pid* | 
				
			|||
@ -0,0 +1,92 @@ | 
				
			|||
<?xml version="1.0" encoding="UTF-8"?> | 
				
			|||
 | 
				
			|||
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" | 
				
			|||
		 xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"> | 
				
			|||
	<parent> | 
				
			|||
		<artifactId>cc-admin-api</artifactId> | 
				
			|||
		<groupId>cc.admin</groupId> | 
				
			|||
		<version>1.0.0</version> | 
				
			|||
	</parent> | 
				
			|||
	<modelVersion>4.0.0</modelVersion> | 
				
			|||
 | 
				
			|||
	<artifactId>auto-poi</artifactId> | 
				
			|||
	<version>1.0.0</version> | 
				
			|||
 | 
				
			|||
	<name>auto-poi</name> | 
				
			|||
 | 
				
			|||
	<properties> | 
				
			|||
		<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding> | 
				
			|||
		<maven.compiler.source>1.8</maven.compiler.source> | 
				
			|||
		<maven.compiler.target>1.8</maven.compiler.target> | 
				
			|||
	</properties> | 
				
			|||
 | 
				
			|||
	<dependencies> | 
				
			|||
		<dependency> | 
				
			|||
			<groupId>junit</groupId> | 
				
			|||
			<artifactId>junit</artifactId> | 
				
			|||
			<version>4.13.1</version> | 
				
			|||
			<scope>test</scope> | 
				
			|||
		</dependency> | 
				
			|||
		<dependency> | 
				
			|||
			<groupId>org.apache.poi</groupId> | 
				
			|||
			<artifactId>poi</artifactId> | 
				
			|||
			<version>4.1.2</version> | 
				
			|||
		</dependency> | 
				
			|||
		<dependency> | 
				
			|||
			<groupId>org.apache.poi</groupId> | 
				
			|||
			<artifactId>poi-ooxml</artifactId> | 
				
			|||
			<version>4.1.2</version> | 
				
			|||
		</dependency> | 
				
			|||
		<dependency> | 
				
			|||
			<groupId>org.apache.commons</groupId> | 
				
			|||
			<artifactId>commons-lang3</artifactId> | 
				
			|||
			<version>3.4</version> | 
				
			|||
		</dependency> | 
				
			|||
	</dependencies> | 
				
			|||
 | 
				
			|||
	<build> | 
				
			|||
		<pluginManagement><!-- lock down plugins versions to avoid using Maven defaults (may be moved to parent pom) --> | 
				
			|||
			<plugins> | 
				
			|||
				<!-- clean lifecycle, see https://maven.apache.org/ref/current/maven-core/lifecycles.html#clean_Lifecycle --> | 
				
			|||
				<plugin> | 
				
			|||
					<artifactId>maven-clean-plugin</artifactId> | 
				
			|||
					<version>3.1.0</version> | 
				
			|||
				</plugin> | 
				
			|||
				<!-- default lifecycle, jar packaging: see https://maven.apache.org/ref/current/maven-core/default-bindings.html#Plugin_bindings_for_jar_packaging --> | 
				
			|||
				<plugin> | 
				
			|||
					<artifactId>maven-resources-plugin</artifactId> | 
				
			|||
					<version>3.0.2</version> | 
				
			|||
				</plugin> | 
				
			|||
				<plugin> | 
				
			|||
					<artifactId>maven-compiler-plugin</artifactId> | 
				
			|||
					<version>3.8.0</version> | 
				
			|||
				</plugin> | 
				
			|||
				<plugin> | 
				
			|||
					<artifactId>maven-surefire-plugin</artifactId> | 
				
			|||
					<version>2.22.1</version> | 
				
			|||
				</plugin> | 
				
			|||
				<plugin> | 
				
			|||
					<artifactId>maven-jar-plugin</artifactId> | 
				
			|||
					<version>3.0.2</version> | 
				
			|||
				</plugin> | 
				
			|||
				<plugin> | 
				
			|||
					<artifactId>maven-install-plugin</artifactId> | 
				
			|||
					<version>2.5.2</version> | 
				
			|||
				</plugin> | 
				
			|||
				<plugin> | 
				
			|||
					<artifactId>maven-deploy-plugin</artifactId> | 
				
			|||
					<version>2.8.2</version> | 
				
			|||
				</plugin> | 
				
			|||
				<!-- site lifecycle, see https://maven.apache.org/ref/current/maven-core/lifecycles.html#site_Lifecycle --> | 
				
			|||
				<plugin> | 
				
			|||
					<artifactId>maven-site-plugin</artifactId> | 
				
			|||
					<version>3.7.1</version> | 
				
			|||
				</plugin> | 
				
			|||
				<plugin> | 
				
			|||
					<artifactId>maven-project-info-reports-plugin</artifactId> | 
				
			|||
					<version>3.0.0</version> | 
				
			|||
				</plugin> | 
				
			|||
			</plugins> | 
				
			|||
		</pluginManagement> | 
				
			|||
	</build> | 
				
			|||
</project> | 
				
			|||
@ -0,0 +1,25 @@ | 
				
			|||
package cc.admin.core.util; | 
				
			|||
 | 
				
			|||
import org.springframework.beans.BeansException; | 
				
			|||
import org.springframework.context.ApplicationContext; | 
				
			|||
import org.springframework.context.ApplicationContextAware; | 
				
			|||
 | 
				
			|||
/** | 
				
			|||
 * | 
				
			|||
 * @author  张代浩 | 
				
			|||
 * | 
				
			|||
 */ | 
				
			|||
public class ApplicationContextUtil implements ApplicationContextAware { | 
				
			|||
 | 
				
			|||
	private static ApplicationContext context; | 
				
			|||
 | 
				
			|||
 | 
				
			|||
	public void setApplicationContext(ApplicationContext context) | 
				
			|||
			throws BeansException { | 
				
			|||
		this.context = context; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public static ApplicationContext getContext() { | 
				
			|||
		return context; | 
				
			|||
	} | 
				
			|||
} | 
				
			|||
@ -0,0 +1,23 @@ | 
				
			|||
package cc.admin.dict.service; | 
				
			|||
 | 
				
			|||
 | 
				
			|||
/** | 
				
			|||
 * 描述: | 
				
			|||
 * @author:scott | 
				
			|||
 * @since:2017-4-12 下午04:58:15 | 
				
			|||
 * @version:1.0 | 
				
			|||
 */ | 
				
			|||
public interface AutoPoiDictServiceI{ | 
				
			|||
	/** | 
				
			|||
 	 * 方法描述:  查询数据字典 | 
				
			|||
 	 * 作    者: yiming.zhang | 
				
			|||
 	 * 日    期: 2014年5月11日-下午4:22:42 | 
				
			|||
 	 * @param dicTable | 
				
			|||
 	 * @param dicCode | 
				
			|||
 	 * @param dicText | 
				
			|||
 	 * @return | 
				
			|||
 	 * 返回类型: List<DictEntity> | 
				
			|||
 	 */ | 
				
			|||
 	public String[] queryDict(String dicTable, String dicCode, String dicText); | 
				
			|||
 | 
				
			|||
} | 
				
			|||
@ -0,0 +1,67 @@ | 
				
			|||
/** | 
				
			|||
 * Copyright 2013-2015 JEECG (jeecgos@163.com) | 
				
			|||
 * | 
				
			|||
 *  Licensed under the Apache License, Version 2.0 (the "License"); | 
				
			|||
 *  you may not use this file except in compliance with the License. | 
				
			|||
 *  You may obtain a copy of the License at | 
				
			|||
 * | 
				
			|||
 *     http://www.apache.org/licenses/LICENSE-2.0
 | 
				
			|||
 * | 
				
			|||
 *  Unless required by applicable law or agreed to in writing, software | 
				
			|||
 * distributed under the License is distributed on an "AS IS" BASIS, | 
				
			|||
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | 
				
			|||
 * See the License for the specific language governing permissions and | 
				
			|||
 * limitations under the License. | 
				
			|||
 */ | 
				
			|||
package cc.admin.poi.cache; | 
				
			|||
 | 
				
			|||
import java.io.InputStream; | 
				
			|||
import java.util.Arrays; | 
				
			|||
import java.util.List; | 
				
			|||
 | 
				
			|||
import org.apache.poi.openxml4j.exceptions.InvalidFormatException; | 
				
			|||
import org.apache.poi.ss.usermodel.Workbook; | 
				
			|||
import org.apache.poi.ss.usermodel.WorkbookFactory; | 
				
			|||
import cc.admin.poi.cache.manager.POICacheManager; | 
				
			|||
import org.slf4j.Logger; | 
				
			|||
import org.slf4j.LoggerFactory; | 
				
			|||
 | 
				
			|||
/** | 
				
			|||
 * Excel类型的缓存 | 
				
			|||
 * | 
				
			|||
 * @author JEECG | 
				
			|||
 * @date 2014年2月11日 | 
				
			|||
 * @version 1.0 | 
				
			|||
 */ | 
				
			|||
public final class ExcelCache { | 
				
			|||
 | 
				
			|||
	private static final Logger LOGGER = LoggerFactory.getLogger(ExcelCache.class); | 
				
			|||
 | 
				
			|||
	public static Workbook getWorkbook(String url, Integer[] sheetNums, boolean needAll) { | 
				
			|||
		InputStream is = null; | 
				
			|||
		List<Integer> sheetList = Arrays.asList(sheetNums); | 
				
			|||
		try { | 
				
			|||
			is = POICacheManager.getFile(url); | 
				
			|||
			Workbook wb = WorkbookFactory.create(is); | 
				
			|||
			// 删除其他的sheet
 | 
				
			|||
			if (!needAll) { | 
				
			|||
				for (int i = wb.getNumberOfSheets() - 1; i >= 0; i--) { | 
				
			|||
					if (!sheetList.contains(i)) { | 
				
			|||
						wb.removeSheetAt(i); | 
				
			|||
					} | 
				
			|||
				} | 
				
			|||
			} | 
				
			|||
			return wb; | 
				
			|||
		}  catch (Exception e) { | 
				
			|||
			LOGGER.error(e.getMessage(), e); | 
				
			|||
		} finally { | 
				
			|||
			try { | 
				
			|||
				is.close(); | 
				
			|||
			} catch (Exception e) { | 
				
			|||
				LOGGER.error(e.getMessage(), e); | 
				
			|||
			} | 
				
			|||
		} | 
				
			|||
		return null; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
} | 
				
			|||
@ -0,0 +1,53 @@ | 
				
			|||
/** | 
				
			|||
 * Copyright 2013-2015 JEECG (jeecgos@163.com) | 
				
			|||
 * | 
				
			|||
 *  Licensed under the Apache License, Version 2.0 (the "License"); | 
				
			|||
 *  you may not use this file except in compliance with the License. | 
				
			|||
 *  You may obtain a copy of the License at | 
				
			|||
 * | 
				
			|||
 *     http://www.apache.org/licenses/LICENSE-2.0
 | 
				
			|||
 * | 
				
			|||
 *  Unless required by applicable law or agreed to in writing, software | 
				
			|||
 * distributed under the License is distributed on an "AS IS" BASIS, | 
				
			|||
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | 
				
			|||
 * See the License for the specific language governing permissions and | 
				
			|||
 * limitations under the License. | 
				
			|||
 */ | 
				
			|||
package cc.admin.poi.cache; | 
				
			|||
 | 
				
			|||
import java.io.InputStream; | 
				
			|||
 | 
				
			|||
import cc.admin.poi.cache.manager.POICacheManager; | 
				
			|||
import cc.admin.poi.word.entity.MyXWPFDocument; | 
				
			|||
import org.slf4j.Logger; | 
				
			|||
import org.slf4j.LoggerFactory; | 
				
			|||
 | 
				
			|||
/** | 
				
			|||
 * word 缓存中心 | 
				
			|||
 * | 
				
			|||
 * @author JEECG | 
				
			|||
 * @date 2014年7月24日 下午10:54:31 | 
				
			|||
 */ | 
				
			|||
public class WordCache { | 
				
			|||
 | 
				
			|||
	private static final Logger LOGGER = LoggerFactory.getLogger(WordCache.class); | 
				
			|||
 | 
				
			|||
	public static MyXWPFDocument getXWPFDocumen(String url) { | 
				
			|||
		InputStream is = null; | 
				
			|||
		try { | 
				
			|||
			is = POICacheManager.getFile(url); | 
				
			|||
			MyXWPFDocument doc = new MyXWPFDocument(is); | 
				
			|||
			return doc; | 
				
			|||
		} catch (Exception e) { | 
				
			|||
			LOGGER.error(e.getMessage(), e); | 
				
			|||
		} finally { | 
				
			|||
			try { | 
				
			|||
				is.close(); | 
				
			|||
			} catch (Exception e) { | 
				
			|||
				LOGGER.error(e.getMessage(), e); | 
				
			|||
			} | 
				
			|||
		} | 
				
			|||
		return null; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
} | 
				
			|||
@ -0,0 +1,75 @@ | 
				
			|||
/** | 
				
			|||
 * Copyright 2013-2015 JEECG (jeecgos@163.com) | 
				
			|||
 * | 
				
			|||
 *  Licensed under the Apache License, Version 2.0 (the "License"); | 
				
			|||
 *  you may not use this file except in compliance with the License. | 
				
			|||
 *  You may obtain a copy of the License at | 
				
			|||
 * | 
				
			|||
 *     http://www.apache.org/licenses/LICENSE-2.0
 | 
				
			|||
 * | 
				
			|||
 *  Unless required by applicable law or agreed to in writing, software | 
				
			|||
 * distributed under the License is distributed on an "AS IS" BASIS, | 
				
			|||
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | 
				
			|||
 * See the License for the specific language governing permissions and | 
				
			|||
 * limitations under the License. | 
				
			|||
 */ | 
				
			|||
package cc.admin.poi.cache.manager; | 
				
			|||
 | 
				
			|||
import java.io.ByteArrayOutputStream; | 
				
			|||
import java.io.FileInputStream; | 
				
			|||
import java.io.FileNotFoundException; | 
				
			|||
import java.io.IOException; | 
				
			|||
 | 
				
			|||
import cc.admin.poi.util.PoiPublicUtil; | 
				
			|||
import org.slf4j.Logger; | 
				
			|||
import org.slf4j.LoggerFactory; | 
				
			|||
 | 
				
			|||
/** | 
				
			|||
 * 文件加载类,根据路径加载指定文件 | 
				
			|||
 * | 
				
			|||
 * @author JEECG | 
				
			|||
 * @date 2014年2月10日 | 
				
			|||
 * @version 1.0 | 
				
			|||
 */ | 
				
			|||
class FileLoade { | 
				
			|||
 | 
				
			|||
	private static final Logger LOGGER = LoggerFactory.getLogger(FileLoade.class); | 
				
			|||
 | 
				
			|||
	public byte[] getFile(String url) { | 
				
			|||
		FileInputStream fileis = null; | 
				
			|||
		ByteArrayOutputStream baos = null; | 
				
			|||
		try { | 
				
			|||
			// 先用绝对路径查询,再查询相对路径
 | 
				
			|||
			try { | 
				
			|||
				fileis = new FileInputStream(url); | 
				
			|||
			} catch (FileNotFoundException e) { | 
				
			|||
				String path = PoiPublicUtil.getWebRootPath(url); | 
				
			|||
				fileis = new FileInputStream(path); | 
				
			|||
			} | 
				
			|||
			baos = new ByteArrayOutputStream(); | 
				
			|||
			byte[] buffer = new byte[1024]; | 
				
			|||
			int len; | 
				
			|||
			while ((len = fileis.read(buffer)) > -1) { | 
				
			|||
				baos.write(buffer, 0, len); | 
				
			|||
			} | 
				
			|||
			baos.flush(); | 
				
			|||
			return baos.toByteArray(); | 
				
			|||
		} catch (FileNotFoundException e) { | 
				
			|||
			LOGGER.error(e.getMessage(), e); | 
				
			|||
		} catch (IOException e) { | 
				
			|||
			LOGGER.error(e.getMessage(), e); | 
				
			|||
		} finally { | 
				
			|||
			try { | 
				
			|||
				if (fileis != null) | 
				
			|||
					fileis.close(); | 
				
			|||
				if (fileis != null) | 
				
			|||
					baos.close(); | 
				
			|||
			} catch (IOException e) { | 
				
			|||
				LOGGER.error(e.getMessage(), e); | 
				
			|||
			} | 
				
			|||
		} | 
				
			|||
		LOGGER.error(fileis + "这个路径文件没有找到,请查询"); | 
				
			|||
		return null; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
} | 
				
			|||
@ -0,0 +1,64 @@ | 
				
			|||
/** | 
				
			|||
 * Copyright 2013-2015 JEECG (jeecgos@163.com) | 
				
			|||
 * | 
				
			|||
 *  Licensed under the Apache License, Version 2.0 (the "License"); | 
				
			|||
 *  you may not use this file except in compliance with the License. | 
				
			|||
 *  You may obtain a copy of the License at | 
				
			|||
 * | 
				
			|||
 *     http://www.apache.org/licenses/LICENSE-2.0
 | 
				
			|||
 * | 
				
			|||
 *  Unless required by applicable law or agreed to in writing, software | 
				
			|||
 * distributed under the License is distributed on an "AS IS" BASIS, | 
				
			|||
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | 
				
			|||
 * See the License for the specific language governing permissions and | 
				
			|||
 * limitations under the License. | 
				
			|||
 */ | 
				
			|||
package cc.admin.poi.cache.manager; | 
				
			|||
 | 
				
			|||
import java.io.ByteArrayInputStream; | 
				
			|||
import java.io.InputStream; | 
				
			|||
import java.util.Arrays; | 
				
			|||
import java.util.concurrent.ExecutionException; | 
				
			|||
import java.util.concurrent.TimeUnit; | 
				
			|||
 | 
				
			|||
import org.slf4j.Logger; | 
				
			|||
import org.slf4j.LoggerFactory; | 
				
			|||
 | 
				
			|||
import com.google.common.cache.CacheBuilder; | 
				
			|||
import com.google.common.cache.CacheLoader; | 
				
			|||
import com.google.common.cache.LoadingCache; | 
				
			|||
 | 
				
			|||
/** | 
				
			|||
 * 缓存管理 | 
				
			|||
 * | 
				
			|||
 * @author JEECG | 
				
			|||
 * @date 2014年2月10日 | 
				
			|||
 * @version 1.0 | 
				
			|||
 */ | 
				
			|||
public final class POICacheManager { | 
				
			|||
 | 
				
			|||
	private static final Logger LOGGER = LoggerFactory.getLogger(POICacheManager.class); | 
				
			|||
 | 
				
			|||
	private static LoadingCache<String, byte[]> loadingCache; | 
				
			|||
 | 
				
			|||
	static { | 
				
			|||
		loadingCache = CacheBuilder.newBuilder().expireAfterWrite(7, TimeUnit.DAYS).maximumSize(50).build(new CacheLoader<String, byte[]>() { | 
				
			|||
			@Override | 
				
			|||
			public byte[] load(String url) throws Exception { | 
				
			|||
				return new FileLoade().getFile(url); | 
				
			|||
			} | 
				
			|||
		}); | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public static InputStream getFile(String id) { | 
				
			|||
		try { | 
				
			|||
			// 复杂数据,防止操作原数据
 | 
				
			|||
			byte[] result = Arrays.copyOf(loadingCache.get(id), loadingCache.get(id).length); | 
				
			|||
			return new ByteArrayInputStream(result); | 
				
			|||
		} catch (ExecutionException e) { | 
				
			|||
			LOGGER.error(e.getMessage(), e); | 
				
			|||
		} | 
				
			|||
		return null; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
} | 
				
			|||
@ -0,0 +1,11 @@ | 
				
			|||
/** | 
				
			|||
 * 对POI用到的模板进行缓存,进行统一管理,缓存工具暂时使用guava(脱离配置文件) | 
				
			|||
 * 缓存方式统一为byte[] 屏蔽文件类型的差异 | 
				
			|||
 * 缓存获取方式,URL或者URL+index(EXcel的) | 
				
			|||
 */ | 
				
			|||
/** | 
				
			|||
 * @author JEECG | 
				
			|||
 * @date 2014年2月10日 | 
				
			|||
 * @version 1.0 | 
				
			|||
 */ | 
				
			|||
package cc.admin.poi.cache; | 
				
			|||
@ -0,0 +1,171 @@ | 
				
			|||
/** | 
				
			|||
 * Copyright 2013-2015 JEECG (jeecgos@163.com) | 
				
			|||
 * | 
				
			|||
 *  Licensed under the Apache License, Version 2.0 (the "License"); | 
				
			|||
 *  you may not use this file except in compliance with the License. | 
				
			|||
 *  You may obtain a copy of the License at | 
				
			|||
 * | 
				
			|||
 *     http://www.apache.org/licenses/LICENSE-2.0
 | 
				
			|||
 * | 
				
			|||
 *  Unless required by applicable law or agreed to in writing, software | 
				
			|||
 * distributed under the License is distributed on an "AS IS" BASIS, | 
				
			|||
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | 
				
			|||
 * See the License for the specific language governing permissions and | 
				
			|||
 * limitations under the License. | 
				
			|||
 */ | 
				
			|||
package cc.admin.poi.excel; | 
				
			|||
 | 
				
			|||
import cc.admin.poi.excel.entity.ExportParams; | 
				
			|||
import org.apache.poi.hssf.usermodel.HSSFWorkbook; | 
				
			|||
import org.apache.poi.ss.usermodel.Workbook; | 
				
			|||
import org.apache.poi.xssf.streaming.SXSSFWorkbook; | 
				
			|||
import org.apache.poi.xssf.usermodel.XSSFWorkbook; | 
				
			|||
import cc.admin.poi.excel.entity.TemplateExportParams; | 
				
			|||
import cc.admin.poi.excel.entity.enmus.ExcelType; | 
				
			|||
import cc.admin.poi.excel.entity.params.ExcelExportEntity; | 
				
			|||
import cc.admin.poi.excel.export.ExcelExportServer; | 
				
			|||
import cc.admin.poi.excel.export.template.ExcelExportOfTemplateUtil; | 
				
			|||
 | 
				
			|||
import java.util.Collection; | 
				
			|||
import java.util.List; | 
				
			|||
import java.util.Map; | 
				
			|||
 | 
				
			|||
/** | 
				
			|||
 * excel 导出工具类 | 
				
			|||
 * | 
				
			|||
 * @author JEECG | 
				
			|||
 * @version 1.0 | 
				
			|||
 * @date 2013-10-17 | 
				
			|||
 */ | 
				
			|||
public final class ExcelExportUtil { | 
				
			|||
 | 
				
			|||
	private ExcelExportUtil() { | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	//---update-begin-----autor:scott------date:20191016-------for:导出字段支持自定义--------
 | 
				
			|||
	/** | 
				
			|||
	 * 根据Entity创建对应的Excel | 
				
			|||
	 * | 
				
			|||
	 * @param entity | 
				
			|||
	 *            表格标题属性 | 
				
			|||
	 * @param pojoClass | 
				
			|||
	 *            Excel对象Class | 
				
			|||
	 * @param dataSet | 
				
			|||
	 *            Excel对象数据List | 
				
			|||
	 * @param exportFields | 
				
			|||
	 * 	          自定义导出Excel字段数组 | 
				
			|||
	 */ | 
				
			|||
	public static Workbook exportExcel(ExportParams entity, Class<?> pojoClass, Collection<?> dataSet, String[] exportFields) { | 
				
			|||
		Workbook workbook; | 
				
			|||
		if (ExcelType.HSSF.equals(entity.getType())) { | 
				
			|||
			workbook = new HSSFWorkbook(); | 
				
			|||
		} else if (dataSet.size() < 1000) { | 
				
			|||
			workbook = new XSSFWorkbook(); | 
				
			|||
		} else { | 
				
			|||
			workbook = new SXSSFWorkbook(); | 
				
			|||
		} | 
				
			|||
		new ExcelExportServer().createSheet(workbook, entity, pojoClass, dataSet,exportFields); | 
				
			|||
		return workbook; | 
				
			|||
	} | 
				
			|||
	//---update-end-----autor:scott------date:20191016-------for:导出字段支持自定义--------
 | 
				
			|||
 | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 根据Entity创建对应的Excel | 
				
			|||
	 * | 
				
			|||
	 * @param entity | 
				
			|||
	 *            表格标题属性 | 
				
			|||
	 * @param pojoClass | 
				
			|||
	 *            Excel对象Class | 
				
			|||
	 * @param dataSet | 
				
			|||
	 *            Excel对象数据List | 
				
			|||
	 */ | 
				
			|||
	public static Workbook exportExcel(ExportParams entity, Class<?> pojoClass, Collection<?> dataSet) { | 
				
			|||
		Workbook workbook; | 
				
			|||
		if (ExcelType.HSSF.equals(entity.getType())) { | 
				
			|||
			workbook = new HSSFWorkbook(); | 
				
			|||
		} else if (dataSet.size() < 1000) { | 
				
			|||
			workbook = new XSSFWorkbook(); | 
				
			|||
		} else { | 
				
			|||
			workbook = new SXSSFWorkbook(); | 
				
			|||
		} | 
				
			|||
		new ExcelExportServer().createSheet(workbook, entity, pojoClass, dataSet,null); | 
				
			|||
		return workbook; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 根据Map创建对应的Excel | 
				
			|||
	 * | 
				
			|||
	 * @param entity | 
				
			|||
	 *            表格标题属性 | 
				
			|||
	 *            Excel对象Class | 
				
			|||
	 * @param dataSet | 
				
			|||
	 *            Excel对象数据List | 
				
			|||
	 */ | 
				
			|||
	public static Workbook exportExcel(ExportParams entity, List<ExcelExportEntity> entityList, Collection<? extends Map<?, ?>> dataSet) { | 
				
			|||
		Workbook workbook; | 
				
			|||
		if (ExcelType.HSSF.equals(entity.getType())) { | 
				
			|||
			workbook = new HSSFWorkbook(); | 
				
			|||
		} else if (dataSet.size() < 1000) { | 
				
			|||
			workbook = new XSSFWorkbook(); | 
				
			|||
		} else { | 
				
			|||
			workbook = new SXSSFWorkbook(); | 
				
			|||
		} | 
				
			|||
		new ExcelExportServer().createSheetForMap(workbook, entity, entityList, dataSet); | 
				
			|||
		return workbook; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 一个excel 创建多个sheet | 
				
			|||
	 * | 
				
			|||
	 * @param list | 
				
			|||
	 *            多个Map key title 对应表格Title key entity 对应表格对应实体 key data | 
				
			|||
	 *            Collection 数据 | 
				
			|||
	 * @return | 
				
			|||
	 */ | 
				
			|||
	public static Workbook exportExcel(List<Map<String, Object>> list, String type) { | 
				
			|||
		Workbook workbook; | 
				
			|||
		if (ExcelType.HSSF.equals(type)) { | 
				
			|||
			workbook = new HSSFWorkbook(); | 
				
			|||
		} else { | 
				
			|||
			workbook = new XSSFWorkbook(); | 
				
			|||
		} | 
				
			|||
		for (Map<String, Object> map : list) { | 
				
			|||
			ExcelExportServer server = new ExcelExportServer(); | 
				
			|||
			server.createSheet(workbook, (ExportParams) map.get("title"), (Class<?>) map.get("entity"), (Collection<?>) map.get("data"),null); | 
				
			|||
		} | 
				
			|||
		return workbook; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 导出文件通过模板解析,不推荐这个了,推荐全部通过模板来执行处理 | 
				
			|||
	 * | 
				
			|||
	 * @param params | 
				
			|||
	 *            导出参数类 | 
				
			|||
	 * @param pojoClass | 
				
			|||
	 *            对应实体 | 
				
			|||
	 * @param dataSet | 
				
			|||
	 *            实体集合 | 
				
			|||
	 * @param map | 
				
			|||
	 * | 
				
			|||
	 *            模板集合 | 
				
			|||
	 * @return | 
				
			|||
	 */ | 
				
			|||
	public static Workbook exportExcel(TemplateExportParams params, Class<?> pojoClass, Collection<?> dataSet, Map<String, Object> map) { | 
				
			|||
		return new ExcelExportOfTemplateUtil().createExcleByTemplate(params, pojoClass, dataSet, map); | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 导出文件通过模板解析只有模板,没有集合 | 
				
			|||
	 * | 
				
			|||
	 * @param params | 
				
			|||
	 *            导出参数类 | 
				
			|||
	 * @param map | 
				
			|||
	 *            模板集合 | 
				
			|||
	 * @return | 
				
			|||
	 */ | 
				
			|||
	public static Workbook exportExcel(TemplateExportParams params, Map<String, Object> map) { | 
				
			|||
		return new ExcelExportOfTemplateUtil().createExcleByTemplate(params, null, null, map); | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
} | 
				
			|||
@ -0,0 +1,168 @@ | 
				
			|||
/** | 
				
			|||
 * Copyright 2013-2015 JEECG (jeecgos@163.com) | 
				
			|||
 * | 
				
			|||
 *  Licensed under the Apache License, Version 2.0 (the "License"); | 
				
			|||
 *  you may not use this file except in compliance with the License. | 
				
			|||
 *  You may obtain a copy of the License at | 
				
			|||
 * | 
				
			|||
 *     http://www.apache.org/licenses/LICENSE-2.0
 | 
				
			|||
 * | 
				
			|||
 *  Unless required by applicable law or agreed to in writing, software | 
				
			|||
 * distributed under the License is distributed on an "AS IS" BASIS, | 
				
			|||
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | 
				
			|||
 * See the License for the specific language governing permissions and | 
				
			|||
 * limitations under the License. | 
				
			|||
 */ | 
				
			|||
package cc.admin.poi.excel; | 
				
			|||
 | 
				
			|||
import java.io.File; | 
				
			|||
import java.io.FileInputStream; | 
				
			|||
import java.io.IOException; | 
				
			|||
import java.io.InputStream; | 
				
			|||
import java.util.List; | 
				
			|||
 | 
				
			|||
import cc.admin.poi.excel.entity.ImportParams; | 
				
			|||
import cc.admin.poi.excel.entity.result.ExcelImportResult; | 
				
			|||
import cc.admin.poi.excel.imports.ExcelImportServer; | 
				
			|||
import cc.admin.poi.excel.imports.sax.SaxReadExcel; | 
				
			|||
import cc.admin.poi.excel.imports.sax.parse.ISaxRowRead; | 
				
			|||
import cc.admin.poi.handler.inter.IExcelReadRowHanlder; | 
				
			|||
import org.slf4j.Logger; | 
				
			|||
import org.slf4j.LoggerFactory; | 
				
			|||
 | 
				
			|||
/** | 
				
			|||
 * Excel 导入工具 | 
				
			|||
 * | 
				
			|||
 * @author JEECG | 
				
			|||
 * @date 2013-9-24 | 
				
			|||
 * @version 1.0 | 
				
			|||
 */ | 
				
			|||
@SuppressWarnings({ "unchecked" }) | 
				
			|||
public final class ExcelImportUtil { | 
				
			|||
 | 
				
			|||
	private ExcelImportUtil() { | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	private static final Logger LOGGER = LoggerFactory.getLogger(ExcelImportUtil.class); | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * Excel 导入 数据源本地文件,不返回校验结果 导入 字 段类型 Integer,Long,Double,Date,String,Boolean | 
				
			|||
	 * | 
				
			|||
	 * @param file | 
				
			|||
	 * @param pojoClass | 
				
			|||
	 * @param params | 
				
			|||
	 * @return | 
				
			|||
	 * @throws Exception | 
				
			|||
	 */ | 
				
			|||
	public static <T> List<T> importExcel(File file, Class<?> pojoClass, ImportParams params) { | 
				
			|||
		FileInputStream in = null; | 
				
			|||
		List<T> result = null; | 
				
			|||
		try { | 
				
			|||
			in = new FileInputStream(file); | 
				
			|||
			result = new ExcelImportServer().importExcelByIs(in, pojoClass, params).getList(); | 
				
			|||
		} catch (Exception e) { | 
				
			|||
			LOGGER.error(e.getMessage(), e); | 
				
			|||
		} finally { | 
				
			|||
			try { | 
				
			|||
				in.close(); | 
				
			|||
			} catch (IOException e) { | 
				
			|||
				LOGGER.error(e.getMessage(), e); | 
				
			|||
			} | 
				
			|||
		} | 
				
			|||
		return result; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * Excel 导入 数据源IO流,不返回校验结果 导入 字段类型 Integer,Long,Double,Date,String,Boolean | 
				
			|||
	 * | 
				
			|||
	 * @param file | 
				
			|||
	 * @param pojoClass | 
				
			|||
	 * @param params | 
				
			|||
	 * @return | 
				
			|||
	 * @throws Exception | 
				
			|||
	 */ | 
				
			|||
	public static <T> List<T> importExcel(InputStream inputstream, Class<?> pojoClass, ImportParams params) throws Exception { | 
				
			|||
		return new ExcelImportServer().importExcelByIs(inputstream, pojoClass, params).getList(); | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * Excel 导入 数据源IO流,返回校验结果 字段类型 Integer,Long,Double,Date,String,Boolean | 
				
			|||
	 * | 
				
			|||
	 * @param file | 
				
			|||
	 * @param pojoClass | 
				
			|||
	 * @param params | 
				
			|||
	 * @return | 
				
			|||
	 * @throws Exception | 
				
			|||
	 */ | 
				
			|||
	public static <T> ExcelImportResult<T> importExcelVerify(InputStream inputstream, Class<?> pojoClass, ImportParams params) throws Exception { | 
				
			|||
		return new ExcelImportServer().importExcelByIs(inputstream, pojoClass, params); | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * Excel 导入 数据源本地文件,返回校验结果 字段类型 Integer,Long,Double,Date,String,Boolean | 
				
			|||
	 * | 
				
			|||
	 * @param file | 
				
			|||
	 * @param pojoClass | 
				
			|||
	 * @param params | 
				
			|||
	 * @return | 
				
			|||
	 * @throws Exception | 
				
			|||
	 */ | 
				
			|||
	public static <T> ExcelImportResult<T> importExcelVerify(File file, Class<?> pojoClass, ImportParams params) { | 
				
			|||
		FileInputStream in = null; | 
				
			|||
		try { | 
				
			|||
			in = new FileInputStream(file); | 
				
			|||
			return new ExcelImportServer().importExcelByIs(in, pojoClass, params); | 
				
			|||
		} catch (Exception e) { | 
				
			|||
			LOGGER.error(e.getMessage(), e); | 
				
			|||
		} finally { | 
				
			|||
			try { | 
				
			|||
				in.close(); | 
				
			|||
			} catch (IOException e) { | 
				
			|||
				LOGGER.error(e.getMessage(), e); | 
				
			|||
			} | 
				
			|||
		} | 
				
			|||
		return null; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * Excel 通过SAX解析方法,适合大数据导入,不支持图片 导入 数据源IO流,不返回校验结果 导入 字段类型 | 
				
			|||
	 * Integer,Long,Double,Date,String,Boolean | 
				
			|||
	 * | 
				
			|||
	 * @param inputstream | 
				
			|||
	 * @param pojoClass | 
				
			|||
	 * @param params | 
				
			|||
	 * @return | 
				
			|||
	 * @throws Exception | 
				
			|||
	 */ | 
				
			|||
	public static <T> List<T> importExcelBySax(InputStream inputstream, Class<?> pojoClass, ImportParams params) { | 
				
			|||
		return new SaxReadExcel().readExcel(inputstream, pojoClass, params, null, null); | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * Excel 通过SAX解析方法,适合大数据导入,不支持图片 导入 数据源本地文件,不返回校验结果 导入 字 段类型 | 
				
			|||
	 * Integer,Long,Double,Date,String,Boolean | 
				
			|||
	 * | 
				
			|||
	 * @param file | 
				
			|||
	 * @param rowRead | 
				
			|||
	 * @return | 
				
			|||
	 * @throws Exception | 
				
			|||
	 */ | 
				
			|||
	@SuppressWarnings("rawtypes") | 
				
			|||
	public static void importExcelBySax(InputStream inputstream, Class<?> pojoClass, ImportParams params, IExcelReadRowHanlder hanlder) { | 
				
			|||
		new SaxReadExcel().readExcel(inputstream, pojoClass, params, null, hanlder); | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * Excel 通过SAX解析方法,适合大数据导入,不支持图片 导入 数据源IO流,不返回校验结果 导入 字段类型 | 
				
			|||
	 * Integer,Long,Double,Date,String,Boolean | 
				
			|||
	 * | 
				
			|||
	 * @param file | 
				
			|||
	 * @param rowRead | 
				
			|||
	 * @return | 
				
			|||
	 * @throws Exception | 
				
			|||
	 */ | 
				
			|||
	public static <T> List<T> importExcelBySax(InputStream inputstream, ISaxRowRead rowRead) { | 
				
			|||
		return new SaxReadExcel().readExcel(inputstream, null, null, rowRead, null); | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
} | 
				
			|||
@ -0,0 +1,67 @@ | 
				
			|||
package cc.admin.poi.excel; | 
				
			|||
 | 
				
			|||
import cc.admin.poi.excel.html.ExcelToHtmlServer; | 
				
			|||
import org.apache.poi.ss.usermodel.Workbook; | 
				
			|||
 | 
				
			|||
/** | 
				
			|||
 * Excel 变成界面 | 
				
			|||
 * | 
				
			|||
 * @author JEECG | 
				
			|||
 * @date 2015年5月10日 上午11:51:48 | 
				
			|||
 */ | 
				
			|||
public final class ExcelToHtmlUtil { | 
				
			|||
 | 
				
			|||
	private ExcelToHtmlUtil() { | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 转换成为Table | 
				
			|||
	 * | 
				
			|||
	 * @param wb | 
				
			|||
	 *            Excel | 
				
			|||
	 * @return | 
				
			|||
	 */ | 
				
			|||
	public static String toTableHtml(Workbook wb) { | 
				
			|||
		return new ExcelToHtmlServer(wb, false, 0).printPage(); | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 转换成为Table | 
				
			|||
	 * | 
				
			|||
	 * @param wb | 
				
			|||
	 *            Excel | 
				
			|||
	 * @param sheetNum | 
				
			|||
	 *            sheetNum | 
				
			|||
	 * @return | 
				
			|||
	 */ | 
				
			|||
	public static String toTableHtml(Workbook wb, int sheetNum) { | 
				
			|||
		return new ExcelToHtmlServer(wb, false, sheetNum).printPage(); | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 转换成为完整界面 | 
				
			|||
	 * | 
				
			|||
	 * @param wb | 
				
			|||
	 *            Excel | 
				
			|||
	 * @param sheetNum | 
				
			|||
	 *            sheetNum | 
				
			|||
	 * @return | 
				
			|||
	 */ | 
				
			|||
	public static String toAllHtml(Workbook wb) { | 
				
			|||
		return new ExcelToHtmlServer(wb, true, 0).printPage(); | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 转换成为完整界面 | 
				
			|||
	 * | 
				
			|||
	 * @param wb | 
				
			|||
	 *            Excel | 
				
			|||
	 * @param sheetNum | 
				
			|||
	 *            sheetNum | 
				
			|||
	 * @return | 
				
			|||
	 */ | 
				
			|||
	public static String toAllHtml(Workbook wb, int sheetNum) { | 
				
			|||
		return new ExcelToHtmlServer(wb, true, sheetNum).printPage(); | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
} | 
				
			|||
@ -0,0 +1,187 @@ | 
				
			|||
/** | 
				
			|||
 * Copyright 2013-2015 JEECG (jeecgos@163.com) | 
				
			|||
 * | 
				
			|||
 *  Licensed under the Apache License, Version 2.0 (the "License"); | 
				
			|||
 *  you may not use this file except in compliance with the License. | 
				
			|||
 *  You may obtain a copy of the License at | 
				
			|||
 * | 
				
			|||
 *     http://www.apache.org/licenses/LICENSE-2.0
 | 
				
			|||
 * | 
				
			|||
 *  Unless required by applicable law or agreed to in writing, software | 
				
			|||
 * distributed under the License is distributed on an "AS IS" BASIS, | 
				
			|||
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | 
				
			|||
 * See the License for the specific language governing permissions and | 
				
			|||
 * limitations under the License. | 
				
			|||
 */ | 
				
			|||
package cc.admin.poi.excel.annotation; | 
				
			|||
 | 
				
			|||
import java.lang.annotation.ElementType; | 
				
			|||
import java.lang.annotation.Retention; | 
				
			|||
import java.lang.annotation.RetentionPolicy; | 
				
			|||
import java.lang.annotation.Target; | 
				
			|||
 | 
				
			|||
/** | 
				
			|||
 * Excel 导出基本注释 | 
				
			|||
 * | 
				
			|||
 * @author JEECG | 
				
			|||
 * @date 2014年6月20日 下午10:25:12 | 
				
			|||
 */ | 
				
			|||
@Retention(RetentionPolicy.RUNTIME) | 
				
			|||
@Target(ElementType.FIELD) | 
				
			|||
public @interface Excel { | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 导出时间设置,如果字段是Date类型则不需要设置 数据库如果是string 类型,这个需要设置这个数据库格式 | 
				
			|||
	 */ | 
				
			|||
	public String databaseFormat() default "yyyyMMddHHmmss"; | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 导出的时间格式,以这个是否为空来判断是否需要格式化日期 | 
				
			|||
	 */ | 
				
			|||
	public String exportFormat() default ""; | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 时间格式,相当于同时设置了exportFormat 和 importFormat | 
				
			|||
	 */ | 
				
			|||
	public String format() default ""; | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 导出时在excel中每个列的高度 单位为字符,一个汉字=2个字符 | 
				
			|||
	 */ | 
				
			|||
	public double height() default 10; | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 导出类型 1 从file读取_old ,2 是从数据库中读取字节文件, 3文件地址_new, 4网络地址 同样导入也是一样的 | 
				
			|||
	 * | 
				
			|||
	 */ | 
				
			|||
	public int imageType() default 3; | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 导入的时间格式,以这个是否为空来判断是否需要格式化日期 | 
				
			|||
	 */ | 
				
			|||
	public String importFormat() default ""; | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 文字后缀,如% 90 变成90% | 
				
			|||
	 */ | 
				
			|||
	public String suffix() default ""; | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 是否换行 即支持\n | 
				
			|||
	 */ | 
				
			|||
	public boolean isWrap() default true; | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 合并单元格依赖关系,比如第二列合并是基于第一列 则{1}就可以了 | 
				
			|||
	 */ | 
				
			|||
	public int[] mergeRely() default {}; | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 纵向合并内容相同的单元格 | 
				
			|||
	 */ | 
				
			|||
	public boolean mergeVertical() default false; | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 导出时,对应数据库的字段 主要是用户区分每个字段, 不能有annocation重名的 导出时的列名 | 
				
			|||
	 * 导出排序跟定义了annotation的字段的顺序有关 可以使用a_id,b_id来确实是否使用 | 
				
			|||
	 */ | 
				
			|||
	public String name(); | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 是否需要纵向合并单元格(用于含有list中,单个的单元格,合并list创建的多个row) | 
				
			|||
	 */ | 
				
			|||
	public boolean needMerge() default false; | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 展示到第几个可以使用a_id,b_id来确定不同排序 | 
				
			|||
	 */ | 
				
			|||
	public String orderNum() default "0"; | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 值得替换 导出是{"男_1","女_0"} 导入反过来,所以只用写一个 | 
				
			|||
	 */ | 
				
			|||
	public String[] replace() default {}; | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 导入路径,如果是图片可以填写,默认是upload/className/ IconEntity这个类对应的就是upload/Icon/ | 
				
			|||
	 * | 
				
			|||
	 */ | 
				
			|||
	public String savePath() default "upload"; | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 导出类型 1 是文本 2 是图片,3是函数,4是数字 默认是文本 | 
				
			|||
	 */ | 
				
			|||
	public int type() default 1; | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 导出时在excel中每个列的宽 单位为字符,一个汉字=2个字符 如 以列名列内容中较合适的长度 例如姓名列6 【姓名一般三个字】 | 
				
			|||
	 * 性别列4【男女占1,但是列标题两个汉字】 限制1-255 | 
				
			|||
	 */ | 
				
			|||
	public double width() default 10; | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 是否自动统计数据,如果是统计,true的话在最后追加一行统计,把所有数据都和 这个处理会吞没异常,请注意这一点 | 
				
			|||
	 * | 
				
			|||
	 * @return | 
				
			|||
	 */ | 
				
			|||
	public boolean isStatistics() default false; | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 方法描述: 数据字典表 | 
				
			|||
	 * 作    者: yiming.zhang | 
				
			|||
	 * 日    期: 2014年5月11日-下午5:26:40 | 
				
			|||
	 * @return | 
				
			|||
	 * 返回类型: String | 
				
			|||
	 */ | 
				
			|||
	public String dictTable() default ""; | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 方法描述:  数据code | 
				
			|||
	 * 作    者: yiming.zhang | 
				
			|||
	 * 日    期: 2014年5月13日-下午9:37:16 | 
				
			|||
	 * @return | 
				
			|||
	 * 返回类型: String | 
				
			|||
	 */ | 
				
			|||
	public String dicCode() default ""; | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 方法描述:  数据Text | 
				
			|||
	 * 作    者: yiming.zhang | 
				
			|||
	 * 日    期: 2014年5月11日-下午5:29:05 | 
				
			|||
	 * @return | 
				
			|||
	 * 返回类型: String | 
				
			|||
	 */ | 
				
			|||
	public String dicText() default ""; | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 导入数据是否需要转化 | 
				
			|||
	 * 若是为true,则需要在pojo中加入 方法:convertset字段名(String text) | 
				
			|||
	 * @return | 
				
			|||
	 */ | 
				
			|||
	public boolean importConvert() default false; | 
				
			|||
	/** | 
				
			|||
	 * 导出数据是否需要转化 | 
				
			|||
	 * 若是为true,则需要在pojo中加入方法:convertget字段名() | 
				
			|||
	 * @return | 
				
			|||
	 */ | 
				
			|||
	public boolean exportConvert() default false; | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 值的替换是否支持替换多个(默认true,若数据库值本来就包含逗号则需要配置该值为false) | 
				
			|||
	 * @author taoYan | 
				
			|||
	 * @since 2018年8月1日 | 
				
			|||
	 */ | 
				
			|||
	public boolean multiReplace() default true; | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 父表头 | 
				
			|||
	 * @return | 
				
			|||
	 */ | 
				
			|||
	String groupName() default ""; | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 数字格式化,参数是Pattern,使用的对象是DecimalFormat | 
				
			|||
	 * @return | 
				
			|||
	 */ | 
				
			|||
	String numFormat() default ""; | 
				
			|||
} | 
				
			|||
@ -0,0 +1,54 @@ | 
				
			|||
/** | 
				
			|||
 * Copyright 2013-2015 JEECG (jeecgos@163.com) | 
				
			|||
 * | 
				
			|||
 *  Licensed under the Apache License, Version 2.0 (the "License"); | 
				
			|||
 *  you may not use this file except in compliance with the License. | 
				
			|||
 *  You may obtain a copy of the License at | 
				
			|||
 * | 
				
			|||
 *     http://www.apache.org/licenses/LICENSE-2.0
 | 
				
			|||
 * | 
				
			|||
 *  Unless required by applicable law or agreed to in writing, software | 
				
			|||
 * distributed under the License is distributed on an "AS IS" BASIS, | 
				
			|||
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | 
				
			|||
 * See the License for the specific language governing permissions and | 
				
			|||
 * limitations under the License. | 
				
			|||
 */ | 
				
			|||
package cc.admin.poi.excel.annotation; | 
				
			|||
 | 
				
			|||
import java.lang.annotation.ElementType; | 
				
			|||
import java.lang.annotation.Retention; | 
				
			|||
import java.lang.annotation.RetentionPolicy; | 
				
			|||
import java.lang.annotation.Target; | 
				
			|||
import java.util.ArrayList; | 
				
			|||
 | 
				
			|||
/** | 
				
			|||
 * 导出的集合 | 
				
			|||
 * | 
				
			|||
 * @author JEECG 2013年8月24日 | 
				
			|||
 */ | 
				
			|||
@Retention(RetentionPolicy.RUNTIME) | 
				
			|||
@Target(ElementType.FIELD) | 
				
			|||
public @interface ExcelCollection { | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 定义excel导出ID 来限定导出字段,处理一个类对应多个不同名称的情况 | 
				
			|||
	 */ | 
				
			|||
	public String id() default ""; | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 导出时,对应数据库的字段 主要是用户区分每个字段, 不能有annocation重名的 导出时的列名 | 
				
			|||
	 * 导出排序跟定义了annotation的字段的顺序有关 可以使用a_id,b_id来确实是否使用 | 
				
			|||
	 */ | 
				
			|||
	public String name(); | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 展示到第几个同样可以使用a_id,b_id | 
				
			|||
	 * | 
				
			|||
	 */ | 
				
			|||
	public String orderNum() default "0"; | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 创建时创建的类型 默认值是 arrayList | 
				
			|||
	 */ | 
				
			|||
	public Class<?> type() default ArrayList.class; | 
				
			|||
} | 
				
			|||
@ -0,0 +1,43 @@ | 
				
			|||
/** | 
				
			|||
 * Copyright 2013-2015 JEECG (jeecgos@163.com) | 
				
			|||
 * | 
				
			|||
 *  Licensed under the Apache License, Version 2.0 (the "License"); | 
				
			|||
 *  you may not use this file except in compliance with the License. | 
				
			|||
 *  You may obtain a copy of the License at | 
				
			|||
 * | 
				
			|||
 *     http://www.apache.org/licenses/LICENSE-2.0
 | 
				
			|||
 * | 
				
			|||
 *  Unless required by applicable law or agreed to in writing, software | 
				
			|||
 * distributed under the License is distributed on an "AS IS" BASIS, | 
				
			|||
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | 
				
			|||
 * See the License for the specific language governing permissions and | 
				
			|||
 * limitations under the License. | 
				
			|||
 */ | 
				
			|||
package cc.admin.poi.excel.annotation; | 
				
			|||
 | 
				
			|||
import java.lang.annotation.ElementType; | 
				
			|||
import java.lang.annotation.Retention; | 
				
			|||
import java.lang.annotation.RetentionPolicy; | 
				
			|||
import java.lang.annotation.Target; | 
				
			|||
 | 
				
			|||
/** | 
				
			|||
 * 标记是不是导出excel 标记为实体类 | 
				
			|||
 * | 
				
			|||
 * @author JEECG | 
				
			|||
 * | 
				
			|||
 */ | 
				
			|||
@Retention(RetentionPolicy.RUNTIME) | 
				
			|||
@Target(ElementType.FIELD) | 
				
			|||
public @interface ExcelEntity { | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 定义excel导出ID 来限定导出字段,处理一个类对应多个不同名称的情况 | 
				
			|||
	 */ | 
				
			|||
	public String id() default ""; | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 导出时,对应数据库的字段 主要是用户区分每个字段, 不能有annocation重名的 导出时的列名 | 
				
			|||
	 * 导出排序跟定义了annotation的字段的顺序有关 可以使用a_id,b_id来确实是否使用 | 
				
			|||
	 */ | 
				
			|||
	public String name() default ""; | 
				
			|||
} | 
				
			|||
@ -0,0 +1,34 @@ | 
				
			|||
/** | 
				
			|||
 * Copyright 2013-2015 JEECG (jeecgos@163.com) | 
				
			|||
 * | 
				
			|||
 *  Licensed under the Apache License, Version 2.0 (the "License"); | 
				
			|||
 *  you may not use this file except in compliance with the License. | 
				
			|||
 *  You may obtain a copy of the License at | 
				
			|||
 * | 
				
			|||
 *     http://www.apache.org/licenses/LICENSE-2.0
 | 
				
			|||
 * | 
				
			|||
 *  Unless required by applicable law or agreed to in writing, software | 
				
			|||
 * distributed under the License is distributed on an "AS IS" BASIS, | 
				
			|||
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | 
				
			|||
 * See the License for the specific language governing permissions and | 
				
			|||
 * limitations under the License. | 
				
			|||
 */ | 
				
			|||
package cc.admin.poi.excel.annotation; | 
				
			|||
 | 
				
			|||
import java.lang.annotation.ElementType; | 
				
			|||
import java.lang.annotation.Retention; | 
				
			|||
import java.lang.annotation.RetentionPolicy; | 
				
			|||
import java.lang.annotation.Target; | 
				
			|||
 | 
				
			|||
/** | 
				
			|||
 * 标记为excel 创建实体忽略,放置死循环的造成 | 
				
			|||
 * | 
				
			|||
 * @author JEECG | 
				
			|||
 * @date 2013-9-24 | 
				
			|||
 * @version 1.0 | 
				
			|||
 */ | 
				
			|||
@Retention(RetentionPolicy.RUNTIME) | 
				
			|||
@Target(ElementType.FIELD) | 
				
			|||
public @interface ExcelIgnore { | 
				
			|||
 | 
				
			|||
} | 
				
			|||
@ -0,0 +1,36 @@ | 
				
			|||
/** | 
				
			|||
 * Copyright 2013-2015 JEECG (jeecgos@163.com) | 
				
			|||
 * | 
				
			|||
 *  Licensed under the Apache License, Version 2.0 (the "License"); | 
				
			|||
 *  you may not use this file except in compliance with the License. | 
				
			|||
 *  You may obtain a copy of the License at | 
				
			|||
 * | 
				
			|||
 *     http://www.apache.org/licenses/LICENSE-2.0
 | 
				
			|||
 * | 
				
			|||
 *  Unless required by applicable law or agreed to in writing, software | 
				
			|||
 * distributed under the License is distributed on an "AS IS" BASIS, | 
				
			|||
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | 
				
			|||
 * See the License for the specific language governing permissions and | 
				
			|||
 * limitations under the License. | 
				
			|||
 */ | 
				
			|||
package cc.admin.poi.excel.annotation; | 
				
			|||
 | 
				
			|||
import java.lang.annotation.ElementType; | 
				
			|||
import java.lang.annotation.Retention; | 
				
			|||
import java.lang.annotation.RetentionPolicy; | 
				
			|||
import java.lang.annotation.Target; | 
				
			|||
 | 
				
			|||
/** | 
				
			|||
 * excel 导出是用于标记id的 | 
				
			|||
 * | 
				
			|||
 * @author JEECG | 
				
			|||
 * | 
				
			|||
 */ | 
				
			|||
@Retention(RetentionPolicy.RUNTIME) | 
				
			|||
@Target({ ElementType.TYPE }) | 
				
			|||
public @interface ExcelTarget { | 
				
			|||
	/** | 
				
			|||
	 * 定义excel导出ID 来限定导出字段 | 
				
			|||
	 */ | 
				
			|||
	public String value(); | 
				
			|||
} | 
				
			|||
@ -0,0 +1,95 @@ | 
				
			|||
/** | 
				
			|||
 * Copyright 2013-2015 JEECG (jeecgos@163.com) | 
				
			|||
 * | 
				
			|||
 *  Licensed under the Apache License, Version 2.0 (the "License"); | 
				
			|||
 *  you may not use this file except in compliance with the License. | 
				
			|||
 *  You may obtain a copy of the License at | 
				
			|||
 * | 
				
			|||
 *     http://www.apache.org/licenses/LICENSE-2.0
 | 
				
			|||
 * | 
				
			|||
 *  Unless required by applicable law or agreed to in writing, software | 
				
			|||
 * distributed under the License is distributed on an "AS IS" BASIS, | 
				
			|||
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | 
				
			|||
 * See the License for the specific language governing permissions and | 
				
			|||
 * limitations under the License. | 
				
			|||
 */ | 
				
			|||
package cc.admin.poi.excel.annotation; | 
				
			|||
 | 
				
			|||
import java.lang.annotation.ElementType; | 
				
			|||
import java.lang.annotation.Retention; | 
				
			|||
import java.lang.annotation.RetentionPolicy; | 
				
			|||
import java.lang.annotation.Target; | 
				
			|||
 | 
				
			|||
/** | 
				
			|||
 * Excel 导入校验 | 
				
			|||
 * | 
				
			|||
 * @author JEECG | 
				
			|||
 * @date 2014年6月23日 下午10:46:26 | 
				
			|||
 */ | 
				
			|||
@Retention(RetentionPolicy.RUNTIME) | 
				
			|||
@Target(ElementType.FIELD) | 
				
			|||
public @interface ExcelVerify { | 
				
			|||
	/** | 
				
			|||
	 * 接口校验 | 
				
			|||
	 * | 
				
			|||
	 * @return | 
				
			|||
	 */ | 
				
			|||
	public boolean interHandler() default false; | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 是电子邮件 | 
				
			|||
	 * | 
				
			|||
	 * @return | 
				
			|||
	 */ | 
				
			|||
	public boolean isEmail() default false; | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 是13位移动电话 | 
				
			|||
	 * | 
				
			|||
	 * @return | 
				
			|||
	 */ | 
				
			|||
	public boolean isMobile() default false; | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 是座机号码 | 
				
			|||
	 * | 
				
			|||
	 * @return | 
				
			|||
	 */ | 
				
			|||
	public boolean isTel() default false; | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 最大长度 | 
				
			|||
	 * | 
				
			|||
	 * @return | 
				
			|||
	 */ | 
				
			|||
	public int maxLength() default -1; | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 最小长度 | 
				
			|||
	 * | 
				
			|||
	 * @return | 
				
			|||
	 */ | 
				
			|||
	public int minLength() default -1; | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 不允许空 | 
				
			|||
	 * | 
				
			|||
	 * @return | 
				
			|||
	 */ | 
				
			|||
	public boolean notNull() default false; | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 正在表达式 | 
				
			|||
	 * | 
				
			|||
	 * @return | 
				
			|||
	 */ | 
				
			|||
	public String regex() default ""; | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 正在表达式,错误提示信息 | 
				
			|||
	 * | 
				
			|||
	 * @return | 
				
			|||
	 */ | 
				
			|||
	public String regexTip() default "数据不符合规范"; | 
				
			|||
 | 
				
			|||
} | 
				
			|||
@ -0,0 +1,39 @@ | 
				
			|||
/** | 
				
			|||
 * Copyright 2013-2015 JEECG (jeecgos@163.com) | 
				
			|||
 * | 
				
			|||
 *  Licensed under the Apache License, Version 2.0 (the "License"); | 
				
			|||
 *  you may not use this file except in compliance with the License. | 
				
			|||
 *  You may obtain a copy of the License at | 
				
			|||
 * | 
				
			|||
 *     http://www.apache.org/licenses/LICENSE-2.0
 | 
				
			|||
 * | 
				
			|||
 *  Unless required by applicable law or agreed to in writing, software | 
				
			|||
 * distributed under the License is distributed on an "AS IS" BASIS, | 
				
			|||
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | 
				
			|||
 * See the License for the specific language governing permissions and | 
				
			|||
 * limitations under the License. | 
				
			|||
 */ | 
				
			|||
package cc.admin.poi.excel.def; | 
				
			|||
 | 
				
			|||
/** | 
				
			|||
 * 基础POI常量 | 
				
			|||
 * | 
				
			|||
 * @author JEECG | 
				
			|||
 * @date 2014年6月30日 下午9:23:37 | 
				
			|||
 */ | 
				
			|||
interface BasePOIConstants { | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 注解对象 | 
				
			|||
	 */ | 
				
			|||
	public final static String CLASS = "entity"; | 
				
			|||
	/** | 
				
			|||
	 * 表格参数 | 
				
			|||
	 */ | 
				
			|||
	public final static String PARAMS = "params"; | 
				
			|||
	/** | 
				
			|||
	 * 下载文件名称 | 
				
			|||
	 */ | 
				
			|||
	public final static String FILE_NAME = "fileName"; | 
				
			|||
 | 
				
			|||
} | 
				
			|||
@ -0,0 +1,37 @@ | 
				
			|||
/** | 
				
			|||
 * Copyright 2013-2015 JEECG (jeecgos@163.com) | 
				
			|||
 * | 
				
			|||
 *  Licensed under the Apache License, Version 2.0 (the "License"); | 
				
			|||
 *  you may not use this file except in compliance with the License. | 
				
			|||
 *  You may obtain a copy of the License at | 
				
			|||
 * | 
				
			|||
 *     http://www.apache.org/licenses/LICENSE-2.0
 | 
				
			|||
 * | 
				
			|||
 *  Unless required by applicable law or agreed to in writing, software | 
				
			|||
 * distributed under the License is distributed on an "AS IS" BASIS, | 
				
			|||
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | 
				
			|||
 * See the License for the specific language governing permissions and | 
				
			|||
 * limitations under the License. | 
				
			|||
 */ | 
				
			|||
package cc.admin.poi.excel.def; | 
				
			|||
 | 
				
			|||
/** | 
				
			|||
 * 正常导出Excel | 
				
			|||
 * | 
				
			|||
 * @Author JEECG on 14-3-8. 静态常量 | 
				
			|||
 */ | 
				
			|||
public interface MapExcelConstants extends BasePOIConstants { | 
				
			|||
	/** | 
				
			|||
	 * 单Sheet导出 | 
				
			|||
	 */ | 
				
			|||
	public final static String DSTC_MAP_EXCEL_VIEW = "ccMapExcelView"; | 
				
			|||
	/** | 
				
			|||
	 * Entity List | 
				
			|||
	 */ | 
				
			|||
	public final static String ENTITY_LIST = "data"; | 
				
			|||
	/** | 
				
			|||
	 * 数据列表 | 
				
			|||
	 */ | 
				
			|||
	public final static String MAP_LIST = "mapList"; | 
				
			|||
 | 
				
			|||
} | 
				
			|||
@ -0,0 +1,51 @@ | 
				
			|||
/** | 
				
			|||
 * Copyright 2013-2015 JEECG (jeecgos@163.com) | 
				
			|||
 * | 
				
			|||
 *  Licensed under the Apache License, Version 2.0 (the "License"); | 
				
			|||
 *  you may not use this file except in compliance with the License. | 
				
			|||
 *  You may obtain a copy of the License at | 
				
			|||
 * | 
				
			|||
 *     http://www.apache.org/licenses/LICENSE-2.0
 | 
				
			|||
 * | 
				
			|||
 *  Unless required by applicable law or agreed to in writing, software | 
				
			|||
 * distributed under the License is distributed on an "AS IS" BASIS, | 
				
			|||
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | 
				
			|||
 * See the License for the specific language governing permissions and | 
				
			|||
 * limitations under the License. | 
				
			|||
 */ | 
				
			|||
package cc.admin.poi.excel.def; | 
				
			|||
 | 
				
			|||
/** | 
				
			|||
 * 正常导出Excel | 
				
			|||
 * | 
				
			|||
 * @Author JEECG on 14-3-8. 静态常量 | 
				
			|||
 */ | 
				
			|||
public interface NormalExcelConstants extends BasePOIConstants { | 
				
			|||
	/** | 
				
			|||
	 * 单Sheet导出 | 
				
			|||
	 */ | 
				
			|||
	public final static String CC_ADMIN_ENTITY_EXCEL_VIEW = "ccEntityExcelView"; | 
				
			|||
	/** | 
				
			|||
	 * 模型Sheet导出 | 
				
			|||
	 */ | 
				
			|||
	public final static String CC_ADMIN_DATA_MODEL_EXCEL_VIEW = "dataModelExcelView"; | 
				
			|||
	/** | 
				
			|||
	 * 数据列表 | 
				
			|||
	 */ | 
				
			|||
	public final static String DATA_LIST = "data"; | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 多Sheet 对象 | 
				
			|||
	 */ | 
				
			|||
	public final static String MAP_LIST = "mapList"; | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 导出字段自定义 | 
				
			|||
	 */ | 
				
			|||
	public final static String EXPORT_FIELDS = "exportFields"; | 
				
			|||
	/** | 
				
			|||
	 * EXPORT_WORKBOOK | 
				
			|||
	 */ | 
				
			|||
	public final static String EXPORT_WORKBOOK = "exportWorkbook"; | 
				
			|||
 | 
				
			|||
} | 
				
			|||
@ -0,0 +1,38 @@ | 
				
			|||
/** | 
				
			|||
 * Copyright 2013-2015 JEECG (jeecgos@163.com) | 
				
			|||
 * | 
				
			|||
 *  Licensed under the Apache License, Version 2.0 (the "License"); | 
				
			|||
 *  you may not use this file except in compliance with the License. | 
				
			|||
 *  You may obtain a copy of the License at | 
				
			|||
 * | 
				
			|||
 *     http://www.apache.org/licenses/LICENSE-2.0
 | 
				
			|||
 * | 
				
			|||
 *  Unless required by applicable law or agreed to in writing, software | 
				
			|||
 * distributed under the License is distributed on an "AS IS" BASIS, | 
				
			|||
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | 
				
			|||
 * See the License for the specific language governing permissions and | 
				
			|||
 * limitations under the License. | 
				
			|||
 */ | 
				
			|||
package cc.admin.poi.excel.def; | 
				
			|||
 | 
				
			|||
/** | 
				
			|||
 * 模板Excel导出常量 | 
				
			|||
 * | 
				
			|||
 * @author JEECG | 
				
			|||
 * @date 2014年6月30日 下午9:26:52 | 
				
			|||
 */ | 
				
			|||
public interface TemplateExcelConstants extends BasePOIConstants { | 
				
			|||
	/** | 
				
			|||
	 * 模板导出 | 
				
			|||
	 */ | 
				
			|||
	public final static String DSTC_TEMPLATE_EXCEL_VIEW = "ccTemplateExcelView"; | 
				
			|||
	/** | 
				
			|||
	 * 数据列表 | 
				
			|||
	 */ | 
				
			|||
	public final static String LIST_DATA = "list"; | 
				
			|||
	/** | 
				
			|||
	 * 模板参数 | 
				
			|||
	 */ | 
				
			|||
	public final static String MAP_DATA = "map"; | 
				
			|||
 | 
				
			|||
} | 
				
			|||
@ -0,0 +1,38 @@ | 
				
			|||
/** | 
				
			|||
 * Copyright 2013-2015 JEECG (jeecgos@163.com) | 
				
			|||
 * | 
				
			|||
 *  Licensed under the Apache License, Version 2.0 (the "License"); | 
				
			|||
 *  you may not use this file except in compliance with the License. | 
				
			|||
 *  You may obtain a copy of the License at | 
				
			|||
 * | 
				
			|||
 *     http://www.apache.org/licenses/LICENSE-2.0
 | 
				
			|||
 * | 
				
			|||
 *  Unless required by applicable law or agreed to in writing, software | 
				
			|||
 * distributed under the License is distributed on an "AS IS" BASIS, | 
				
			|||
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | 
				
			|||
 * See the License for the specific language governing permissions and | 
				
			|||
 * limitations under the License. | 
				
			|||
 */ | 
				
			|||
package cc.admin.poi.excel.def; | 
				
			|||
 | 
				
			|||
/** | 
				
			|||
 * Word 导出模板常量 | 
				
			|||
 * | 
				
			|||
 * @author JEECG | 
				
			|||
 * @date 2014年7月24日 下午11:26:46 | 
				
			|||
 */ | 
				
			|||
public interface TemplateWordConstants extends BasePOIConstants { | 
				
			|||
	/** | 
				
			|||
	 * 模板导出 | 
				
			|||
	 */ | 
				
			|||
	public final static String DSTC_TEMPLATE_WORD_VIEW = "ccTemplateWordView"; | 
				
			|||
	/** | 
				
			|||
	 * 数据列表 | 
				
			|||
	 */ | 
				
			|||
	public final static String URL = "url"; | 
				
			|||
	/** | 
				
			|||
	 * 模板参数 | 
				
			|||
	 */ | 
				
			|||
	public final static String MAP_DATA = "map"; | 
				
			|||
 | 
				
			|||
} | 
				
			|||
@ -0,0 +1,41 @@ | 
				
			|||
/** | 
				
			|||
 * Copyright 2013-2015 JEECG (jeecgos@163.com) | 
				
			|||
 * | 
				
			|||
 *  Licensed under the Apache License, Version 2.0 (the "License"); | 
				
			|||
 *  you may not use this file except in compliance with the License. | 
				
			|||
 *  You may obtain a copy of the License at | 
				
			|||
 * | 
				
			|||
 *     http://www.apache.org/licenses/LICENSE-2.0
 | 
				
			|||
 * | 
				
			|||
 *  Unless required by applicable law or agreed to in writing, software | 
				
			|||
 * distributed under the License is distributed on an "AS IS" BASIS, | 
				
			|||
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | 
				
			|||
 * See the License for the specific language governing permissions and | 
				
			|||
 * limitations under the License. | 
				
			|||
 */ | 
				
			|||
package cc.admin.poi.excel.entity; | 
				
			|||
 | 
				
			|||
import cc.admin.poi.handler.inter.IExcelDataHandler; | 
				
			|||
 | 
				
			|||
/** | 
				
			|||
 * 基础参数 | 
				
			|||
 * | 
				
			|||
 * @author JEECG | 
				
			|||
 * @date 2014年6月20日 下午1:56:52 | 
				
			|||
 */ | 
				
			|||
public class ExcelBaseParams { | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 数据处理接口,以此为主,replace,format都在这后面 | 
				
			|||
	 */ | 
				
			|||
	private IExcelDataHandler dataHanlder; | 
				
			|||
 | 
				
			|||
	public IExcelDataHandler getDataHanlder() { | 
				
			|||
		return dataHanlder; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setDataHanlder(IExcelDataHandler dataHanlder) { | 
				
			|||
		this.dataHanlder = dataHanlder; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
} | 
				
			|||
@ -0,0 +1,236 @@ | 
				
			|||
/** | 
				
			|||
 * Copyright 2013-2015 JEECG (jeecgos@163.com) | 
				
			|||
 * | 
				
			|||
 *  Licensed under the Apache License, Version 2.0 (the "License"); | 
				
			|||
 *  you may not use this file except in compliance with the License. | 
				
			|||
 *  You may obtain a copy of the License at | 
				
			|||
 * | 
				
			|||
 *     http://www.apache.org/licenses/LICENSE-2.0
 | 
				
			|||
 * | 
				
			|||
 *  Unless required by applicable law or agreed to in writing, software | 
				
			|||
 * distributed under the License is distributed on an "AS IS" BASIS, | 
				
			|||
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | 
				
			|||
 * See the License for the specific language governing permissions and | 
				
			|||
 * limitations under the License. | 
				
			|||
 */ | 
				
			|||
package cc.admin.poi.excel.entity; | 
				
			|||
 | 
				
			|||
import org.apache.poi.hssf.util.HSSFColor; | 
				
			|||
import cc.admin.poi.excel.entity.enmus.ExcelType; | 
				
			|||
import cc.admin.poi.excel.export.styler.ExcelExportStylerDefaultImpl; | 
				
			|||
 | 
				
			|||
/** | 
				
			|||
 * Excel 导出参数 | 
				
			|||
 * | 
				
			|||
 * @author JEECG | 
				
			|||
 * @version 1.0 2013年8月24日 | 
				
			|||
 */ | 
				
			|||
public class ExportParams extends ExcelBaseParams { | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 表格名称 | 
				
			|||
	 */ | 
				
			|||
	private String title; | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 表格名称 | 
				
			|||
	 */ | 
				
			|||
	private short titleHeight = 10; | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 第二行名称 | 
				
			|||
	 */ | 
				
			|||
	private String secondTitle; | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 表格名称 | 
				
			|||
	 */ | 
				
			|||
	private short secondTitleHeight = 8; | 
				
			|||
	/** | 
				
			|||
	 * sheetName | 
				
			|||
	 */ | 
				
			|||
	private String sheetName; | 
				
			|||
	/** | 
				
			|||
	 * 过滤的属性 | 
				
			|||
	 */ | 
				
			|||
	private String[] exclusions; | 
				
			|||
	/** | 
				
			|||
	 * 是否添加需要需要 | 
				
			|||
	 */ | 
				
			|||
	private boolean addIndex; | 
				
			|||
	/** | 
				
			|||
	 * 是否添加需要需要 | 
				
			|||
	 */ | 
				
			|||
	private String indexName = "序号"; | 
				
			|||
	/** | 
				
			|||
	 * 冰冻列 | 
				
			|||
	 */ | 
				
			|||
	private int freezeCol; | 
				
			|||
	/** | 
				
			|||
	 * 表头颜色 | 
				
			|||
	 */ | 
				
			|||
	private short color = HSSFColor.HSSFColorPredefined.WHITE.getIndex(); | 
				
			|||
	/** | 
				
			|||
	 * 属性说明行的颜色 例如:HSSFColor.SKY_BLUE.index 默认 | 
				
			|||
	 */ | 
				
			|||
	private short headerColor = HSSFColor.HSSFColorPredefined.SKY_BLUE.getIndex(); | 
				
			|||
	/** | 
				
			|||
	 * Excel 导出版本 | 
				
			|||
	 */ | 
				
			|||
	private ExcelType type = ExcelType.HSSF; | 
				
			|||
	/** | 
				
			|||
	 * Excel 导出style | 
				
			|||
	 */ | 
				
			|||
	private Class<?> style = ExcelExportStylerDefaultImpl.class; | 
				
			|||
	/** | 
				
			|||
	 * 是否创建表头 | 
				
			|||
	 */ | 
				
			|||
	private boolean isCreateHeadRows = true; | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 本地文件存储基础路径 | 
				
			|||
	 */ | 
				
			|||
	private String imageBasePath; | 
				
			|||
 | 
				
			|||
	public ExportParams() { | 
				
			|||
 | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public ExportParams(String title, String sheetName) { | 
				
			|||
		this.title = title; | 
				
			|||
		this.sheetName = sheetName; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public ExportParams(String title, String sheetName, ExcelType type) { | 
				
			|||
		this.title = title; | 
				
			|||
		this.sheetName = sheetName; | 
				
			|||
		this.type = type; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public ExportParams(String title, String secondTitle, String sheetName) { | 
				
			|||
		this.title = title; | 
				
			|||
		this.secondTitle = secondTitle; | 
				
			|||
		this.sheetName = sheetName; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public short getColor() { | 
				
			|||
		return color; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public String[] getExclusions() { | 
				
			|||
		return exclusions; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public short getHeaderColor() { | 
				
			|||
		return headerColor; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public String getSecondTitle() { | 
				
			|||
		return secondTitle; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public short getSecondTitleHeight() { | 
				
			|||
		return (short) (secondTitleHeight * 50); | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public String getSheetName() { | 
				
			|||
		return sheetName; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public String getTitle() { | 
				
			|||
		return title; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public short getTitleHeight() { | 
				
			|||
		return (short) (titleHeight * 50); | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public boolean isAddIndex() { | 
				
			|||
		return addIndex; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setAddIndex(boolean addIndex) { | 
				
			|||
		this.addIndex = addIndex; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setColor(short color) { | 
				
			|||
		this.color = color; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setExclusions(String[] exclusions) { | 
				
			|||
		this.exclusions = exclusions; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setHeaderColor(short headerColor) { | 
				
			|||
		this.headerColor = headerColor; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setSecondTitle(String secondTitle) { | 
				
			|||
		this.secondTitle = secondTitle; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setSecondTitleHeight(short secondTitleHeight) { | 
				
			|||
		this.secondTitleHeight = secondTitleHeight; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setSheetName(String sheetName) { | 
				
			|||
		this.sheetName = sheetName; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setTitle(String title) { | 
				
			|||
		this.title = title; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setTitleHeight(short titleHeight) { | 
				
			|||
		this.titleHeight = titleHeight; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public ExcelType getType() { | 
				
			|||
		return type; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setType(ExcelType type) { | 
				
			|||
		this.type = type; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public String getIndexName() { | 
				
			|||
		return indexName; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setIndexName(String indexName) { | 
				
			|||
		this.indexName = indexName; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public Class<?> getStyle() { | 
				
			|||
		return style; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setStyle(Class<?> style) { | 
				
			|||
		this.style = style; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public int getFreezeCol() { | 
				
			|||
		return freezeCol; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setFreezeCol(int freezeCol) { | 
				
			|||
		this.freezeCol = freezeCol; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public boolean isCreateHeadRows() { | 
				
			|||
		return isCreateHeadRows; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setCreateHeadRows(boolean isCreateHeadRows) { | 
				
			|||
		this.isCreateHeadRows = isCreateHeadRows; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public String getImageBasePath() { | 
				
			|||
		return imageBasePath; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setImageBasePath(String imageBasePath) { | 
				
			|||
		this.imageBasePath = imageBasePath; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
} | 
				
			|||
@ -0,0 +1,177 @@ | 
				
			|||
/** | 
				
			|||
 * Copyright 2013-2015 JEECG (jeecgos@163.com) | 
				
			|||
 * | 
				
			|||
 *  Licensed under the Apache License, Version 2.0 (the "License"); | 
				
			|||
 *  you may not use this file except in compliance with the License. | 
				
			|||
 *  You may obtain a copy of the License at | 
				
			|||
 * | 
				
			|||
 *     http://www.apache.org/licenses/LICENSE-2.0
 | 
				
			|||
 * | 
				
			|||
 *  Unless required by applicable law or agreed to in writing, software | 
				
			|||
 * distributed under the License is distributed on an "AS IS" BASIS, | 
				
			|||
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | 
				
			|||
 * See the License for the specific language governing permissions and | 
				
			|||
 * limitations under the License. | 
				
			|||
 */ | 
				
			|||
package cc.admin.poi.excel.entity; | 
				
			|||
 | 
				
			|||
import cc.admin.poi.handler.inter.IExcelVerifyHandler; | 
				
			|||
 | 
				
			|||
import java.util.List; | 
				
			|||
 | 
				
			|||
/** | 
				
			|||
 * 导入参数设置 | 
				
			|||
 * | 
				
			|||
 * @author JEECG | 
				
			|||
 * @date 2013-9-24 | 
				
			|||
 * @version 1.0 | 
				
			|||
 */ | 
				
			|||
public class ImportParams extends ExcelBaseParams { | 
				
			|||
	/** | 
				
			|||
	 * 表格标题行数,默认0 | 
				
			|||
	 */ | 
				
			|||
	private int titleRows = 0; | 
				
			|||
	/** | 
				
			|||
	 * 表头行数,默认1 | 
				
			|||
	 */ | 
				
			|||
	private int headRows = 1; | 
				
			|||
	/** | 
				
			|||
	 * 字段真正值和列标题之间的距离 默认0 | 
				
			|||
	 */ | 
				
			|||
	private int startRows = 0; | 
				
			|||
	/** | 
				
			|||
	 * 主键设置,如何这个cell没有值,就跳过 或者认为这个是list的下面的值 | 
				
			|||
	 */ | 
				
			|||
	private int keyIndex = 0; | 
				
			|||
	/** | 
				
			|||
	 * 上传表格需要读取的sheet 数量,默认为1 | 
				
			|||
	 */ | 
				
			|||
	private int sheetNum = 1; | 
				
			|||
	/** | 
				
			|||
	 * 是否需要保存上传的Excel,默认为false | 
				
			|||
	 */ | 
				
			|||
	private boolean needSave = false; | 
				
			|||
	/** | 
				
			|||
	 * 保存上传的Excel目录,默认是 如 TestEntity这个类保存路径就是 | 
				
			|||
	 * upload/excelUpload/Test/yyyyMMddHHmss_***** 保存名称上传时间_五位随机数 | 
				
			|||
	 */ | 
				
			|||
	private String saveUrl = "upload/excelUpload"; | 
				
			|||
	/** | 
				
			|||
	 * 校验处理接口 | 
				
			|||
	 */ | 
				
			|||
	private IExcelVerifyHandler verifyHanlder; | 
				
			|||
	/** | 
				
			|||
	 * 最后的无效行数 | 
				
			|||
	 */ | 
				
			|||
	private int lastOfInvalidRow = 0; | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 不需要解析的表头 只作为多表头展示,无字段与其绑定 | 
				
			|||
	 */ | 
				
			|||
	private List<String> ignoreHeaderList; | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 图片列 集合 | 
				
			|||
	 */ | 
				
			|||
	private List<String> imageList; | 
				
			|||
 | 
				
			|||
	public int getHeadRows() { | 
				
			|||
		return headRows; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public int getKeyIndex() { | 
				
			|||
		return keyIndex; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public String getSaveUrl() { | 
				
			|||
		return saveUrl; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public int getSheetNum() { | 
				
			|||
		return sheetNum; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public int getStartRows() { | 
				
			|||
		return startRows; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public int getTitleRows() { | 
				
			|||
		return titleRows; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public IExcelVerifyHandler getVerifyHanlder() { | 
				
			|||
		return verifyHanlder; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public boolean isNeedSave() { | 
				
			|||
		return needSave; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setHeadRows(int headRows) { | 
				
			|||
		this.headRows = headRows; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setKeyIndex(int keyIndex) { | 
				
			|||
		this.keyIndex = keyIndex; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setNeedSave(boolean needSave) { | 
				
			|||
		this.needSave = needSave; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setSaveUrl(String saveUrl) { | 
				
			|||
		this.saveUrl = saveUrl; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setSheetNum(int sheetNum) { | 
				
			|||
		this.sheetNum = sheetNum; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setStartRows(int startRows) { | 
				
			|||
		this.startRows = startRows; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setTitleRows(int titleRows) { | 
				
			|||
		this.titleRows = titleRows; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setVerifyHanlder(IExcelVerifyHandler verifyHanlder) { | 
				
			|||
		this.verifyHanlder = verifyHanlder; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public int getLastOfInvalidRow() { | 
				
			|||
		return lastOfInvalidRow; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setLastOfInvalidRow(int lastOfInvalidRow) { | 
				
			|||
		this.lastOfInvalidRow = lastOfInvalidRow; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public List<String> getImageList() { | 
				
			|||
		return imageList; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setImageList(List<String> imageList) { | 
				
			|||
		this.imageList = imageList; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public List<String> getIgnoreHeaderList() { | 
				
			|||
		return ignoreHeaderList; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setIgnoreHeaderList(List<String> ignoreHeaderList) { | 
				
			|||
		this.ignoreHeaderList = ignoreHeaderList; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 根据表头显示的文字 判断是否忽略该表头 | 
				
			|||
	 * @param text | 
				
			|||
	 * @return | 
				
			|||
	 */ | 
				
			|||
	public boolean isIgnoreHeader(String text){ | 
				
			|||
		if(ignoreHeaderList!=null && ignoreHeaderList.indexOf(text)>=0){ | 
				
			|||
			return true; | 
				
			|||
		} | 
				
			|||
		return false; | 
				
			|||
	} | 
				
			|||
} | 
				
			|||
@ -0,0 +1,209 @@ | 
				
			|||
/** | 
				
			|||
 * Copyright 2013-2015 JEECG (jeecgos@163.com) | 
				
			|||
 * | 
				
			|||
 *  Licensed under the Apache License, Version 2.0 (the "License"); | 
				
			|||
 *  you may not use this file except in compliance with the License. | 
				
			|||
 *  You may obtain a copy of the License at | 
				
			|||
 * | 
				
			|||
 *     http://www.apache.org/licenses/LICENSE-2.0
 | 
				
			|||
 * | 
				
			|||
 *  Unless required by applicable law or agreed to in writing, software | 
				
			|||
 * distributed under the License is distributed on an "AS IS" BASIS, | 
				
			|||
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | 
				
			|||
 * See the License for the specific language governing permissions and | 
				
			|||
 * limitations under the License. | 
				
			|||
 */ | 
				
			|||
package cc.admin.poi.excel.entity; | 
				
			|||
 | 
				
			|||
import cc.admin.poi.excel.export.styler.ExcelExportStylerDefaultImpl; | 
				
			|||
 | 
				
			|||
/** | 
				
			|||
 * 模板导出参数设置 | 
				
			|||
 * | 
				
			|||
 * @author JEECG | 
				
			|||
 * @date 2013-10-17 | 
				
			|||
 * @version 1.0 | 
				
			|||
 */ | 
				
			|||
public class TemplateExportParams extends ExcelBaseParams { | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 输出全部的sheet | 
				
			|||
	 */ | 
				
			|||
	private boolean scanAllsheet = false; | 
				
			|||
	/** | 
				
			|||
	 * 模板的路径 | 
				
			|||
	 */ | 
				
			|||
	private String templateUrl; | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 需要导出的第几个 sheetNum,默认是第0个 | 
				
			|||
	 */ | 
				
			|||
	private Integer[] sheetNum = new Integer[] { 0 }; | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 这只sheetName 不填就使用原来的 | 
				
			|||
	 */ | 
				
			|||
	private String[] sheetName; | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 表格列标题行数,默认1 | 
				
			|||
	 */ | 
				
			|||
	private int headingRows = 1; | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 表格列标题开始行,默认1 | 
				
			|||
	 */ | 
				
			|||
	private int headingStartRow = 1; | 
				
			|||
	/** | 
				
			|||
	 * 设置数据源的NUM | 
				
			|||
	 */ | 
				
			|||
	private int dataSheetNum = 0; | 
				
			|||
	/** | 
				
			|||
	 * Excel 导出style | 
				
			|||
	 */ | 
				
			|||
	private Class<?> style = ExcelExportStylerDefaultImpl.class; | 
				
			|||
	/** | 
				
			|||
	 * FOR EACH 用到的局部变量 | 
				
			|||
	 */ | 
				
			|||
	private String tempParams = "t"; | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 默认构造器 | 
				
			|||
	 */ | 
				
			|||
	public TemplateExportParams() { | 
				
			|||
 | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 构造器 | 
				
			|||
	 * | 
				
			|||
	 * @param templateUrl | 
				
			|||
	 *            模板路径 | 
				
			|||
	 * @param scanAllsheet | 
				
			|||
	 *            是否输出全部的sheet | 
				
			|||
	 * @param sheetName | 
				
			|||
	 *            sheet的名称,可不填 | 
				
			|||
	 */ | 
				
			|||
	public TemplateExportParams(String templateUrl, boolean scanAllsheet, String... sheetName) { | 
				
			|||
		this.templateUrl = templateUrl; | 
				
			|||
		this.scanAllsheet = scanAllsheet; | 
				
			|||
		if (sheetName != null && sheetName.length > 0) { | 
				
			|||
			this.sheetName = sheetName; | 
				
			|||
 | 
				
			|||
		} | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 构造器 | 
				
			|||
	 * | 
				
			|||
	 * @param templateUrl | 
				
			|||
	 *            模板路径 | 
				
			|||
	 * @param sheetNum | 
				
			|||
	 *            sheet 的位置,可不填 | 
				
			|||
	 */ | 
				
			|||
	public TemplateExportParams(String templateUrl, Integer... sheetNum) { | 
				
			|||
		this.templateUrl = templateUrl; | 
				
			|||
		if (sheetNum != null && sheetNum.length > 0) { | 
				
			|||
			this.sheetNum = sheetNum; | 
				
			|||
		} | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 单个sheet输出构造器 | 
				
			|||
	 * | 
				
			|||
	 * @param templateUrl | 
				
			|||
	 *            模板路径 | 
				
			|||
	 * @param sheetName | 
				
			|||
	 *            sheet的名称 | 
				
			|||
	 * @param sheetNum | 
				
			|||
	 *            sheet的位置,可不填 | 
				
			|||
	 */ | 
				
			|||
	public TemplateExportParams(String templateUrl, String sheetName, Integer... sheetNum) { | 
				
			|||
		this.templateUrl = templateUrl; | 
				
			|||
		this.sheetName = new String[] { sheetName }; | 
				
			|||
		if (sheetNum != null && sheetNum.length > 0) { | 
				
			|||
			this.sheetNum = sheetNum; | 
				
			|||
		} | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public int getHeadingRows() { | 
				
			|||
		return headingRows; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public int getHeadingStartRow() { | 
				
			|||
		return headingStartRow; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public String[] getSheetName() { | 
				
			|||
		return sheetName; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public Integer[] getSheetNum() { | 
				
			|||
		return sheetNum; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public String getTemplateUrl() { | 
				
			|||
		return templateUrl; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setHeadingRows(int headingRows) { | 
				
			|||
		this.headingRows = headingRows; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setHeadingStartRow(int headingStartRow) { | 
				
			|||
		this.headingStartRow = headingStartRow; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setSheetName(String[] sheetName) { | 
				
			|||
		this.sheetName = sheetName; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setSheetName(String sheetName) { | 
				
			|||
		this.sheetName = new String[] { sheetName }; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setSheetNum(Integer[] sheetNum) { | 
				
			|||
		this.sheetNum = sheetNum; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setSheetNum(Integer sheetNum) { | 
				
			|||
		this.sheetNum = new Integer[] { sheetNum }; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setTemplateUrl(String templateUrl) { | 
				
			|||
		this.templateUrl = templateUrl; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public Class<?> getStyle() { | 
				
			|||
		return style; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setStyle(Class<?> style) { | 
				
			|||
		this.style = style; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public int getDataSheetNum() { | 
				
			|||
		return dataSheetNum; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setDataSheetNum(int dataSheetNum) { | 
				
			|||
		this.dataSheetNum = dataSheetNum; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public boolean isScanAllsheet() { | 
				
			|||
		return scanAllsheet; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setScanAllsheet(boolean scanAllsheet) { | 
				
			|||
		this.scanAllsheet = scanAllsheet; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public String getTempParams() { | 
				
			|||
		return tempParams; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setTempParams(String tempParams) { | 
				
			|||
		this.tempParams = tempParams; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
} | 
				
			|||
@ -0,0 +1,28 @@ | 
				
			|||
/** | 
				
			|||
 * Copyright 2013-2015 JEECG (jeecgos@163.com) | 
				
			|||
 * | 
				
			|||
 *  Licensed under the Apache License, Version 2.0 (the "License"); | 
				
			|||
 *  you may not use this file except in compliance with the License. | 
				
			|||
 *  You may obtain a copy of the License at | 
				
			|||
 * | 
				
			|||
 *     http://www.apache.org/licenses/LICENSE-2.0
 | 
				
			|||
 * | 
				
			|||
 *  Unless required by applicable law or agreed to in writing, software | 
				
			|||
 * distributed under the License is distributed on an "AS IS" BASIS, | 
				
			|||
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | 
				
			|||
 * See the License for the specific language governing permissions and | 
				
			|||
 * limitations under the License. | 
				
			|||
 */ | 
				
			|||
package cc.admin.poi.excel.entity.enmus; | 
				
			|||
 | 
				
			|||
/** | 
				
			|||
 * Cell 值得类型 | 
				
			|||
 * | 
				
			|||
 * @author JEECG | 
				
			|||
 * @date 2014年12月29日 下午10:20:49 | 
				
			|||
 */ | 
				
			|||
public enum CellValueType { | 
				
			|||
 | 
				
			|||
	String, Number, Boolean, Date, TElement, Null, None; | 
				
			|||
 | 
				
			|||
} | 
				
			|||
@ -0,0 +1,48 @@ | 
				
			|||
/** | 
				
			|||
 * Copyright 2013-2015 JEECG (jeecgos@163.com) | 
				
			|||
 * | 
				
			|||
 *  Licensed under the Apache License, Version 2.0 (the "License"); | 
				
			|||
 *  you may not use this file except in compliance with the License. | 
				
			|||
 *  You may obtain a copy of the License at | 
				
			|||
 * | 
				
			|||
 *     http://www.apache.org/licenses/LICENSE-2.0
 | 
				
			|||
 * | 
				
			|||
 *  Unless required by applicable law or agreed to in writing, software | 
				
			|||
 * distributed under the License is distributed on an "AS IS" BASIS, | 
				
			|||
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | 
				
			|||
 * See the License for the specific language governing permissions and | 
				
			|||
 * limitations under the License. | 
				
			|||
 */ | 
				
			|||
package cc.admin.poi.excel.entity.enmus; | 
				
			|||
 | 
				
			|||
import cc.admin.poi.excel.export.styler.ExcelExportStylerBorderImpl; | 
				
			|||
import cc.admin.poi.excel.export.styler.ExcelExportStylerColorImpl; | 
				
			|||
import cc.admin.poi.excel.export.styler.ExcelExportStylerDefaultImpl; | 
				
			|||
 | 
				
			|||
/** | 
				
			|||
 * 插件提供的几个默认样式 | 
				
			|||
 * | 
				
			|||
 * @author JEECG | 
				
			|||
 * @date 2015年1月9日 下午9:02:24 | 
				
			|||
 */ | 
				
			|||
public enum ExcelStyleType { | 
				
			|||
 | 
				
			|||
	NONE("默认样式", ExcelExportStylerDefaultImpl.class), BORDER("边框样式", ExcelExportStylerBorderImpl.class), COLOR("间隔行样式", ExcelExportStylerColorImpl.class); | 
				
			|||
 | 
				
			|||
	private String name; | 
				
			|||
	private Class<?> clazz; | 
				
			|||
 | 
				
			|||
	ExcelStyleType(String name, Class<?> clazz) { | 
				
			|||
		this.name = name; | 
				
			|||
		this.clazz = clazz; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public Class<?> getClazz() { | 
				
			|||
		return clazz; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public String getName() { | 
				
			|||
		return name; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
} | 
				
			|||
@ -0,0 +1,28 @@ | 
				
			|||
/** | 
				
			|||
 * Copyright 2013-2015 JEECG (jeecgos@163.com) | 
				
			|||
 * | 
				
			|||
 *  Licensed under the Apache License, Version 2.0 (the "License"); | 
				
			|||
 *  you may not use this file except in compliance with the License. | 
				
			|||
 *  You may obtain a copy of the License at | 
				
			|||
 * | 
				
			|||
 *     http://www.apache.org/licenses/LICENSE-2.0
 | 
				
			|||
 * | 
				
			|||
 *  Unless required by applicable law or agreed to in writing, software | 
				
			|||
 * distributed under the License is distributed on an "AS IS" BASIS, | 
				
			|||
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | 
				
			|||
 * See the License for the specific language governing permissions and | 
				
			|||
 * limitations under the License. | 
				
			|||
 */ | 
				
			|||
package cc.admin.poi.excel.entity.enmus; | 
				
			|||
 | 
				
			|||
/** | 
				
			|||
 * Excel Type | 
				
			|||
 * | 
				
			|||
 * @author JEECG | 
				
			|||
 * @date 2014年12月29日 下午9:08:21 | 
				
			|||
 */ | 
				
			|||
public enum ExcelType { | 
				
			|||
 | 
				
			|||
	HSSF, XSSF; | 
				
			|||
 | 
				
			|||
} | 
				
			|||
@ -0,0 +1,41 @@ | 
				
			|||
/** | 
				
			|||
 * Copyright 2013-2015 JEECG (jeecgos@163.com) | 
				
			|||
 * | 
				
			|||
 *  Licensed under the Apache License, Version 2.0 (the "License"); | 
				
			|||
 *  you may not use this file except in compliance with the License. | 
				
			|||
 *  You may obtain a copy of the License at | 
				
			|||
 * | 
				
			|||
 *     http://www.apache.org/licenses/LICENSE-2.0
 | 
				
			|||
 * | 
				
			|||
 *  Unless required by applicable law or agreed to in writing, software | 
				
			|||
 * distributed under the License is distributed on an "AS IS" BASIS, | 
				
			|||
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | 
				
			|||
 * See the License for the specific language governing permissions and | 
				
			|||
 * limitations under the License. | 
				
			|||
 */ | 
				
			|||
package cc.admin.poi.excel.entity.entity; | 
				
			|||
 | 
				
			|||
import cc.admin.poi.handler.inter.IExcelDataHandler; | 
				
			|||
 | 
				
			|||
/** | 
				
			|||
 * 基础参数 | 
				
			|||
 * | 
				
			|||
 * @author JEECG | 
				
			|||
 * @date 2014年6月20日 下午1:56:52 | 
				
			|||
 */ | 
				
			|||
public class ExcelBaseParams { | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 数据处理接口,以此为主,replace,format都在这后面 | 
				
			|||
	 */ | 
				
			|||
	private IExcelDataHandler dataHanlder; | 
				
			|||
 | 
				
			|||
	public IExcelDataHandler getDataHanlder() { | 
				
			|||
		return dataHanlder; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setDataHanlder(IExcelDataHandler dataHanlder) { | 
				
			|||
		this.dataHanlder = dataHanlder; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
} | 
				
			|||
@ -0,0 +1,237 @@ | 
				
			|||
/** | 
				
			|||
 * Copyright 2013-2015 JEECG (jeecgos@163.com) | 
				
			|||
 * | 
				
			|||
 *  Licensed under the Apache License, Version 2.0 (the "License"); | 
				
			|||
 *  you may not use this file except in compliance with the License. | 
				
			|||
 *  You may obtain a copy of the License at | 
				
			|||
 * | 
				
			|||
 *     http://www.apache.org/licenses/LICENSE-2.0
 | 
				
			|||
 * | 
				
			|||
 *  Unless required by applicable law or agreed to in writing, software | 
				
			|||
 * distributed under the License is distributed on an "AS IS" BASIS, | 
				
			|||
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | 
				
			|||
 * See the License for the specific language governing permissions and | 
				
			|||
 * limitations under the License. | 
				
			|||
 */ | 
				
			|||
package cc.admin.poi.excel.entity.entity; | 
				
			|||
 | 
				
			|||
import cc.admin.poi.excel.entity.ExcelBaseParams; | 
				
			|||
import cc.admin.poi.excel.entity.enmus.ExcelType; | 
				
			|||
import cc.admin.poi.excel.export.styler.ExcelExportStylerDefaultImpl; | 
				
			|||
import org.apache.poi.hssf.util.HSSFColor; | 
				
			|||
 | 
				
			|||
/** | 
				
			|||
 * Excel 导出参数 | 
				
			|||
 * | 
				
			|||
 * @author JEECG | 
				
			|||
 * @version 1.0 2013年8月24日 | 
				
			|||
 */ | 
				
			|||
public class ExportParams extends ExcelBaseParams { | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 表格名称 | 
				
			|||
	 */ | 
				
			|||
	private String title; | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 表格名称 | 
				
			|||
	 */ | 
				
			|||
	private short titleHeight = 10; | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 第二行名称 | 
				
			|||
	 */ | 
				
			|||
	private String secondTitle; | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 表格名称 | 
				
			|||
	 */ | 
				
			|||
	private short secondTitleHeight = 8; | 
				
			|||
	/** | 
				
			|||
	 * sheetName | 
				
			|||
	 */ | 
				
			|||
	private String sheetName; | 
				
			|||
	/** | 
				
			|||
	 * 过滤的属性 | 
				
			|||
	 */ | 
				
			|||
	private String[] exclusions; | 
				
			|||
	/** | 
				
			|||
	 * 是否添加需要需要 | 
				
			|||
	 */ | 
				
			|||
	private boolean addIndex; | 
				
			|||
	/** | 
				
			|||
	 * 是否添加需要需要 | 
				
			|||
	 */ | 
				
			|||
	private String indexName = "序号"; | 
				
			|||
	/** | 
				
			|||
	 * 冰冻列 | 
				
			|||
	 */ | 
				
			|||
	private int freezeCol; | 
				
			|||
	/** | 
				
			|||
	 * 表头颜色 | 
				
			|||
	 */ | 
				
			|||
	private short color = HSSFColor.HSSFColorPredefined.WHITE.getIndex(); | 
				
			|||
	/** | 
				
			|||
	 * 属性说明行的颜色 例如:HSSFColor.SKY_BLUE.index 默认 | 
				
			|||
	 */ | 
				
			|||
	private short headerColor = HSSFColor.HSSFColorPredefined.SKY_BLUE.getIndex(); | 
				
			|||
	/** | 
				
			|||
	 * Excel 导出版本 | 
				
			|||
	 */ | 
				
			|||
	private ExcelType type = ExcelType.HSSF; | 
				
			|||
	/** | 
				
			|||
	 * Excel 导出style | 
				
			|||
	 */ | 
				
			|||
	private Class<?> style = ExcelExportStylerDefaultImpl.class; | 
				
			|||
	/** | 
				
			|||
	 * 是否创建表头 | 
				
			|||
	 */ | 
				
			|||
	private boolean isCreateHeadRows = true; | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 本地文件存储基础路径 | 
				
			|||
	 */ | 
				
			|||
	private String imageBasePath; | 
				
			|||
 | 
				
			|||
	public ExportParams() { | 
				
			|||
 | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public ExportParams(String title, String sheetName) { | 
				
			|||
		this.title = title; | 
				
			|||
		this.sheetName = sheetName; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public ExportParams(String title, String sheetName, ExcelType type) { | 
				
			|||
		this.title = title; | 
				
			|||
		this.sheetName = sheetName; | 
				
			|||
		this.type = type; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public ExportParams(String title, String secondTitle, String sheetName) { | 
				
			|||
		this.title = title; | 
				
			|||
		this.secondTitle = secondTitle; | 
				
			|||
		this.sheetName = sheetName; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public short getColor() { | 
				
			|||
		return color; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public String[] getExclusions() { | 
				
			|||
		return exclusions; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public short getHeaderColor() { | 
				
			|||
		return headerColor; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public String getSecondTitle() { | 
				
			|||
		return secondTitle; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public short getSecondTitleHeight() { | 
				
			|||
		return (short) (secondTitleHeight * 50); | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public String getSheetName() { | 
				
			|||
		return sheetName; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public String getTitle() { | 
				
			|||
		return title; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public short getTitleHeight() { | 
				
			|||
		return (short) (titleHeight * 50); | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public boolean isAddIndex() { | 
				
			|||
		return addIndex; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setAddIndex(boolean addIndex) { | 
				
			|||
		this.addIndex = addIndex; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setColor(short color) { | 
				
			|||
		this.color = color; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setExclusions(String[] exclusions) { | 
				
			|||
		this.exclusions = exclusions; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setHeaderColor(short headerColor) { | 
				
			|||
		this.headerColor = headerColor; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setSecondTitle(String secondTitle) { | 
				
			|||
		this.secondTitle = secondTitle; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setSecondTitleHeight(short secondTitleHeight) { | 
				
			|||
		this.secondTitleHeight = secondTitleHeight; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setSheetName(String sheetName) { | 
				
			|||
		this.sheetName = sheetName; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setTitle(String title) { | 
				
			|||
		this.title = title; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setTitleHeight(short titleHeight) { | 
				
			|||
		this.titleHeight = titleHeight; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public ExcelType getType() { | 
				
			|||
		return type; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setType(ExcelType type) { | 
				
			|||
		this.type = type; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public String getIndexName() { | 
				
			|||
		return indexName; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setIndexName(String indexName) { | 
				
			|||
		this.indexName = indexName; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public Class<?> getStyle() { | 
				
			|||
		return style; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setStyle(Class<?> style) { | 
				
			|||
		this.style = style; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public int getFreezeCol() { | 
				
			|||
		return freezeCol; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setFreezeCol(int freezeCol) { | 
				
			|||
		this.freezeCol = freezeCol; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public boolean isCreateHeadRows() { | 
				
			|||
		return isCreateHeadRows; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setCreateHeadRows(boolean isCreateHeadRows) { | 
				
			|||
		this.isCreateHeadRows = isCreateHeadRows; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public String getImageBasePath() { | 
				
			|||
		return imageBasePath; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setImageBasePath(String imageBasePath) { | 
				
			|||
		this.imageBasePath = imageBasePath; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
} | 
				
			|||
@ -0,0 +1,178 @@ | 
				
			|||
/** | 
				
			|||
 * Copyright 2013-2015 JEECG (jeecgos@163.com) | 
				
			|||
 * | 
				
			|||
 *  Licensed under the Apache License, Version 2.0 (the "License"); | 
				
			|||
 *  you may not use this file except in compliance with the License. | 
				
			|||
 *  You may obtain a copy of the License at | 
				
			|||
 * | 
				
			|||
 *     http://www.apache.org/licenses/LICENSE-2.0
 | 
				
			|||
 * | 
				
			|||
 *  Unless required by applicable law or agreed to in writing, software | 
				
			|||
 * distributed under the License is distributed on an "AS IS" BASIS, | 
				
			|||
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | 
				
			|||
 * See the License for the specific language governing permissions and | 
				
			|||
 * limitations under the License. | 
				
			|||
 */ | 
				
			|||
package cc.admin.poi.excel.entity.entity; | 
				
			|||
 | 
				
			|||
import cc.admin.poi.excel.entity.ExcelBaseParams; | 
				
			|||
import cc.admin.poi.handler.inter.IExcelVerifyHandler; | 
				
			|||
 | 
				
			|||
import java.util.List; | 
				
			|||
 | 
				
			|||
/** | 
				
			|||
 * 导入参数设置 | 
				
			|||
 * | 
				
			|||
 * @author JEECG | 
				
			|||
 * @date 2013-9-24 | 
				
			|||
 * @version 1.0 | 
				
			|||
 */ | 
				
			|||
public class ImportParams extends ExcelBaseParams { | 
				
			|||
	/** | 
				
			|||
	 * 表格标题行数,默认0 | 
				
			|||
	 */ | 
				
			|||
	private int titleRows = 0; | 
				
			|||
	/** | 
				
			|||
	 * 表头行数,默认1 | 
				
			|||
	 */ | 
				
			|||
	private int headRows = 1; | 
				
			|||
	/** | 
				
			|||
	 * 字段真正值和列标题之间的距离 默认0 | 
				
			|||
	 */ | 
				
			|||
	private int startRows = 0; | 
				
			|||
	/** | 
				
			|||
	 * 主键设置,如何这个cell没有值,就跳过 或者认为这个是list的下面的值 | 
				
			|||
	 */ | 
				
			|||
	private int keyIndex = 0; | 
				
			|||
	/** | 
				
			|||
	 * 上传表格需要读取的sheet 数量,默认为1 | 
				
			|||
	 */ | 
				
			|||
	private int sheetNum = 1; | 
				
			|||
	/** | 
				
			|||
	 * 是否需要保存上传的Excel,默认为false | 
				
			|||
	 */ | 
				
			|||
	private boolean needSave = false; | 
				
			|||
	/** | 
				
			|||
	 * 保存上传的Excel目录,默认是 如 TestEntity这个类保存路径就是 | 
				
			|||
	 * upload/excelUpload/Test/yyyyMMddHHmss_***** 保存名称上传时间_五位随机数 | 
				
			|||
	 */ | 
				
			|||
	private String saveUrl = "upload/excelUpload"; | 
				
			|||
	/** | 
				
			|||
	 * 校验处理接口 | 
				
			|||
	 */ | 
				
			|||
	private IExcelVerifyHandler verifyHanlder; | 
				
			|||
	/** | 
				
			|||
	 * 最后的无效行数 | 
				
			|||
	 */ | 
				
			|||
	private int lastOfInvalidRow = 0; | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 不需要解析的表头 只作为多表头展示,无字段与其绑定 | 
				
			|||
	 */ | 
				
			|||
	private List<String> ignoreHeaderList; | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 图片列 集合 | 
				
			|||
	 */ | 
				
			|||
	private List<String> imageList; | 
				
			|||
 | 
				
			|||
	public int getHeadRows() { | 
				
			|||
		return headRows; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public int getKeyIndex() { | 
				
			|||
		return keyIndex; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public String getSaveUrl() { | 
				
			|||
		return saveUrl; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public int getSheetNum() { | 
				
			|||
		return sheetNum; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public int getStartRows() { | 
				
			|||
		return startRows; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public int getTitleRows() { | 
				
			|||
		return titleRows; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public IExcelVerifyHandler getVerifyHanlder() { | 
				
			|||
		return verifyHanlder; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public boolean isNeedSave() { | 
				
			|||
		return needSave; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setHeadRows(int headRows) { | 
				
			|||
		this.headRows = headRows; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setKeyIndex(int keyIndex) { | 
				
			|||
		this.keyIndex = keyIndex; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setNeedSave(boolean needSave) { | 
				
			|||
		this.needSave = needSave; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setSaveUrl(String saveUrl) { | 
				
			|||
		this.saveUrl = saveUrl; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setSheetNum(int sheetNum) { | 
				
			|||
		this.sheetNum = sheetNum; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setStartRows(int startRows) { | 
				
			|||
		this.startRows = startRows; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setTitleRows(int titleRows) { | 
				
			|||
		this.titleRows = titleRows; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setVerifyHanlder(IExcelVerifyHandler verifyHanlder) { | 
				
			|||
		this.verifyHanlder = verifyHanlder; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public int getLastOfInvalidRow() { | 
				
			|||
		return lastOfInvalidRow; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setLastOfInvalidRow(int lastOfInvalidRow) { | 
				
			|||
		this.lastOfInvalidRow = lastOfInvalidRow; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public List<String> getImageList() { | 
				
			|||
		return imageList; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setImageList(List<String> imageList) { | 
				
			|||
		this.imageList = imageList; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public List<String> getIgnoreHeaderList() { | 
				
			|||
		return ignoreHeaderList; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setIgnoreHeaderList(List<String> ignoreHeaderList) { | 
				
			|||
		this.ignoreHeaderList = ignoreHeaderList; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 根据表头显示的文字 判断是否忽略该表头 | 
				
			|||
	 * @param text | 
				
			|||
	 * @return | 
				
			|||
	 */ | 
				
			|||
	public boolean isIgnoreHeader(String text){ | 
				
			|||
		if(ignoreHeaderList!=null && ignoreHeaderList.indexOf(text)>=0){ | 
				
			|||
			return true; | 
				
			|||
		} | 
				
			|||
		return false; | 
				
			|||
	} | 
				
			|||
} | 
				
			|||
@ -0,0 +1,210 @@ | 
				
			|||
/** | 
				
			|||
 * Copyright 2013-2015 JEECG (jeecgos@163.com) | 
				
			|||
 * | 
				
			|||
 *  Licensed under the Apache License, Version 2.0 (the "License"); | 
				
			|||
 *  you may not use this file except in compliance with the License. | 
				
			|||
 *  You may obtain a copy of the License at | 
				
			|||
 * | 
				
			|||
 *     http://www.apache.org/licenses/LICENSE-2.0
 | 
				
			|||
 * | 
				
			|||
 *  Unless required by applicable law or agreed to in writing, software | 
				
			|||
 * distributed under the License is distributed on an "AS IS" BASIS, | 
				
			|||
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | 
				
			|||
 * See the License for the specific language governing permissions and | 
				
			|||
 * limitations under the License. | 
				
			|||
 */ | 
				
			|||
package cc.admin.poi.excel.entity.entity; | 
				
			|||
 | 
				
			|||
import cc.admin.poi.excel.entity.ExcelBaseParams; | 
				
			|||
import cc.admin.poi.excel.export.styler.ExcelExportStylerDefaultImpl; | 
				
			|||
 | 
				
			|||
/** | 
				
			|||
 * 模板导出参数设置 | 
				
			|||
 * | 
				
			|||
 * @author JEECG | 
				
			|||
 * @date 2013-10-17 | 
				
			|||
 * @version 1.0 | 
				
			|||
 */ | 
				
			|||
public class TemplateExportParams extends ExcelBaseParams { | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 输出全部的sheet | 
				
			|||
	 */ | 
				
			|||
	private boolean scanAllsheet = false; | 
				
			|||
	/** | 
				
			|||
	 * 模板的路径 | 
				
			|||
	 */ | 
				
			|||
	private String templateUrl; | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 需要导出的第几个 sheetNum,默认是第0个 | 
				
			|||
	 */ | 
				
			|||
	private Integer[] sheetNum = new Integer[] { 0 }; | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 这只sheetName 不填就使用原来的 | 
				
			|||
	 */ | 
				
			|||
	private String[] sheetName; | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 表格列标题行数,默认1 | 
				
			|||
	 */ | 
				
			|||
	private int headingRows = 1; | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 表格列标题开始行,默认1 | 
				
			|||
	 */ | 
				
			|||
	private int headingStartRow = 1; | 
				
			|||
	/** | 
				
			|||
	 * 设置数据源的NUM | 
				
			|||
	 */ | 
				
			|||
	private int dataSheetNum = 0; | 
				
			|||
	/** | 
				
			|||
	 * Excel 导出style | 
				
			|||
	 */ | 
				
			|||
	private Class<?> style = ExcelExportStylerDefaultImpl.class; | 
				
			|||
	/** | 
				
			|||
	 * FOR EACH 用到的局部变量 | 
				
			|||
	 */ | 
				
			|||
	private String tempParams = "t"; | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 默认构造器 | 
				
			|||
	 */ | 
				
			|||
	public TemplateExportParams() { | 
				
			|||
 | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 构造器 | 
				
			|||
	 * | 
				
			|||
	 * @param templateUrl | 
				
			|||
	 *            模板路径 | 
				
			|||
	 * @param scanAllsheet | 
				
			|||
	 *            是否输出全部的sheet | 
				
			|||
	 * @param sheetName | 
				
			|||
	 *            sheet的名称,可不填 | 
				
			|||
	 */ | 
				
			|||
	public TemplateExportParams(String templateUrl, boolean scanAllsheet, String... sheetName) { | 
				
			|||
		this.templateUrl = templateUrl; | 
				
			|||
		this.scanAllsheet = scanAllsheet; | 
				
			|||
		if (sheetName != null && sheetName.length > 0) { | 
				
			|||
			this.sheetName = sheetName; | 
				
			|||
 | 
				
			|||
		} | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 构造器 | 
				
			|||
	 * | 
				
			|||
	 * @param templateUrl | 
				
			|||
	 *            模板路径 | 
				
			|||
	 * @param sheetNum | 
				
			|||
	 *            sheet 的位置,可不填 | 
				
			|||
	 */ | 
				
			|||
	public TemplateExportParams(String templateUrl, Integer... sheetNum) { | 
				
			|||
		this.templateUrl = templateUrl; | 
				
			|||
		if (sheetNum != null && sheetNum.length > 0) { | 
				
			|||
			this.sheetNum = sheetNum; | 
				
			|||
		} | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 单个sheet输出构造器 | 
				
			|||
	 * | 
				
			|||
	 * @param templateUrl | 
				
			|||
	 *            模板路径 | 
				
			|||
	 * @param sheetName | 
				
			|||
	 *            sheet的名称 | 
				
			|||
	 * @param sheetNum | 
				
			|||
	 *            sheet的位置,可不填 | 
				
			|||
	 */ | 
				
			|||
	public TemplateExportParams(String templateUrl, String sheetName, Integer... sheetNum) { | 
				
			|||
		this.templateUrl = templateUrl; | 
				
			|||
		this.sheetName = new String[] { sheetName }; | 
				
			|||
		if (sheetNum != null && sheetNum.length > 0) { | 
				
			|||
			this.sheetNum = sheetNum; | 
				
			|||
		} | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public int getHeadingRows() { | 
				
			|||
		return headingRows; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public int getHeadingStartRow() { | 
				
			|||
		return headingStartRow; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public String[] getSheetName() { | 
				
			|||
		return sheetName; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public Integer[] getSheetNum() { | 
				
			|||
		return sheetNum; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public String getTemplateUrl() { | 
				
			|||
		return templateUrl; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setHeadingRows(int headingRows) { | 
				
			|||
		this.headingRows = headingRows; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setHeadingStartRow(int headingStartRow) { | 
				
			|||
		this.headingStartRow = headingStartRow; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setSheetName(String[] sheetName) { | 
				
			|||
		this.sheetName = sheetName; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setSheetName(String sheetName) { | 
				
			|||
		this.sheetName = new String[] { sheetName }; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setSheetNum(Integer[] sheetNum) { | 
				
			|||
		this.sheetNum = sheetNum; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setSheetNum(Integer sheetNum) { | 
				
			|||
		this.sheetNum = new Integer[] { sheetNum }; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setTemplateUrl(String templateUrl) { | 
				
			|||
		this.templateUrl = templateUrl; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public Class<?> getStyle() { | 
				
			|||
		return style; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setStyle(Class<?> style) { | 
				
			|||
		this.style = style; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public int getDataSheetNum() { | 
				
			|||
		return dataSheetNum; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setDataSheetNum(int dataSheetNum) { | 
				
			|||
		this.dataSheetNum = dataSheetNum; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public boolean isScanAllsheet() { | 
				
			|||
		return scanAllsheet; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setScanAllsheet(boolean scanAllsheet) { | 
				
			|||
		this.scanAllsheet = scanAllsheet; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public String getTempParams() { | 
				
			|||
		return tempParams; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setTempParams(String tempParams) { | 
				
			|||
		this.tempParams = tempParams; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
} | 
				
			|||
@ -0,0 +1,28 @@ | 
				
			|||
/** | 
				
			|||
 * Copyright 2013-2015 JEECG (jeecgos@163.com) | 
				
			|||
 * | 
				
			|||
 *  Licensed under the Apache License, Version 2.0 (the "License"); | 
				
			|||
 *  you may not use this file except in compliance with the License. | 
				
			|||
 *  You may obtain a copy of the License at | 
				
			|||
 * | 
				
			|||
 *     http://www.apache.org/licenses/LICENSE-2.0
 | 
				
			|||
 * | 
				
			|||
 *  Unless required by applicable law or agreed to in writing, software | 
				
			|||
 * distributed under the License is distributed on an "AS IS" BASIS, | 
				
			|||
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | 
				
			|||
 * See the License for the specific language governing permissions and | 
				
			|||
 * limitations under the License. | 
				
			|||
 */ | 
				
			|||
package cc.admin.poi.excel.entity.entity.enmus; | 
				
			|||
 | 
				
			|||
/** | 
				
			|||
 * Cell 值得类型 | 
				
			|||
 * | 
				
			|||
 * @author JEECG | 
				
			|||
 * @date 2014年12月29日 下午10:20:49 | 
				
			|||
 */ | 
				
			|||
public enum CellValueType { | 
				
			|||
 | 
				
			|||
	String, Number, Boolean, Date, TElement, Null, None; | 
				
			|||
 | 
				
			|||
} | 
				
			|||
@ -0,0 +1,48 @@ | 
				
			|||
/** | 
				
			|||
 * Copyright 2013-2015 JEECG (jeecgos@163.com) | 
				
			|||
 * | 
				
			|||
 *  Licensed under the Apache License, Version 2.0 (the "License"); | 
				
			|||
 *  you may not use this file except in compliance with the License. | 
				
			|||
 *  You may obtain a copy of the License at | 
				
			|||
 * | 
				
			|||
 *     http://www.apache.org/licenses/LICENSE-2.0
 | 
				
			|||
 * | 
				
			|||
 *  Unless required by applicable law or agreed to in writing, software | 
				
			|||
 * distributed under the License is distributed on an "AS IS" BASIS, | 
				
			|||
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | 
				
			|||
 * See the License for the specific language governing permissions and | 
				
			|||
 * limitations under the License. | 
				
			|||
 */ | 
				
			|||
package cc.admin.poi.excel.entity.entity.enmus; | 
				
			|||
 | 
				
			|||
import cc.admin.poi.excel.export.styler.ExcelExportStylerBorderImpl; | 
				
			|||
import cc.admin.poi.excel.export.styler.ExcelExportStylerColorImpl; | 
				
			|||
import cc.admin.poi.excel.export.styler.ExcelExportStylerDefaultImpl; | 
				
			|||
 | 
				
			|||
/** | 
				
			|||
 * 插件提供的几个默认样式 | 
				
			|||
 * | 
				
			|||
 * @author JEECG | 
				
			|||
 * @date 2015年1月9日 下午9:02:24 | 
				
			|||
 */ | 
				
			|||
public enum ExcelStyleType { | 
				
			|||
 | 
				
			|||
	NONE("默认样式", ExcelExportStylerDefaultImpl.class), BORDER("边框样式", ExcelExportStylerBorderImpl.class), COLOR("间隔行样式", ExcelExportStylerColorImpl.class); | 
				
			|||
 | 
				
			|||
	private String name; | 
				
			|||
	private Class<?> clazz; | 
				
			|||
 | 
				
			|||
	ExcelStyleType(String name, Class<?> clazz) { | 
				
			|||
		this.name = name; | 
				
			|||
		this.clazz = clazz; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public Class<?> getClazz() { | 
				
			|||
		return clazz; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public String getName() { | 
				
			|||
		return name; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
} | 
				
			|||
@ -0,0 +1,28 @@ | 
				
			|||
/** | 
				
			|||
 * Copyright 2013-2015 JEECG (jeecgos@163.com) | 
				
			|||
 * | 
				
			|||
 *  Licensed under the Apache License, Version 2.0 (the "License"); | 
				
			|||
 *  you may not use this file except in compliance with the License. | 
				
			|||
 *  You may obtain a copy of the License at | 
				
			|||
 * | 
				
			|||
 *     http://www.apache.org/licenses/LICENSE-2.0
 | 
				
			|||
 * | 
				
			|||
 *  Unless required by applicable law or agreed to in writing, software | 
				
			|||
 * distributed under the License is distributed on an "AS IS" BASIS, | 
				
			|||
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | 
				
			|||
 * See the License for the specific language governing permissions and | 
				
			|||
 * limitations under the License. | 
				
			|||
 */ | 
				
			|||
package cc.admin.poi.excel.entity.entity.enmus; | 
				
			|||
 | 
				
			|||
/** | 
				
			|||
 * Excel Type | 
				
			|||
 * | 
				
			|||
 * @author JEECG | 
				
			|||
 * @date 2014年12月29日 下午9:08:21 | 
				
			|||
 */ | 
				
			|||
public enum ExcelType { | 
				
			|||
 | 
				
			|||
	HSSF, XSSF; | 
				
			|||
 | 
				
			|||
} | 
				
			|||
@ -0,0 +1,148 @@ | 
				
			|||
/** | 
				
			|||
 * Copyright 2013-2015 JEECG (jeecgos@163.com) | 
				
			|||
 * | 
				
			|||
 *  Licensed under the Apache License, Version 2.0 (the "License"); | 
				
			|||
 *  you may not use this file except in compliance with the License. | 
				
			|||
 *  You may obtain a copy of the License at | 
				
			|||
 * | 
				
			|||
 *     http://www.apache.org/licenses/LICENSE-2.0
 | 
				
			|||
 * | 
				
			|||
 *  Unless required by applicable law or agreed to in writing, software | 
				
			|||
 * distributed under the License is distributed on an "AS IS" BASIS, | 
				
			|||
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | 
				
			|||
 * See the License for the specific language governing permissions and | 
				
			|||
 * limitations under the License. | 
				
			|||
 */ | 
				
			|||
package cc.admin.poi.excel.entity.entity.params; | 
				
			|||
 | 
				
			|||
import java.lang.reflect.Method; | 
				
			|||
import java.util.List; | 
				
			|||
 | 
				
			|||
/** | 
				
			|||
 * Excel 导入导出基础对象类 | 
				
			|||
 * | 
				
			|||
 * @author JEECG | 
				
			|||
 * @date 2014年6月20日 下午2:26:09 | 
				
			|||
 */ | 
				
			|||
public class ExcelBaseEntity { | 
				
			|||
	/** | 
				
			|||
	 * 对应name | 
				
			|||
	 */ | 
				
			|||
	protected String name; | 
				
			|||
	/** | 
				
			|||
	 * 对应type | 
				
			|||
	 */ | 
				
			|||
	private int type = 1; | 
				
			|||
	/** | 
				
			|||
	 * 数据库格式 | 
				
			|||
	 */ | 
				
			|||
	private String databaseFormat; | 
				
			|||
	/** | 
				
			|||
	 * 导出日期格式 | 
				
			|||
	 */ | 
				
			|||
	private String format; | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 数字格式化,参数是Pattern,使用的对象是DecimalFormat | 
				
			|||
	 */ | 
				
			|||
	private String numFormat; | 
				
			|||
	/** | 
				
			|||
	 * 替换值表达式 :"男_1","女_0" | 
				
			|||
	 */ | 
				
			|||
	private String[] replace; | 
				
			|||
	/** | 
				
			|||
	 * 替换是否是替换多个值 | 
				
			|||
	 */ | 
				
			|||
	private boolean multiReplace; | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 表头组名称 | 
				
			|||
	 */ | 
				
			|||
	private String groupName; | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * set/get方法 | 
				
			|||
	 */ | 
				
			|||
	private Method method; | 
				
			|||
 | 
				
			|||
	private List<Method> methods; | 
				
			|||
 | 
				
			|||
	public String getDatabaseFormat() { | 
				
			|||
		return databaseFormat; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public String getFormat() { | 
				
			|||
		return format; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public Method getMethod() { | 
				
			|||
		return method; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public List<Method> getMethods() { | 
				
			|||
		return methods; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public String getName() { | 
				
			|||
		return name; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public String[] getReplace() { | 
				
			|||
		return replace; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public int getType() { | 
				
			|||
		return type; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setDatabaseFormat(String databaseFormat) { | 
				
			|||
		this.databaseFormat = databaseFormat; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setFormat(String format) { | 
				
			|||
		this.format = format; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setMethod(Method method) { | 
				
			|||
		this.method = method; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setMethods(List<Method> methods) { | 
				
			|||
		this.methods = methods; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setName(String name) { | 
				
			|||
		this.name = name; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setReplace(String[] replace) { | 
				
			|||
		this.replace = replace; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setType(int type) { | 
				
			|||
		this.type = type; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public boolean isMultiReplace() { | 
				
			|||
		return multiReplace; | 
				
			|||
	} | 
				
			|||
	public void setMultiReplace(boolean multiReplace) { | 
				
			|||
		this.multiReplace = multiReplace; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public String getNumFormat() { | 
				
			|||
		return numFormat; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setNumFormat(String numFormat) { | 
				
			|||
		this.numFormat = numFormat; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public String getGroupName() { | 
				
			|||
		return groupName; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setGroupName(String groupName) { | 
				
			|||
		this.groupName = groupName; | 
				
			|||
	} | 
				
			|||
} | 
				
			|||
@ -0,0 +1,79 @@ | 
				
			|||
/** | 
				
			|||
 * Copyright 2013-2015 JEECG (jeecgos@163.com) | 
				
			|||
 * | 
				
			|||
 *  Licensed under the Apache License, Version 2.0 (the "License"); | 
				
			|||
 *  you may not use this file except in compliance with the License. | 
				
			|||
 *  You may obtain a copy of the License at | 
				
			|||
 * | 
				
			|||
 *     http://www.apache.org/licenses/LICENSE-2.0
 | 
				
			|||
 * | 
				
			|||
 *  Unless required by applicable law or agreed to in writing, software | 
				
			|||
 * distributed under the License is distributed on an "AS IS" BASIS, | 
				
			|||
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | 
				
			|||
 * See the License for the specific language governing permissions and | 
				
			|||
 * limitations under the License. | 
				
			|||
 */ | 
				
			|||
package cc.admin.poi.excel.entity.entity.params; | 
				
			|||
 | 
				
			|||
import cc.admin.poi.excel.entity.params.ExcelImportEntity; | 
				
			|||
 | 
				
			|||
import java.util.Map; | 
				
			|||
 | 
				
			|||
/** | 
				
			|||
 * Excel 对于的 Collection | 
				
			|||
 * | 
				
			|||
 * @author JEECG | 
				
			|||
 * @date 2013-9-26 | 
				
			|||
 * @version 1.0 | 
				
			|||
 */ | 
				
			|||
public class ExcelCollectionParams { | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 集合对应的名称 | 
				
			|||
	 */ | 
				
			|||
	private String name; | 
				
			|||
	/** | 
				
			|||
	 * Excel 列名称 | 
				
			|||
	 */ | 
				
			|||
	private String excelName; | 
				
			|||
	/** | 
				
			|||
	 * 实体对象 | 
				
			|||
	 */ | 
				
			|||
	private Class<?> type; | 
				
			|||
	/** | 
				
			|||
	 * 这个list下面的参数集合实体对象 | 
				
			|||
	 */ | 
				
			|||
	private Map<String, cc.admin.poi.excel.entity.params.ExcelImportEntity> excelParams; | 
				
			|||
 | 
				
			|||
	public Map<String, cc.admin.poi.excel.entity.params.ExcelImportEntity> getExcelParams() { | 
				
			|||
		return excelParams; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public String getName() { | 
				
			|||
		return name; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public Class<?> getType() { | 
				
			|||
		return type; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setExcelParams(Map<String, ExcelImportEntity> excelParams) { | 
				
			|||
		this.excelParams = excelParams; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setName(String name) { | 
				
			|||
		this.name = name; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setType(Class<?> type) { | 
				
			|||
		this.type = type; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public String getExcelName() { | 
				
			|||
		return excelName; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setExcelName(String excelName) { | 
				
			|||
		this.excelName = excelName; | 
				
			|||
	} | 
				
			|||
} | 
				
			|||
@ -0,0 +1,295 @@ | 
				
			|||
/** | 
				
			|||
 * Copyright 2013-2015 JEECG (jeecgos@163.com) | 
				
			|||
 * | 
				
			|||
 *  Licensed under the Apache License, Version 2.0 (the "License"); | 
				
			|||
 *  you may not use this file except in compliance with the License. | 
				
			|||
 *  You may obtain a copy of the License at | 
				
			|||
 * | 
				
			|||
 *     http://www.apache.org/licenses/LICENSE-2.0
 | 
				
			|||
 * | 
				
			|||
 *  Unless required by applicable law or agreed to in writing, software | 
				
			|||
 * distributed under the License is distributed on an "AS IS" BASIS, | 
				
			|||
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | 
				
			|||
 * See the License for the specific language governing permissions and | 
				
			|||
 * limitations under the License. | 
				
			|||
 */ | 
				
			|||
package cc.admin.poi.excel.entity.entity.params; | 
				
			|||
 | 
				
			|||
import cc.admin.poi.excel.entity.params.ExcelBaseEntity; | 
				
			|||
 | 
				
			|||
import java.util.ArrayList; | 
				
			|||
import java.util.List; | 
				
			|||
 | 
				
			|||
/** | 
				
			|||
 * excel 导出工具类,对cell类型做映射 | 
				
			|||
 * | 
				
			|||
 * @author JEECG | 
				
			|||
 * @version 1.0 2013年8月24日 | 
				
			|||
 */ | 
				
			|||
public class ExcelExportEntity extends ExcelBaseEntity implements Comparable<ExcelExportEntity> { | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 如果是MAP导出,这个是map的key | 
				
			|||
	 */ | 
				
			|||
	private Object key; | 
				
			|||
 | 
				
			|||
	private double width = 10; | 
				
			|||
 | 
				
			|||
	private double height = 10; | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 图片的类型,1是文件地址(class目录),2是数据库字节,3是文件地址(磁盘目录),4网络图片 | 
				
			|||
	 */ | 
				
			|||
	private int exportImageType = 3; | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 图片储存位置(磁盘目录) 用于导出获取图片绝对路径 | 
				
			|||
	 */ | 
				
			|||
	private String imageBasePath; | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 排序顺序 | 
				
			|||
	 */ | 
				
			|||
	private int orderNum = 0; | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 是否支持换行 | 
				
			|||
	 */ | 
				
			|||
	private boolean isWrap; | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 是否需要合并 | 
				
			|||
	 */ | 
				
			|||
	private boolean needMerge; | 
				
			|||
	/** | 
				
			|||
	 * 单元格纵向合并 | 
				
			|||
	 */ | 
				
			|||
	private boolean mergeVertical; | 
				
			|||
	/** | 
				
			|||
	 * 合并依赖 | 
				
			|||
	 */ | 
				
			|||
	private int[] mergeRely; | 
				
			|||
	/** | 
				
			|||
	 * 后缀 | 
				
			|||
	 */ | 
				
			|||
	private String suffix; | 
				
			|||
	/** | 
				
			|||
	 * 统计 | 
				
			|||
	 */ | 
				
			|||
	private boolean isStatistics; | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 是否横向合并 | 
				
			|||
	 */ | 
				
			|||
	private boolean colspan; | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 被横向合并的列名称 | 
				
			|||
	 */ | 
				
			|||
	private List<String> subColumnList; | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 父表头的名称 | 
				
			|||
	 */ | 
				
			|||
	private String groupName; | 
				
			|||
 | 
				
			|||
	private List<ExcelExportEntity> list; | 
				
			|||
 | 
				
			|||
	public ExcelExportEntity() { | 
				
			|||
 | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public ExcelExportEntity(String name) { | 
				
			|||
		super.name = name; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public ExcelExportEntity(String name, Object key) { | 
				
			|||
		super.name = name; | 
				
			|||
		this.key = key; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 构造器 | 
				
			|||
	 * @param name 描述-文字 | 
				
			|||
	 * @param key 存储key 如果是MAP导出,这个是map的key | 
				
			|||
	 * @param colspan 是否为合并列(a,b列公用一个表头c,则a,b,c都需要设置为true) | 
				
			|||
	 */ | 
				
			|||
	public ExcelExportEntity(String name, Object key, boolean colspan) { | 
				
			|||
		super.name = name; | 
				
			|||
		this.key = key; | 
				
			|||
		this.colspan = colspan; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public ExcelExportEntity(String name, Object key, int width) { | 
				
			|||
		super.name = name; | 
				
			|||
		this.width = width; | 
				
			|||
		this.key = key; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public int getExportImageType() { | 
				
			|||
		return exportImageType; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public double getHeight() { | 
				
			|||
		return height; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public Object getKey() { | 
				
			|||
		return key; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public List<ExcelExportEntity> getList() { | 
				
			|||
		return list; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public int[] getMergeRely() { | 
				
			|||
		return mergeRely == null ? new int[0] : mergeRely; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public int getOrderNum() { | 
				
			|||
		return orderNum; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public double getWidth() { | 
				
			|||
		return width; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public boolean isMergeVertical() { | 
				
			|||
		return mergeVertical; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public boolean isNeedMerge() { | 
				
			|||
		return needMerge; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public boolean isWrap() { | 
				
			|||
		return isWrap; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setExportImageType(int exportImageType) { | 
				
			|||
		this.exportImageType = exportImageType; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setHeight(double height) { | 
				
			|||
		this.height = height; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setKey(Object key) { | 
				
			|||
		this.key = key; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setList(List<ExcelExportEntity> list) { | 
				
			|||
		this.list = list; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setMergeRely(int[] mergeRely) { | 
				
			|||
		this.mergeRely = mergeRely; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setMergeVertical(boolean mergeVertical) { | 
				
			|||
		this.mergeVertical = mergeVertical; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setNeedMerge(boolean needMerge) { | 
				
			|||
		this.needMerge = needMerge; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setOrderNum(int orderNum) { | 
				
			|||
		this.orderNum = orderNum; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setWidth(double width) { | 
				
			|||
		this.width = width; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setWrap(boolean isWrap) { | 
				
			|||
		this.isWrap = isWrap; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public String getSuffix() { | 
				
			|||
		return suffix; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setSuffix(String suffix) { | 
				
			|||
		this.suffix = suffix; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public boolean isStatistics() { | 
				
			|||
		return isStatistics; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setStatistics(boolean isStatistics) { | 
				
			|||
		this.isStatistics = isStatistics; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public String getImageBasePath() { | 
				
			|||
		return imageBasePath; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setImageBasePath(String imageBasePath) { | 
				
			|||
		this.imageBasePath = imageBasePath; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public boolean isColspan() { | 
				
			|||
		return colspan; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setColspan(boolean colspan) { | 
				
			|||
		this.colspan = colspan; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public List<String> getSubColumnList() { | 
				
			|||
		return subColumnList; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setSubColumnList(List<String> subColumnList) { | 
				
			|||
		this.subColumnList = subColumnList; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public String getGroupName() { | 
				
			|||
		return groupName; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setGroupName(String groupName) { | 
				
			|||
		this.groupName = groupName; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 是否为合并子列 | 
				
			|||
	 * @return | 
				
			|||
	 */ | 
				
			|||
	public boolean isSubColumn(){ | 
				
			|||
		return this.colspan && (this.subColumnList==null || this.subColumnList.size()==0); | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 是否为合并父列 | 
				
			|||
	 * @return | 
				
			|||
	 */ | 
				
			|||
	public boolean isMergeColumn(){ | 
				
			|||
		return this.colspan && this.subColumnList!=null && this.subColumnList.size()>0; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 获取被合并的子列 | 
				
			|||
	 * @param all | 
				
			|||
	 * @return | 
				
			|||
	 */ | 
				
			|||
	public List<ExcelExportEntity> initSubExportEntity(List<ExcelExportEntity> all){ | 
				
			|||
		List<ExcelExportEntity> sub = new ArrayList<ExcelExportEntity>(); | 
				
			|||
		for (ExcelExportEntity temp : all) { | 
				
			|||
			if(this.subColumnList.contains(temp.getKey())){ | 
				
			|||
				sub.add(temp); | 
				
			|||
			} | 
				
			|||
		} | 
				
			|||
		this.setList(sub); | 
				
			|||
		return sub; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	@Override | 
				
			|||
	public int compareTo(ExcelExportEntity prev) { | 
				
			|||
		return this.getOrderNum() - prev.getOrderNum(); | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
} | 
				
			|||
@ -0,0 +1,113 @@ | 
				
			|||
/** | 
				
			|||
 * Copyright 2013-2015 JEECG (jeecgos@163.com) | 
				
			|||
 * | 
				
			|||
 *  Licensed under the Apache License, Version 2.0 (the "License"); | 
				
			|||
 *  you may not use this file except in compliance with the License. | 
				
			|||
 *  You may obtain a copy of the License at | 
				
			|||
 * | 
				
			|||
 *     http://www.apache.org/licenses/LICENSE-2.0
 | 
				
			|||
 * | 
				
			|||
 *  Unless required by applicable law or agreed to in writing, software | 
				
			|||
 * distributed under the License is distributed on an "AS IS" BASIS, | 
				
			|||
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | 
				
			|||
 * See the License for the specific language governing permissions and | 
				
			|||
 * limitations under the License. | 
				
			|||
 */ | 
				
			|||
package cc.admin.poi.excel.entity.entity.params; | 
				
			|||
 | 
				
			|||
import cc.admin.poi.excel.entity.params.ExcelBaseEntity; | 
				
			|||
import cc.admin.poi.excel.entity.params.ExcelVerifyEntity; | 
				
			|||
 | 
				
			|||
import java.util.List; | 
				
			|||
 | 
				
			|||
/** | 
				
			|||
 * excel 导入工具类,对cell类型做映射 | 
				
			|||
 * | 
				
			|||
 * @author JEECG | 
				
			|||
 * @version 1.0 2013年8月24日 | 
				
			|||
 */ | 
				
			|||
public class ExcelImportEntity extends ExcelBaseEntity { | 
				
			|||
	/** | 
				
			|||
	 * 对应 Collection NAME | 
				
			|||
	 */ | 
				
			|||
	private String collectionName; | 
				
			|||
	/** | 
				
			|||
	 * 保存图片的地址 当saveType设置为3/4时,此值可以设置为:local,minio,alioss | 
				
			|||
	 */ | 
				
			|||
	private String saveUrl; | 
				
			|||
	/** | 
				
			|||
	 * 保存图片的类型,1是文件_old,2是数据库字节,3文件地址_new,4网络地址 | 
				
			|||
	 */ | 
				
			|||
	private int saveType; | 
				
			|||
	/** | 
				
			|||
	 * 对应exportType | 
				
			|||
	 */ | 
				
			|||
	private String classType; | 
				
			|||
	/** | 
				
			|||
	 * 校驗參數 | 
				
			|||
	 */ | 
				
			|||
	private ExcelVerifyEntity verify; | 
				
			|||
	/** | 
				
			|||
	 * 后缀 | 
				
			|||
	 */ | 
				
			|||
	private String suffix; | 
				
			|||
 | 
				
			|||
	private List<ExcelImportEntity> list; | 
				
			|||
 | 
				
			|||
	public String getClassType() { | 
				
			|||
		return classType; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public String getCollectionName() { | 
				
			|||
		return collectionName; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public List<ExcelImportEntity> getList() { | 
				
			|||
		return list; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public int getSaveType() { | 
				
			|||
		return saveType; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public String getSaveUrl() { | 
				
			|||
		return saveUrl; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public ExcelVerifyEntity getVerify() { | 
				
			|||
		return verify; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setClassType(String classType) { | 
				
			|||
		this.classType = classType; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setCollectionName(String collectionName) { | 
				
			|||
		this.collectionName = collectionName; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setList(List<ExcelImportEntity> list) { | 
				
			|||
		this.list = list; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setSaveType(int saveType) { | 
				
			|||
		this.saveType = saveType; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setSaveUrl(String saveUrl) { | 
				
			|||
		this.saveUrl = saveUrl; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setVerify(ExcelVerifyEntity verify) { | 
				
			|||
		this.verify = verify; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public String getSuffix() { | 
				
			|||
		return suffix; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setSuffix(String suffix) { | 
				
			|||
		this.suffix = suffix; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
} | 
				
			|||
@ -0,0 +1,66 @@ | 
				
			|||
package cc.admin.poi.excel.entity.entity.params; | 
				
			|||
 | 
				
			|||
import org.apache.poi.ss.usermodel.CellStyle; | 
				
			|||
 | 
				
			|||
import java.io.Serializable; | 
				
			|||
 | 
				
			|||
/** | 
				
			|||
 * 模板便利是的参数 | 
				
			|||
 * | 
				
			|||
 * @author JEECG | 
				
			|||
 * @date 2015年4月29日 下午9:22:48 | 
				
			|||
 */ | 
				
			|||
public class ExcelTemplateParams implements Serializable { | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
     * | 
				
			|||
     */ | 
				
			|||
	private static final long serialVersionUID = 1L; | 
				
			|||
	/** | 
				
			|||
	 * key | 
				
			|||
	 */ | 
				
			|||
	private String name; | 
				
			|||
	/** | 
				
			|||
	 * 模板的cellStyle | 
				
			|||
	 */ | 
				
			|||
	private CellStyle cellStyle; | 
				
			|||
	/** | 
				
			|||
	 * 行高 | 
				
			|||
	 */ | 
				
			|||
	private short height; | 
				
			|||
 | 
				
			|||
	public ExcelTemplateParams() { | 
				
			|||
 | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public ExcelTemplateParams(String name, CellStyle cellStyle, short height) { | 
				
			|||
		this.name = name; | 
				
			|||
		this.cellStyle = cellStyle; | 
				
			|||
		this.height = height; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public String getName() { | 
				
			|||
		return name; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setName(String name) { | 
				
			|||
		this.name = name; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public CellStyle getCellStyle() { | 
				
			|||
		return cellStyle; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setCellStyle(CellStyle cellStyle) { | 
				
			|||
		this.cellStyle = cellStyle; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public short getHeight() { | 
				
			|||
		return height; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setHeight(short height) { | 
				
			|||
		this.height = height; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
} | 
				
			|||
@ -0,0 +1,159 @@ | 
				
			|||
/** | 
				
			|||
 * Copyright 2013-2015 JEECG (jeecgos@163.com) | 
				
			|||
 * | 
				
			|||
 *  Licensed under the Apache License, Version 2.0 (the "License"); | 
				
			|||
 *  you may not use this file except in compliance with the License. | 
				
			|||
 *  You may obtain a copy of the License at | 
				
			|||
 * | 
				
			|||
 *     http://www.apache.org/licenses/LICENSE-2.0
 | 
				
			|||
 * | 
				
			|||
 *  Unless required by applicable law or agreed to in writing, software | 
				
			|||
 * distributed under the License is distributed on an "AS IS" BASIS, | 
				
			|||
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | 
				
			|||
 * See the License for the specific language governing permissions and | 
				
			|||
 * limitations under the License. | 
				
			|||
 */ | 
				
			|||
package cc.admin.poi.excel.entity.entity.params; | 
				
			|||
 | 
				
			|||
/** | 
				
			|||
 * Excel 校验对象 | 
				
			|||
 * | 
				
			|||
 * @author JEECG | 
				
			|||
 * @date 2014年6月29日 下午4:24:59 | 
				
			|||
 */ | 
				
			|||
public class ExcelVerifyEntity { | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 接口校验 | 
				
			|||
	 * | 
				
			|||
	 * @return | 
				
			|||
	 */ | 
				
			|||
	private boolean interHandler; | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 不允许空 | 
				
			|||
	 * | 
				
			|||
	 * @return | 
				
			|||
	 */ | 
				
			|||
	private boolean notNull; | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 是13位移动电话 | 
				
			|||
	 * | 
				
			|||
	 * @return | 
				
			|||
	 */ | 
				
			|||
	private boolean isMobile; | 
				
			|||
	/** | 
				
			|||
	 * 是座机号码 | 
				
			|||
	 * | 
				
			|||
	 * @return | 
				
			|||
	 */ | 
				
			|||
	private boolean isTel; | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 是电子邮件 | 
				
			|||
	 * | 
				
			|||
	 * @return | 
				
			|||
	 */ | 
				
			|||
	private boolean isEmail; | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 最小长度 | 
				
			|||
	 * | 
				
			|||
	 * @return | 
				
			|||
	 */ | 
				
			|||
	private int minLength; | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 最大长度 | 
				
			|||
	 * | 
				
			|||
	 * @return | 
				
			|||
	 */ | 
				
			|||
	private int maxLength; | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 正在表达式 | 
				
			|||
	 * | 
				
			|||
	 * @return | 
				
			|||
	 */ | 
				
			|||
	private String regex; | 
				
			|||
	/** | 
				
			|||
	 * 正在表达式,错误提示信息 | 
				
			|||
	 * | 
				
			|||
	 * @return | 
				
			|||
	 */ | 
				
			|||
	private String regexTip; | 
				
			|||
 | 
				
			|||
	public int getMaxLength() { | 
				
			|||
		return maxLength; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public int getMinLength() { | 
				
			|||
		return minLength; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public String getRegex() { | 
				
			|||
		return regex; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public String getRegexTip() { | 
				
			|||
		return regexTip; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public boolean isEmail() { | 
				
			|||
		return isEmail; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public boolean isInterHandler() { | 
				
			|||
		return interHandler; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public boolean isMobile() { | 
				
			|||
		return isMobile; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public boolean isNotNull() { | 
				
			|||
		return notNull; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public boolean isTel() { | 
				
			|||
		return isTel; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setEmail(boolean isEmail) { | 
				
			|||
		this.isEmail = isEmail; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setInterHandler(boolean interHandler) { | 
				
			|||
		this.interHandler = interHandler; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setMaxLength(int maxLength) { | 
				
			|||
		this.maxLength = maxLength; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setMinLength(int minLength) { | 
				
			|||
		this.minLength = minLength; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setMobile(boolean isMobile) { | 
				
			|||
		this.isMobile = isMobile; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setNotNull(boolean notNull) { | 
				
			|||
		this.notNull = notNull; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setRegex(String regex) { | 
				
			|||
		this.regex = regex; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setRegexTip(String regexTip) { | 
				
			|||
		this.regexTip = regexTip; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setTel(boolean isTel) { | 
				
			|||
		this.isTel = isTel; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
} | 
				
			|||
@ -0,0 +1,84 @@ | 
				
			|||
/** | 
				
			|||
 * Copyright 2013-2015 JEECG (jeecgos@163.com) | 
				
			|||
 * | 
				
			|||
 *  Licensed under the Apache License, Version 2.0 (the "License"); | 
				
			|||
 *  you may not use this file except in compliance with the License. | 
				
			|||
 *  You may obtain a copy of the License at | 
				
			|||
 * | 
				
			|||
 *     http://www.apache.org/licenses/LICENSE-2.0
 | 
				
			|||
 * | 
				
			|||
 *  Unless required by applicable law or agreed to in writing, software | 
				
			|||
 * distributed under the License is distributed on an "AS IS" BASIS, | 
				
			|||
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | 
				
			|||
 * See the License for the specific language governing permissions and | 
				
			|||
 * limitations under the License. | 
				
			|||
 */ | 
				
			|||
package cc.admin.poi.excel.entity.entity.params; | 
				
			|||
 | 
				
			|||
import java.util.List; | 
				
			|||
 | 
				
			|||
/** | 
				
			|||
 * 合并单元格使用对象 | 
				
			|||
 * | 
				
			|||
 * Created by jue on 14-6-11. | 
				
			|||
 */ | 
				
			|||
public class MergeEntity { | 
				
			|||
	/** | 
				
			|||
	 * 合并开始行 | 
				
			|||
	 */ | 
				
			|||
	private int startRow; | 
				
			|||
	/** | 
				
			|||
	 * 合并结束行 | 
				
			|||
	 */ | 
				
			|||
	private int endRow; | 
				
			|||
	/** | 
				
			|||
	 * 文字 | 
				
			|||
	 */ | 
				
			|||
	private String text; | 
				
			|||
	/** | 
				
			|||
	 * 依赖关系文本 | 
				
			|||
	 */ | 
				
			|||
	private List<String> relyList; | 
				
			|||
 | 
				
			|||
	public MergeEntity() { | 
				
			|||
 | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public MergeEntity(String text, int startRow, int endRow) { | 
				
			|||
		this.text = text; | 
				
			|||
		this.endRow = endRow; | 
				
			|||
		this.startRow = startRow; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public int getEndRow() { | 
				
			|||
		return endRow; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public List<String> getRelyList() { | 
				
			|||
		return relyList; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public int getStartRow() { | 
				
			|||
		return startRow; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public String getText() { | 
				
			|||
		return text; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setEndRow(int endRow) { | 
				
			|||
		this.endRow = endRow; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setRelyList(List<String> relyList) { | 
				
			|||
		this.relyList = relyList; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setStartRow(int startRow) { | 
				
			|||
		this.startRow = startRow; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setText(String text) { | 
				
			|||
		this.text = text; | 
				
			|||
	} | 
				
			|||
} | 
				
			|||
@ -0,0 +1,79 @@ | 
				
			|||
/** | 
				
			|||
 * Copyright 2013-2015 JEECG (jeecgos@163.com) | 
				
			|||
 * | 
				
			|||
 *  Licensed under the Apache License, Version 2.0 (the "License"); | 
				
			|||
 *  you may not use this file except in compliance with the License. | 
				
			|||
 *  You may obtain a copy of the License at | 
				
			|||
 * | 
				
			|||
 *     http://www.apache.org/licenses/LICENSE-2.0
 | 
				
			|||
 * | 
				
			|||
 *  Unless required by applicable law or agreed to in writing, software | 
				
			|||
 * distributed under the License is distributed on an "AS IS" BASIS, | 
				
			|||
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | 
				
			|||
 * See the License for the specific language governing permissions and | 
				
			|||
 * limitations under the License. | 
				
			|||
 */ | 
				
			|||
package cc.admin.poi.excel.entity.entity.result; | 
				
			|||
 | 
				
			|||
import org.apache.poi.ss.usermodel.Workbook; | 
				
			|||
 | 
				
			|||
import java.util.List; | 
				
			|||
 | 
				
			|||
/** | 
				
			|||
 * 导入返回类 | 
				
			|||
 * | 
				
			|||
 * @author JEECG | 
				
			|||
 * @date 2014年6月29日 下午5:12:10 | 
				
			|||
 */ | 
				
			|||
public class ExcelImportResult<T> { | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 结果集 | 
				
			|||
	 */ | 
				
			|||
	private List<T> list; | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 是否存在校验失败 | 
				
			|||
	 */ | 
				
			|||
	private boolean verfiyFail; | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 数据源 | 
				
			|||
	 */ | 
				
			|||
	private Workbook workbook; | 
				
			|||
 | 
				
			|||
	public ExcelImportResult() { | 
				
			|||
 | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public ExcelImportResult(List<T> list, boolean verfiyFail, Workbook workbook) { | 
				
			|||
		this.list = list; | 
				
			|||
		this.verfiyFail = verfiyFail; | 
				
			|||
		this.workbook = workbook; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public List<T> getList() { | 
				
			|||
		return list; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public Workbook getWorkbook() { | 
				
			|||
		return workbook; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public boolean isVerfiyFail() { | 
				
			|||
		return verfiyFail; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setList(List<T> list) { | 
				
			|||
		this.list = list; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setVerfiyFail(boolean verfiyFail) { | 
				
			|||
		this.verfiyFail = verfiyFail; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setWorkbook(Workbook workbook) { | 
				
			|||
		this.workbook = workbook; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
} | 
				
			|||
@ -0,0 +1,63 @@ | 
				
			|||
/** | 
				
			|||
 * Copyright 2013-2015 JEECG (jeecgos@163.com) | 
				
			|||
 * | 
				
			|||
 *  Licensed under the Apache License, Version 2.0 (the "License"); | 
				
			|||
 *  you may not use this file except in compliance with the License. | 
				
			|||
 *  You may obtain a copy of the License at | 
				
			|||
 * | 
				
			|||
 *     http://www.apache.org/licenses/LICENSE-2.0
 | 
				
			|||
 * | 
				
			|||
 *  Unless required by applicable law or agreed to in writing, software | 
				
			|||
 * distributed under the License is distributed on an "AS IS" BASIS, | 
				
			|||
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | 
				
			|||
 * See the License for the specific language governing permissions and | 
				
			|||
 * limitations under the License. | 
				
			|||
 */ | 
				
			|||
package cc.admin.poi.excel.entity.entity.result; | 
				
			|||
 | 
				
			|||
/** | 
				
			|||
 * Excel导入处理返回结果 | 
				
			|||
 * | 
				
			|||
 * @author JEECG | 
				
			|||
 * @date 2014年6月23日 下午11:03:29 | 
				
			|||
 */ | 
				
			|||
public class ExcelVerifyHanlderResult { | 
				
			|||
	/** | 
				
			|||
	 * 是否正确 | 
				
			|||
	 */ | 
				
			|||
	private boolean success; | 
				
			|||
	/** | 
				
			|||
	 * 错误信息 | 
				
			|||
	 */ | 
				
			|||
	private String msg; | 
				
			|||
 | 
				
			|||
	public ExcelVerifyHanlderResult() { | 
				
			|||
 | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public ExcelVerifyHanlderResult(boolean success) { | 
				
			|||
		this.success = success; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public ExcelVerifyHanlderResult(boolean success, String msg) { | 
				
			|||
		this.success = success; | 
				
			|||
		this.msg = msg; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public String getMsg() { | 
				
			|||
		return msg; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public boolean isSuccess() { | 
				
			|||
		return success; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setMsg(String msg) { | 
				
			|||
		this.msg = msg; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setSuccess(boolean success) { | 
				
			|||
		this.success = success; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
} | 
				
			|||
@ -0,0 +1,62 @@ | 
				
			|||
/** | 
				
			|||
 * Copyright 2013-2015 JEECG (jeecgos@163.com) | 
				
			|||
 * | 
				
			|||
 *  Licensed under the Apache License, Version 2.0 (the "License"); | 
				
			|||
 *  you may not use this file except in compliance with the License. | 
				
			|||
 *  You may obtain a copy of the License at | 
				
			|||
 * | 
				
			|||
 *     http://www.apache.org/licenses/LICENSE-2.0
 | 
				
			|||
 * | 
				
			|||
 *  Unless required by applicable law or agreed to in writing, software | 
				
			|||
 * distributed under the License is distributed on an "AS IS" BASIS, | 
				
			|||
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | 
				
			|||
 * See the License for the specific language governing permissions and | 
				
			|||
 * limitations under the License. | 
				
			|||
 */ | 
				
			|||
package cc.admin.poi.excel.entity.entity.sax; | 
				
			|||
 | 
				
			|||
import cc.admin.poi.excel.entity.enmus.CellValueType; | 
				
			|||
 | 
				
			|||
/** | 
				
			|||
 * Cell 对象 | 
				
			|||
 * | 
				
			|||
 * @author JEECG | 
				
			|||
 * @date 2014年12月29日 下午10:12:57 | 
				
			|||
 */ | 
				
			|||
public class SaxReadCellEntity { | 
				
			|||
	/** | 
				
			|||
	 * 值类型 | 
				
			|||
	 */ | 
				
			|||
	private CellValueType cellType; | 
				
			|||
	/** | 
				
			|||
	 * 值 | 
				
			|||
	 */ | 
				
			|||
	private Object value; | 
				
			|||
 | 
				
			|||
	public SaxReadCellEntity(CellValueType cellType, Object value) { | 
				
			|||
		this.cellType = cellType; | 
				
			|||
		this.value = value; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public CellValueType getCellType() { | 
				
			|||
		return cellType; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setCellType(CellValueType cellType) { | 
				
			|||
		this.cellType = cellType; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public Object getValue() { | 
				
			|||
		return value; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setValue(Object value) { | 
				
			|||
		this.value = value; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	@Override | 
				
			|||
	public String toString() { | 
				
			|||
		return "[type=" + cellType.toString() + ",value=" + value + "]"; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
} | 
				
			|||
@ -0,0 +1,43 @@ | 
				
			|||
/** | 
				
			|||
 * Copyright 2013-2015 JEECG (jeecgos@163.com) | 
				
			|||
 * | 
				
			|||
 *  Licensed under the Apache License, Version 2.0 (the "License"); | 
				
			|||
 *  you may not use this file except in compliance with the License. | 
				
			|||
 *  You may obtain a copy of the License at | 
				
			|||
 * | 
				
			|||
 *     http://www.apache.org/licenses/LICENSE-2.0
 | 
				
			|||
 * | 
				
			|||
 *  Unless required by applicable law or agreed to in writing, software | 
				
			|||
 * distributed under the License is distributed on an "AS IS" BASIS, | 
				
			|||
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | 
				
			|||
 * See the License for the specific language governing permissions and | 
				
			|||
 * limitations under the License. | 
				
			|||
 */ | 
				
			|||
package cc.admin.poi.excel.entity.entity.vo; | 
				
			|||
 | 
				
			|||
/** | 
				
			|||
 * 基础常量 Created by jue on 14-4-21. | 
				
			|||
 */ | 
				
			|||
public interface PoiBaseConstants { | 
				
			|||
	/** | 
				
			|||
	 * 字段属性对应方法 | 
				
			|||
	 */ | 
				
			|||
	public static String GET = "get"; | 
				
			|||
	/** | 
				
			|||
	 * 字段属性对应方法 | 
				
			|||
	 */ | 
				
			|||
	public static String SET = "set"; | 
				
			|||
	/** | 
				
			|||
	 * 字段属性对应方法 | 
				
			|||
	 */ | 
				
			|||
	public static String IS = "is"; | 
				
			|||
	/** | 
				
			|||
	 * 是否增加属性列 | 
				
			|||
	 */ | 
				
			|||
	public static String IS_ADD_INDEX = "isAddIndex"; | 
				
			|||
	/** | 
				
			|||
	 * 字段属性对应convert方法 | 
				
			|||
	 */ | 
				
			|||
	public static String CONVERT = "convert"; | 
				
			|||
 | 
				
			|||
} | 
				
			|||
@ -0,0 +1,148 @@ | 
				
			|||
/** | 
				
			|||
 * Copyright 2013-2015 JEECG (jeecgos@163.com) | 
				
			|||
 * | 
				
			|||
 *  Licensed under the Apache License, Version 2.0 (the "License"); | 
				
			|||
 *  you may not use this file except in compliance with the License. | 
				
			|||
 *  You may obtain a copy of the License at | 
				
			|||
 * | 
				
			|||
 *     http://www.apache.org/licenses/LICENSE-2.0
 | 
				
			|||
 * | 
				
			|||
 *  Unless required by applicable law or agreed to in writing, software | 
				
			|||
 * distributed under the License is distributed on an "AS IS" BASIS, | 
				
			|||
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | 
				
			|||
 * See the License for the specific language governing permissions and | 
				
			|||
 * limitations under the License. | 
				
			|||
 */ | 
				
			|||
package cc.admin.poi.excel.entity.params; | 
				
			|||
 | 
				
			|||
import java.lang.reflect.Method; | 
				
			|||
import java.util.List; | 
				
			|||
 | 
				
			|||
/** | 
				
			|||
 * Excel 导入导出基础对象类 | 
				
			|||
 * | 
				
			|||
 * @author JEECG | 
				
			|||
 * @date 2014年6月20日 下午2:26:09 | 
				
			|||
 */ | 
				
			|||
public class ExcelBaseEntity { | 
				
			|||
	/** | 
				
			|||
	 * 对应name | 
				
			|||
	 */ | 
				
			|||
	protected String name; | 
				
			|||
	/** | 
				
			|||
	 * 对应type | 
				
			|||
	 */ | 
				
			|||
	private int type = 1; | 
				
			|||
	/** | 
				
			|||
	 * 数据库格式 | 
				
			|||
	 */ | 
				
			|||
	private String databaseFormat; | 
				
			|||
	/** | 
				
			|||
	 * 导出日期格式 | 
				
			|||
	 */ | 
				
			|||
	private String format; | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 数字格式化,参数是Pattern,使用的对象是DecimalFormat | 
				
			|||
	 */ | 
				
			|||
	private String numFormat; | 
				
			|||
	/** | 
				
			|||
	 * 替换值表达式 :"男_1","女_0" | 
				
			|||
	 */ | 
				
			|||
	private String[] replace; | 
				
			|||
	/** | 
				
			|||
	 * 替换是否是替换多个值 | 
				
			|||
	 */ | 
				
			|||
	private boolean multiReplace; | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 表头组名称 | 
				
			|||
	 */ | 
				
			|||
	private String groupName; | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * set/get方法 | 
				
			|||
	 */ | 
				
			|||
	private Method method; | 
				
			|||
 | 
				
			|||
	private List<Method> methods; | 
				
			|||
 | 
				
			|||
	public String getDatabaseFormat() { | 
				
			|||
		return databaseFormat; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public String getFormat() { | 
				
			|||
		return format; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public Method getMethod() { | 
				
			|||
		return method; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public List<Method> getMethods() { | 
				
			|||
		return methods; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public String getName() { | 
				
			|||
		return name; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public String[] getReplace() { | 
				
			|||
		return replace; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public int getType() { | 
				
			|||
		return type; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setDatabaseFormat(String databaseFormat) { | 
				
			|||
		this.databaseFormat = databaseFormat; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setFormat(String format) { | 
				
			|||
		this.format = format; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setMethod(Method method) { | 
				
			|||
		this.method = method; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setMethods(List<Method> methods) { | 
				
			|||
		this.methods = methods; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setName(String name) { | 
				
			|||
		this.name = name; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setReplace(String[] replace) { | 
				
			|||
		this.replace = replace; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setType(int type) { | 
				
			|||
		this.type = type; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public boolean isMultiReplace() { | 
				
			|||
		return multiReplace; | 
				
			|||
	} | 
				
			|||
	public void setMultiReplace(boolean multiReplace) { | 
				
			|||
		this.multiReplace = multiReplace; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public String getNumFormat() { | 
				
			|||
		return numFormat; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setNumFormat(String numFormat) { | 
				
			|||
		this.numFormat = numFormat; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public String getGroupName() { | 
				
			|||
		return groupName; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setGroupName(String groupName) { | 
				
			|||
		this.groupName = groupName; | 
				
			|||
	} | 
				
			|||
} | 
				
			|||
@ -0,0 +1,77 @@ | 
				
			|||
/** | 
				
			|||
 * Copyright 2013-2015 JEECG (jeecgos@163.com) | 
				
			|||
 * | 
				
			|||
 *  Licensed under the Apache License, Version 2.0 (the "License"); | 
				
			|||
 *  you may not use this file except in compliance with the License. | 
				
			|||
 *  You may obtain a copy of the License at | 
				
			|||
 * | 
				
			|||
 *     http://www.apache.org/licenses/LICENSE-2.0
 | 
				
			|||
 * | 
				
			|||
 *  Unless required by applicable law or agreed to in writing, software | 
				
			|||
 * distributed under the License is distributed on an "AS IS" BASIS, | 
				
			|||
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | 
				
			|||
 * See the License for the specific language governing permissions and | 
				
			|||
 * limitations under the License. | 
				
			|||
 */ | 
				
			|||
package cc.admin.poi.excel.entity.params; | 
				
			|||
 | 
				
			|||
import java.util.Map; | 
				
			|||
 | 
				
			|||
/** | 
				
			|||
 * Excel 对于的 Collection | 
				
			|||
 * | 
				
			|||
 * @author JEECG | 
				
			|||
 * @date 2013-9-26 | 
				
			|||
 * @version 1.0 | 
				
			|||
 */ | 
				
			|||
public class ExcelCollectionParams { | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 集合对应的名称 | 
				
			|||
	 */ | 
				
			|||
	private String name; | 
				
			|||
	/** | 
				
			|||
	 * Excel 列名称 | 
				
			|||
	 */ | 
				
			|||
	private String excelName; | 
				
			|||
	/** | 
				
			|||
	 * 实体对象 | 
				
			|||
	 */ | 
				
			|||
	private Class<?> type; | 
				
			|||
	/** | 
				
			|||
	 * 这个list下面的参数集合实体对象 | 
				
			|||
	 */ | 
				
			|||
	private Map<String, ExcelImportEntity> excelParams; | 
				
			|||
 | 
				
			|||
	public Map<String, ExcelImportEntity> getExcelParams() { | 
				
			|||
		return excelParams; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public String getName() { | 
				
			|||
		return name; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public Class<?> getType() { | 
				
			|||
		return type; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setExcelParams(Map<String, ExcelImportEntity> excelParams) { | 
				
			|||
		this.excelParams = excelParams; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setName(String name) { | 
				
			|||
		this.name = name; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setType(Class<?> type) { | 
				
			|||
		this.type = type; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public String getExcelName() { | 
				
			|||
		return excelName; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setExcelName(String excelName) { | 
				
			|||
		this.excelName = excelName; | 
				
			|||
	} | 
				
			|||
} | 
				
			|||
@ -0,0 +1,293 @@ | 
				
			|||
/** | 
				
			|||
 * Copyright 2013-2015 JEECG (jeecgos@163.com) | 
				
			|||
 * | 
				
			|||
 *  Licensed under the Apache License, Version 2.0 (the "License"); | 
				
			|||
 *  you may not use this file except in compliance with the License. | 
				
			|||
 *  You may obtain a copy of the License at | 
				
			|||
 * | 
				
			|||
 *     http://www.apache.org/licenses/LICENSE-2.0
 | 
				
			|||
 * | 
				
			|||
 *  Unless required by applicable law or agreed to in writing, software | 
				
			|||
 * distributed under the License is distributed on an "AS IS" BASIS, | 
				
			|||
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | 
				
			|||
 * See the License for the specific language governing permissions and | 
				
			|||
 * limitations under the License. | 
				
			|||
 */ | 
				
			|||
package cc.admin.poi.excel.entity.params; | 
				
			|||
 | 
				
			|||
import java.util.ArrayList; | 
				
			|||
import java.util.List; | 
				
			|||
 | 
				
			|||
/** | 
				
			|||
 * excel 导出工具类,对cell类型做映射 | 
				
			|||
 * | 
				
			|||
 * @author JEECG | 
				
			|||
 * @version 1.0 2013年8月24日 | 
				
			|||
 */ | 
				
			|||
public class ExcelExportEntity extends ExcelBaseEntity implements Comparable<ExcelExportEntity> { | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 如果是MAP导出,这个是map的key | 
				
			|||
	 */ | 
				
			|||
	private Object key; | 
				
			|||
 | 
				
			|||
	private double width = 10; | 
				
			|||
 | 
				
			|||
	private double height = 10; | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 图片的类型,1是文件地址(class目录),2是数据库字节,3是文件地址(磁盘目录),4网络图片 | 
				
			|||
	 */ | 
				
			|||
	private int exportImageType = 3; | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 图片储存位置(磁盘目录) 用于导出获取图片绝对路径 | 
				
			|||
	 */ | 
				
			|||
	private String imageBasePath; | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 排序顺序 | 
				
			|||
	 */ | 
				
			|||
	private int orderNum = 0; | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 是否支持换行 | 
				
			|||
	 */ | 
				
			|||
	private boolean isWrap; | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 是否需要合并 | 
				
			|||
	 */ | 
				
			|||
	private boolean needMerge; | 
				
			|||
	/** | 
				
			|||
	 * 单元格纵向合并 | 
				
			|||
	 */ | 
				
			|||
	private boolean mergeVertical; | 
				
			|||
	/** | 
				
			|||
	 * 合并依赖 | 
				
			|||
	 */ | 
				
			|||
	private int[] mergeRely; | 
				
			|||
	/** | 
				
			|||
	 * 后缀 | 
				
			|||
	 */ | 
				
			|||
	private String suffix; | 
				
			|||
	/** | 
				
			|||
	 * 统计 | 
				
			|||
	 */ | 
				
			|||
	private boolean isStatistics; | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 是否横向合并 | 
				
			|||
	 */ | 
				
			|||
	private boolean colspan; | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 被横向合并的列名称 | 
				
			|||
	 */ | 
				
			|||
	private List<String> subColumnList; | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 父表头的名称 | 
				
			|||
	 */ | 
				
			|||
	private String groupName; | 
				
			|||
 | 
				
			|||
	private List<ExcelExportEntity> list; | 
				
			|||
 | 
				
			|||
	public ExcelExportEntity() { | 
				
			|||
 | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public ExcelExportEntity(String name) { | 
				
			|||
		super.name = name; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public ExcelExportEntity(String name, Object key) { | 
				
			|||
		super.name = name; | 
				
			|||
		this.key = key; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 构造器 | 
				
			|||
	 * @param name 描述-文字 | 
				
			|||
	 * @param key 存储key 如果是MAP导出,这个是map的key | 
				
			|||
	 * @param colspan 是否为合并列(a,b列公用一个表头c,则a,b,c都需要设置为true) | 
				
			|||
	 */ | 
				
			|||
	public ExcelExportEntity(String name, Object key, boolean colspan) { | 
				
			|||
		super.name = name; | 
				
			|||
		this.key = key; | 
				
			|||
		this.colspan = colspan; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public ExcelExportEntity(String name, Object key, int width) { | 
				
			|||
		super.name = name; | 
				
			|||
		this.width = width; | 
				
			|||
		this.key = key; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public int getExportImageType() { | 
				
			|||
		return exportImageType; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public double getHeight() { | 
				
			|||
		return height; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public Object getKey() { | 
				
			|||
		return key; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public List<ExcelExportEntity> getList() { | 
				
			|||
		return list; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public int[] getMergeRely() { | 
				
			|||
		return mergeRely == null ? new int[0] : mergeRely; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public int getOrderNum() { | 
				
			|||
		return orderNum; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public double getWidth() { | 
				
			|||
		return width; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public boolean isMergeVertical() { | 
				
			|||
		return mergeVertical; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public boolean isNeedMerge() { | 
				
			|||
		return needMerge; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public boolean isWrap() { | 
				
			|||
		return isWrap; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setExportImageType(int exportImageType) { | 
				
			|||
		this.exportImageType = exportImageType; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setHeight(double height) { | 
				
			|||
		this.height = height; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setKey(Object key) { | 
				
			|||
		this.key = key; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setList(List<ExcelExportEntity> list) { | 
				
			|||
		this.list = list; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setMergeRely(int[] mergeRely) { | 
				
			|||
		this.mergeRely = mergeRely; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setMergeVertical(boolean mergeVertical) { | 
				
			|||
		this.mergeVertical = mergeVertical; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setNeedMerge(boolean needMerge) { | 
				
			|||
		this.needMerge = needMerge; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setOrderNum(int orderNum) { | 
				
			|||
		this.orderNum = orderNum; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setWidth(double width) { | 
				
			|||
		this.width = width; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setWrap(boolean isWrap) { | 
				
			|||
		this.isWrap = isWrap; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public String getSuffix() { | 
				
			|||
		return suffix; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setSuffix(String suffix) { | 
				
			|||
		this.suffix = suffix; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public boolean isStatistics() { | 
				
			|||
		return isStatistics; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setStatistics(boolean isStatistics) { | 
				
			|||
		this.isStatistics = isStatistics; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public String getImageBasePath() { | 
				
			|||
		return imageBasePath; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setImageBasePath(String imageBasePath) { | 
				
			|||
		this.imageBasePath = imageBasePath; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public boolean isColspan() { | 
				
			|||
		return colspan; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setColspan(boolean colspan) { | 
				
			|||
		this.colspan = colspan; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public List<String> getSubColumnList() { | 
				
			|||
		return subColumnList; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setSubColumnList(List<String> subColumnList) { | 
				
			|||
		this.subColumnList = subColumnList; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public String getGroupName() { | 
				
			|||
		return groupName; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setGroupName(String groupName) { | 
				
			|||
		this.groupName = groupName; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 是否为合并子列 | 
				
			|||
	 * @return | 
				
			|||
	 */ | 
				
			|||
	public boolean isSubColumn(){ | 
				
			|||
		return this.colspan && (this.subColumnList==null || this.subColumnList.size()==0); | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 是否为合并父列 | 
				
			|||
	 * @return | 
				
			|||
	 */ | 
				
			|||
	public boolean isMergeColumn(){ | 
				
			|||
		return this.colspan && this.subColumnList!=null && this.subColumnList.size()>0; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 获取被合并的子列 | 
				
			|||
	 * @param all | 
				
			|||
	 * @return | 
				
			|||
	 */ | 
				
			|||
	public List<ExcelExportEntity> initSubExportEntity(List<ExcelExportEntity> all){ | 
				
			|||
		List<ExcelExportEntity> sub = new ArrayList<ExcelExportEntity>(); | 
				
			|||
		for (ExcelExportEntity temp : all) { | 
				
			|||
			if(this.subColumnList.contains(temp.getKey())){ | 
				
			|||
				sub.add(temp); | 
				
			|||
			} | 
				
			|||
		} | 
				
			|||
		this.setList(sub); | 
				
			|||
		return sub; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	@Override | 
				
			|||
	public int compareTo(ExcelExportEntity prev) { | 
				
			|||
		return this.getOrderNum() - prev.getOrderNum(); | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
} | 
				
			|||
@ -0,0 +1,110 @@ | 
				
			|||
/** | 
				
			|||
 * Copyright 2013-2015 JEECG (jeecgos@163.com) | 
				
			|||
 * | 
				
			|||
 *  Licensed under the Apache License, Version 2.0 (the "License"); | 
				
			|||
 *  you may not use this file except in compliance with the License. | 
				
			|||
 *  You may obtain a copy of the License at | 
				
			|||
 * | 
				
			|||
 *     http://www.apache.org/licenses/LICENSE-2.0
 | 
				
			|||
 * | 
				
			|||
 *  Unless required by applicable law or agreed to in writing, software | 
				
			|||
 * distributed under the License is distributed on an "AS IS" BASIS, | 
				
			|||
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | 
				
			|||
 * See the License for the specific language governing permissions and | 
				
			|||
 * limitations under the License. | 
				
			|||
 */ | 
				
			|||
package cc.admin.poi.excel.entity.params; | 
				
			|||
 | 
				
			|||
import java.util.List; | 
				
			|||
 | 
				
			|||
/** | 
				
			|||
 * excel 导入工具类,对cell类型做映射 | 
				
			|||
 * | 
				
			|||
 * @author JEECG | 
				
			|||
 * @version 1.0 2013年8月24日 | 
				
			|||
 */ | 
				
			|||
public class ExcelImportEntity extends ExcelBaseEntity { | 
				
			|||
	/** | 
				
			|||
	 * 对应 Collection NAME | 
				
			|||
	 */ | 
				
			|||
	private String collectionName; | 
				
			|||
	/** | 
				
			|||
	 * 保存图片的地址 当saveType设置为3/4时,此值可以设置为:local,minio,alioss | 
				
			|||
	 */ | 
				
			|||
	private String saveUrl; | 
				
			|||
	/** | 
				
			|||
	 * 保存图片的类型,1是文件_old,2是数据库字节,3文件地址_new,4网络地址 | 
				
			|||
	 */ | 
				
			|||
	private int saveType; | 
				
			|||
	/** | 
				
			|||
	 * 对应exportType | 
				
			|||
	 */ | 
				
			|||
	private String classType; | 
				
			|||
	/** | 
				
			|||
	 * 校驗參數 | 
				
			|||
	 */ | 
				
			|||
	private ExcelVerifyEntity verify; | 
				
			|||
	/** | 
				
			|||
	 * 后缀 | 
				
			|||
	 */ | 
				
			|||
	private String suffix; | 
				
			|||
 | 
				
			|||
	private List<ExcelImportEntity> list; | 
				
			|||
 | 
				
			|||
	public String getClassType() { | 
				
			|||
		return classType; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public String getCollectionName() { | 
				
			|||
		return collectionName; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public List<ExcelImportEntity> getList() { | 
				
			|||
		return list; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public int getSaveType() { | 
				
			|||
		return saveType; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public String getSaveUrl() { | 
				
			|||
		return saveUrl; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public ExcelVerifyEntity getVerify() { | 
				
			|||
		return verify; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setClassType(String classType) { | 
				
			|||
		this.classType = classType; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setCollectionName(String collectionName) { | 
				
			|||
		this.collectionName = collectionName; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setList(List<ExcelImportEntity> list) { | 
				
			|||
		this.list = list; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setSaveType(int saveType) { | 
				
			|||
		this.saveType = saveType; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setSaveUrl(String saveUrl) { | 
				
			|||
		this.saveUrl = saveUrl; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setVerify(ExcelVerifyEntity verify) { | 
				
			|||
		this.verify = verify; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public String getSuffix() { | 
				
			|||
		return suffix; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setSuffix(String suffix) { | 
				
			|||
		this.suffix = suffix; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
} | 
				
			|||
@ -0,0 +1,66 @@ | 
				
			|||
package cc.admin.poi.excel.entity.params; | 
				
			|||
 | 
				
			|||
import java.io.Serializable; | 
				
			|||
 | 
				
			|||
import org.apache.poi.ss.usermodel.CellStyle; | 
				
			|||
 | 
				
			|||
/** | 
				
			|||
 * 模板便利是的参数 | 
				
			|||
 * | 
				
			|||
 * @author JEECG | 
				
			|||
 * @date 2015年4月29日 下午9:22:48 | 
				
			|||
 */ | 
				
			|||
public class ExcelTemplateParams implements Serializable { | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
     * | 
				
			|||
     */ | 
				
			|||
	private static final long serialVersionUID = 1L; | 
				
			|||
	/** | 
				
			|||
	 * key | 
				
			|||
	 */ | 
				
			|||
	private String name; | 
				
			|||
	/** | 
				
			|||
	 * 模板的cellStyle | 
				
			|||
	 */ | 
				
			|||
	private CellStyle cellStyle; | 
				
			|||
	/** | 
				
			|||
	 * 行高 | 
				
			|||
	 */ | 
				
			|||
	private short height; | 
				
			|||
 | 
				
			|||
	public ExcelTemplateParams() { | 
				
			|||
 | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public ExcelTemplateParams(String name, CellStyle cellStyle, short height) { | 
				
			|||
		this.name = name; | 
				
			|||
		this.cellStyle = cellStyle; | 
				
			|||
		this.height = height; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public String getName() { | 
				
			|||
		return name; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setName(String name) { | 
				
			|||
		this.name = name; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public CellStyle getCellStyle() { | 
				
			|||
		return cellStyle; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setCellStyle(CellStyle cellStyle) { | 
				
			|||
		this.cellStyle = cellStyle; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public short getHeight() { | 
				
			|||
		return height; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setHeight(short height) { | 
				
			|||
		this.height = height; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
} | 
				
			|||
@ -0,0 +1,159 @@ | 
				
			|||
/** | 
				
			|||
 * Copyright 2013-2015 JEECG (jeecgos@163.com) | 
				
			|||
 * | 
				
			|||
 *  Licensed under the Apache License, Version 2.0 (the "License"); | 
				
			|||
 *  you may not use this file except in compliance with the License. | 
				
			|||
 *  You may obtain a copy of the License at | 
				
			|||
 * | 
				
			|||
 *     http://www.apache.org/licenses/LICENSE-2.0
 | 
				
			|||
 * | 
				
			|||
 *  Unless required by applicable law or agreed to in writing, software | 
				
			|||
 * distributed under the License is distributed on an "AS IS" BASIS, | 
				
			|||
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | 
				
			|||
 * See the License for the specific language governing permissions and | 
				
			|||
 * limitations under the License. | 
				
			|||
 */ | 
				
			|||
package cc.admin.poi.excel.entity.params; | 
				
			|||
 | 
				
			|||
/** | 
				
			|||
 * Excel 校验对象 | 
				
			|||
 * | 
				
			|||
 * @author JEECG | 
				
			|||
 * @date 2014年6月29日 下午4:24:59 | 
				
			|||
 */ | 
				
			|||
public class ExcelVerifyEntity { | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 接口校验 | 
				
			|||
	 * | 
				
			|||
	 * @return | 
				
			|||
	 */ | 
				
			|||
	private boolean interHandler; | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 不允许空 | 
				
			|||
	 * | 
				
			|||
	 * @return | 
				
			|||
	 */ | 
				
			|||
	private boolean notNull; | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 是13位移动电话 | 
				
			|||
	 * | 
				
			|||
	 * @return | 
				
			|||
	 */ | 
				
			|||
	private boolean isMobile; | 
				
			|||
	/** | 
				
			|||
	 * 是座机号码 | 
				
			|||
	 * | 
				
			|||
	 * @return | 
				
			|||
	 */ | 
				
			|||
	private boolean isTel; | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 是电子邮件 | 
				
			|||
	 * | 
				
			|||
	 * @return | 
				
			|||
	 */ | 
				
			|||
	private boolean isEmail; | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 最小长度 | 
				
			|||
	 * | 
				
			|||
	 * @return | 
				
			|||
	 */ | 
				
			|||
	private int minLength; | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 最大长度 | 
				
			|||
	 * | 
				
			|||
	 * @return | 
				
			|||
	 */ | 
				
			|||
	private int maxLength; | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 正在表达式 | 
				
			|||
	 * | 
				
			|||
	 * @return | 
				
			|||
	 */ | 
				
			|||
	private String regex; | 
				
			|||
	/** | 
				
			|||
	 * 正在表达式,错误提示信息 | 
				
			|||
	 * | 
				
			|||
	 * @return | 
				
			|||
	 */ | 
				
			|||
	private String regexTip; | 
				
			|||
 | 
				
			|||
	public int getMaxLength() { | 
				
			|||
		return maxLength; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public int getMinLength() { | 
				
			|||
		return minLength; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public String getRegex() { | 
				
			|||
		return regex; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public String getRegexTip() { | 
				
			|||
		return regexTip; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public boolean isEmail() { | 
				
			|||
		return isEmail; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public boolean isInterHandler() { | 
				
			|||
		return interHandler; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public boolean isMobile() { | 
				
			|||
		return isMobile; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public boolean isNotNull() { | 
				
			|||
		return notNull; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public boolean isTel() { | 
				
			|||
		return isTel; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setEmail(boolean isEmail) { | 
				
			|||
		this.isEmail = isEmail; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setInterHandler(boolean interHandler) { | 
				
			|||
		this.interHandler = interHandler; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setMaxLength(int maxLength) { | 
				
			|||
		this.maxLength = maxLength; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setMinLength(int minLength) { | 
				
			|||
		this.minLength = minLength; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setMobile(boolean isMobile) { | 
				
			|||
		this.isMobile = isMobile; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setNotNull(boolean notNull) { | 
				
			|||
		this.notNull = notNull; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setRegex(String regex) { | 
				
			|||
		this.regex = regex; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setRegexTip(String regexTip) { | 
				
			|||
		this.regexTip = regexTip; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setTel(boolean isTel) { | 
				
			|||
		this.isTel = isTel; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
} | 
				
			|||
@ -0,0 +1,84 @@ | 
				
			|||
/** | 
				
			|||
 * Copyright 2013-2015 JEECG (jeecgos@163.com) | 
				
			|||
 * | 
				
			|||
 *  Licensed under the Apache License, Version 2.0 (the "License"); | 
				
			|||
 *  you may not use this file except in compliance with the License. | 
				
			|||
 *  You may obtain a copy of the License at | 
				
			|||
 * | 
				
			|||
 *     http://www.apache.org/licenses/LICENSE-2.0
 | 
				
			|||
 * | 
				
			|||
 *  Unless required by applicable law or agreed to in writing, software | 
				
			|||
 * distributed under the License is distributed on an "AS IS" BASIS, | 
				
			|||
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | 
				
			|||
 * See the License for the specific language governing permissions and | 
				
			|||
 * limitations under the License. | 
				
			|||
 */ | 
				
			|||
package cc.admin.poi.excel.entity.params; | 
				
			|||
 | 
				
			|||
import java.util.List; | 
				
			|||
 | 
				
			|||
/** | 
				
			|||
 * 合并单元格使用对象 | 
				
			|||
 * | 
				
			|||
 * Created by jue on 14-6-11. | 
				
			|||
 */ | 
				
			|||
public class MergeEntity { | 
				
			|||
	/** | 
				
			|||
	 * 合并开始行 | 
				
			|||
	 */ | 
				
			|||
	private int startRow; | 
				
			|||
	/** | 
				
			|||
	 * 合并结束行 | 
				
			|||
	 */ | 
				
			|||
	private int endRow; | 
				
			|||
	/** | 
				
			|||
	 * 文字 | 
				
			|||
	 */ | 
				
			|||
	private String text; | 
				
			|||
	/** | 
				
			|||
	 * 依赖关系文本 | 
				
			|||
	 */ | 
				
			|||
	private List<String> relyList; | 
				
			|||
 | 
				
			|||
	public MergeEntity() { | 
				
			|||
 | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public MergeEntity(String text, int startRow, int endRow) { | 
				
			|||
		this.text = text; | 
				
			|||
		this.endRow = endRow; | 
				
			|||
		this.startRow = startRow; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public int getEndRow() { | 
				
			|||
		return endRow; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public List<String> getRelyList() { | 
				
			|||
		return relyList; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public int getStartRow() { | 
				
			|||
		return startRow; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public String getText() { | 
				
			|||
		return text; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setEndRow(int endRow) { | 
				
			|||
		this.endRow = endRow; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setRelyList(List<String> relyList) { | 
				
			|||
		this.relyList = relyList; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setStartRow(int startRow) { | 
				
			|||
		this.startRow = startRow; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setText(String text) { | 
				
			|||
		this.text = text; | 
				
			|||
	} | 
				
			|||
} | 
				
			|||
@ -0,0 +1,79 @@ | 
				
			|||
/** | 
				
			|||
 * Copyright 2013-2015 JEECG (jeecgos@163.com) | 
				
			|||
 * | 
				
			|||
 *  Licensed under the Apache License, Version 2.0 (the "License"); | 
				
			|||
 *  you may not use this file except in compliance with the License. | 
				
			|||
 *  You may obtain a copy of the License at | 
				
			|||
 * | 
				
			|||
 *     http://www.apache.org/licenses/LICENSE-2.0
 | 
				
			|||
 * | 
				
			|||
 *  Unless required by applicable law or agreed to in writing, software | 
				
			|||
 * distributed under the License is distributed on an "AS IS" BASIS, | 
				
			|||
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | 
				
			|||
 * See the License for the specific language governing permissions and | 
				
			|||
 * limitations under the License. | 
				
			|||
 */ | 
				
			|||
package cc.admin.poi.excel.entity.result; | 
				
			|||
 | 
				
			|||
import java.util.List; | 
				
			|||
 | 
				
			|||
import org.apache.poi.ss.usermodel.Workbook; | 
				
			|||
 | 
				
			|||
/** | 
				
			|||
 * 导入返回类 | 
				
			|||
 * | 
				
			|||
 * @author JEECG | 
				
			|||
 * @date 2014年6月29日 下午5:12:10 | 
				
			|||
 */ | 
				
			|||
public class ExcelImportResult<T> { | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 结果集 | 
				
			|||
	 */ | 
				
			|||
	private List<T> list; | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 是否存在校验失败 | 
				
			|||
	 */ | 
				
			|||
	private boolean verfiyFail; | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 数据源 | 
				
			|||
	 */ | 
				
			|||
	private Workbook workbook; | 
				
			|||
 | 
				
			|||
	public ExcelImportResult() { | 
				
			|||
 | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public ExcelImportResult(List<T> list, boolean verfiyFail, Workbook workbook) { | 
				
			|||
		this.list = list; | 
				
			|||
		this.verfiyFail = verfiyFail; | 
				
			|||
		this.workbook = workbook; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public List<T> getList() { | 
				
			|||
		return list; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public Workbook getWorkbook() { | 
				
			|||
		return workbook; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public boolean isVerfiyFail() { | 
				
			|||
		return verfiyFail; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setList(List<T> list) { | 
				
			|||
		this.list = list; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setVerfiyFail(boolean verfiyFail) { | 
				
			|||
		this.verfiyFail = verfiyFail; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setWorkbook(Workbook workbook) { | 
				
			|||
		this.workbook = workbook; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
} | 
				
			|||
@ -0,0 +1,63 @@ | 
				
			|||
/** | 
				
			|||
 * Copyright 2013-2015 JEECG (jeecgos@163.com) | 
				
			|||
 * | 
				
			|||
 *  Licensed under the Apache License, Version 2.0 (the "License"); | 
				
			|||
 *  you may not use this file except in compliance with the License. | 
				
			|||
 *  You may obtain a copy of the License at | 
				
			|||
 * | 
				
			|||
 *     http://www.apache.org/licenses/LICENSE-2.0
 | 
				
			|||
 * | 
				
			|||
 *  Unless required by applicable law or agreed to in writing, software | 
				
			|||
 * distributed under the License is distributed on an "AS IS" BASIS, | 
				
			|||
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | 
				
			|||
 * See the License for the specific language governing permissions and | 
				
			|||
 * limitations under the License. | 
				
			|||
 */ | 
				
			|||
package cc.admin.poi.excel.entity.result; | 
				
			|||
 | 
				
			|||
/** | 
				
			|||
 * Excel导入处理返回结果 | 
				
			|||
 * | 
				
			|||
 * @author JEECG | 
				
			|||
 * @date 2014年6月23日 下午11:03:29 | 
				
			|||
 */ | 
				
			|||
public class ExcelVerifyHanlderResult { | 
				
			|||
	/** | 
				
			|||
	 * 是否正确 | 
				
			|||
	 */ | 
				
			|||
	private boolean success; | 
				
			|||
	/** | 
				
			|||
	 * 错误信息 | 
				
			|||
	 */ | 
				
			|||
	private String msg; | 
				
			|||
 | 
				
			|||
	public ExcelVerifyHanlderResult() { | 
				
			|||
 | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public ExcelVerifyHanlderResult(boolean success) { | 
				
			|||
		this.success = success; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public ExcelVerifyHanlderResult(boolean success, String msg) { | 
				
			|||
		this.success = success; | 
				
			|||
		this.msg = msg; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public String getMsg() { | 
				
			|||
		return msg; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public boolean isSuccess() { | 
				
			|||
		return success; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setMsg(String msg) { | 
				
			|||
		this.msg = msg; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setSuccess(boolean success) { | 
				
			|||
		this.success = success; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
} | 
				
			|||
@ -0,0 +1,62 @@ | 
				
			|||
/** | 
				
			|||
 * Copyright 2013-2015 JEECG (jeecgos@163.com) | 
				
			|||
 * | 
				
			|||
 *  Licensed under the Apache License, Version 2.0 (the "License"); | 
				
			|||
 *  you may not use this file except in compliance with the License. | 
				
			|||
 *  You may obtain a copy of the License at | 
				
			|||
 * | 
				
			|||
 *     http://www.apache.org/licenses/LICENSE-2.0
 | 
				
			|||
 * | 
				
			|||
 *  Unless required by applicable law or agreed to in writing, software | 
				
			|||
 * distributed under the License is distributed on an "AS IS" BASIS, | 
				
			|||
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | 
				
			|||
 * See the License for the specific language governing permissions and | 
				
			|||
 * limitations under the License. | 
				
			|||
 */ | 
				
			|||
package cc.admin.poi.excel.entity.sax; | 
				
			|||
 | 
				
			|||
import cc.admin.poi.excel.entity.enmus.CellValueType; | 
				
			|||
 | 
				
			|||
/** | 
				
			|||
 * Cell 对象 | 
				
			|||
 * | 
				
			|||
 * @author JEECG | 
				
			|||
 * @date 2014年12月29日 下午10:12:57 | 
				
			|||
 */ | 
				
			|||
public class SaxReadCellEntity { | 
				
			|||
	/** | 
				
			|||
	 * 值类型 | 
				
			|||
	 */ | 
				
			|||
	private CellValueType cellType; | 
				
			|||
	/** | 
				
			|||
	 * 值 | 
				
			|||
	 */ | 
				
			|||
	private Object value; | 
				
			|||
 | 
				
			|||
	public SaxReadCellEntity(CellValueType cellType, Object value) { | 
				
			|||
		this.cellType = cellType; | 
				
			|||
		this.value = value; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public CellValueType getCellType() { | 
				
			|||
		return cellType; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setCellType(CellValueType cellType) { | 
				
			|||
		this.cellType = cellType; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public Object getValue() { | 
				
			|||
		return value; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setValue(Object value) { | 
				
			|||
		this.value = value; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	@Override | 
				
			|||
	public String toString() { | 
				
			|||
		return "[type=" + cellType.toString() + ",value=" + value + "]"; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
} | 
				
			|||
@ -0,0 +1,43 @@ | 
				
			|||
/** | 
				
			|||
 * Copyright 2013-2015 JEECG (jeecgos@163.com) | 
				
			|||
 * | 
				
			|||
 *  Licensed under the Apache License, Version 2.0 (the "License"); | 
				
			|||
 *  you may not use this file except in compliance with the License. | 
				
			|||
 *  You may obtain a copy of the License at | 
				
			|||
 * | 
				
			|||
 *     http://www.apache.org/licenses/LICENSE-2.0
 | 
				
			|||
 * | 
				
			|||
 *  Unless required by applicable law or agreed to in writing, software | 
				
			|||
 * distributed under the License is distributed on an "AS IS" BASIS, | 
				
			|||
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | 
				
			|||
 * See the License for the specific language governing permissions and | 
				
			|||
 * limitations under the License. | 
				
			|||
 */ | 
				
			|||
package cc.admin.poi.excel.entity.vo; | 
				
			|||
 | 
				
			|||
/** | 
				
			|||
 * 基础常量 Created by jue on 14-4-21. | 
				
			|||
 */ | 
				
			|||
public interface PoiBaseConstants { | 
				
			|||
	/** | 
				
			|||
	 * 字段属性对应方法 | 
				
			|||
	 */ | 
				
			|||
	public static String GET = "get"; | 
				
			|||
	/** | 
				
			|||
	 * 字段属性对应方法 | 
				
			|||
	 */ | 
				
			|||
	public static String SET = "set"; | 
				
			|||
	/** | 
				
			|||
	 * 字段属性对应方法 | 
				
			|||
	 */ | 
				
			|||
	public static String IS = "is"; | 
				
			|||
	/** | 
				
			|||
	 * 是否增加属性列 | 
				
			|||
	 */ | 
				
			|||
	public static String IS_ADD_INDEX = "isAddIndex"; | 
				
			|||
	/** | 
				
			|||
	 * 字段属性对应convert方法 | 
				
			|||
	 */ | 
				
			|||
	public static String CONVERT = "convert"; | 
				
			|||
 | 
				
			|||
} | 
				
			|||
@ -0,0 +1,336 @@ | 
				
			|||
/** | 
				
			|||
 * Copyright 2013-2015 JEECG (jeecgos@163.com) | 
				
			|||
 * | 
				
			|||
 *  Licensed under the Apache License, Version 2.0 (the "License"); | 
				
			|||
 *  you may not use this file except in compliance with the License. | 
				
			|||
 *  You may obtain a copy of the License at | 
				
			|||
 * | 
				
			|||
 *     http://www.apache.org/licenses/LICENSE-2.0
 | 
				
			|||
 * | 
				
			|||
 *  Unless required by applicable law or agreed to in writing, software | 
				
			|||
 * distributed under the License is distributed on an "AS IS" BASIS, | 
				
			|||
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | 
				
			|||
 * See the License for the specific language governing permissions and | 
				
			|||
 * limitations under the License. | 
				
			|||
 */ | 
				
			|||
package cc.admin.poi.excel.export; | 
				
			|||
 | 
				
			|||
import cc.admin.poi.excel.annotation.ExcelTarget; | 
				
			|||
import cc.admin.poi.excel.entity.ExportParams; | 
				
			|||
import cc.admin.poi.excel.entity.enmus.ExcelType; | 
				
			|||
import cc.admin.poi.excel.entity.params.ExcelExportEntity; | 
				
			|||
import cc.admin.poi.excel.entity.vo.PoiBaseConstants; | 
				
			|||
import cc.admin.poi.excel.export.base.ExcelExportBase; | 
				
			|||
import cc.admin.poi.excel.export.styler.IExcelExportStyler; | 
				
			|||
import cc.admin.poi.exception.excel.ExcelExportException; | 
				
			|||
import cc.admin.poi.exception.excel.enums.ExcelExportEnum; | 
				
			|||
import cc.admin.poi.util.PoiPublicUtil; | 
				
			|||
import org.apache.commons.lang3.StringUtils; | 
				
			|||
import org.apache.poi.ss.usermodel.*; | 
				
			|||
import org.apache.poi.ss.util.CellRangeAddress; | 
				
			|||
import org.slf4j.Logger; | 
				
			|||
import org.slf4j.LoggerFactory; | 
				
			|||
 | 
				
			|||
import java.lang.reflect.Field; | 
				
			|||
import java.util.*; | 
				
			|||
 | 
				
			|||
/** | 
				
			|||
 * Excel导出服务 | 
				
			|||
 * | 
				
			|||
 * @author JEECG | 
				
			|||
 * @date 2014年6月17日 下午5:30:54 | 
				
			|||
 */ | 
				
			|||
public class ExcelExportServer extends ExcelExportBase { | 
				
			|||
 | 
				
			|||
	private final static Logger LOGGER = LoggerFactory.getLogger(ExcelExportServer.class); | 
				
			|||
 | 
				
			|||
	// 最大行数,超过自动多Sheet
 | 
				
			|||
	private int MAX_NUM = 60000; | 
				
			|||
 | 
				
			|||
	private int createHeaderAndTitle(ExportParams entity, Sheet sheet, Workbook workbook, List<ExcelExportEntity> excelParams) { | 
				
			|||
		int rows = 0, feildWidth = getFieldWidth(excelParams); | 
				
			|||
		if (entity.getTitle() != null) { | 
				
			|||
			rows += createHeaderRow(entity, sheet, workbook, feildWidth); | 
				
			|||
		} | 
				
			|||
		rows += createTitleRow(entity, sheet, workbook, rows, excelParams); | 
				
			|||
		sheet.createFreezePane(0, rows, 0, rows); | 
				
			|||
		return rows; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 创建 表头改变 | 
				
			|||
	 * | 
				
			|||
	 * @param entity | 
				
			|||
	 * @param sheet | 
				
			|||
	 * @param workbook | 
				
			|||
	 * @param feildWidth | 
				
			|||
	 */ | 
				
			|||
	public int createHeaderRow(ExportParams entity, Sheet sheet, Workbook workbook, int feildWidth) { | 
				
			|||
		Row row = sheet.createRow(0); | 
				
			|||
		row.setHeight(entity.getTitleHeight()); | 
				
			|||
		createStringCell(row, 0, entity.getTitle(), getExcelExportStyler().getHeaderStyle(entity.getHeaderColor()), null); | 
				
			|||
		for (int i = 1; i <= feildWidth; i++) { | 
				
			|||
			createStringCell(row, i, "", getExcelExportStyler().getHeaderStyle(entity.getHeaderColor()), null); | 
				
			|||
		} | 
				
			|||
		sheet.addMergedRegion(new CellRangeAddress(0, 0, 0, feildWidth)); | 
				
			|||
		if (entity.getSecondTitle() != null) { | 
				
			|||
			row = sheet.createRow(1); | 
				
			|||
			row.setHeight(entity.getSecondTitleHeight()); | 
				
			|||
			CellStyle style = workbook.createCellStyle(); | 
				
			|||
			style.setAlignment(HorizontalAlignment.RIGHT); | 
				
			|||
			createStringCell(row, 0, entity.getSecondTitle(), style, null); | 
				
			|||
			for (int i = 1; i <= feildWidth; i++) { | 
				
			|||
				createStringCell(row, i, "", getExcelExportStyler().getHeaderStyle(entity.getHeaderColor()), null); | 
				
			|||
			} | 
				
			|||
			sheet.addMergedRegion(new CellRangeAddress(1, 1, 0, feildWidth)); | 
				
			|||
			return 2; | 
				
			|||
		} | 
				
			|||
		return 1; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void createSheet(Workbook workbook, ExportParams entity, Class<?> pojoClass, Collection<?> dataSet, String[] exportFields) { | 
				
			|||
		if (LOGGER.isDebugEnabled()) { | 
				
			|||
			LOGGER.debug("Excel export start ,class is {}", pojoClass); | 
				
			|||
			LOGGER.debug("Excel version is {}", entity.getType().equals(ExcelType.HSSF) ? "03" : "07"); | 
				
			|||
		} | 
				
			|||
		if (workbook == null || entity == null || pojoClass == null || dataSet == null) { | 
				
			|||
			throw new ExcelExportException(ExcelExportEnum.PARAMETER_ERROR); | 
				
			|||
		} | 
				
			|||
		super.type = entity.getType(); | 
				
			|||
		if (type.equals(ExcelType.XSSF)) { | 
				
			|||
			MAX_NUM = 1000000; | 
				
			|||
		} | 
				
			|||
		Sheet sheet = null; | 
				
			|||
		try { | 
				
			|||
			sheet = workbook.createSheet(entity.getSheetName()); | 
				
			|||
		} catch (Exception e) { | 
				
			|||
			// 重复遍历,出现了重名现象,创建非指定的名称Sheet
 | 
				
			|||
			sheet = workbook.createSheet(); | 
				
			|||
		} | 
				
			|||
		try { | 
				
			|||
			dataHanlder = entity.getDataHanlder(); | 
				
			|||
			if (dataHanlder != null) { | 
				
			|||
				needHanlderList = Arrays.asList(dataHanlder.getNeedHandlerFields()); | 
				
			|||
			} | 
				
			|||
			// 创建表格样式
 | 
				
			|||
			setExcelExportStyler((IExcelExportStyler) entity.getStyle().getConstructor(Workbook.class).newInstance(workbook)); | 
				
			|||
			Drawing patriarch = sheet.createDrawingPatriarch(); | 
				
			|||
			List<ExcelExportEntity> excelParams = new ArrayList<ExcelExportEntity>(); | 
				
			|||
			if (entity.isAddIndex()) { | 
				
			|||
				excelParams.add(indexExcelEntity(entity)); | 
				
			|||
			} | 
				
			|||
			// 得到所有字段
 | 
				
			|||
			Field fileds[] = PoiPublicUtil.getClassFields(pojoClass); | 
				
			|||
 | 
				
			|||
            //---update-begin-----autor:scott------date:20191016-------for:导出字段支持自定义--------
 | 
				
			|||
            //支持自定义导出字段
 | 
				
			|||
            if (exportFields != null) { | 
				
			|||
                List<Field> list = new ArrayList<Field>(Arrays.asList(fileds)); | 
				
			|||
                for (int i = 0; i < list.size(); i++) { | 
				
			|||
                    if (!Arrays.asList(exportFields).contains(list.get(i).getName())) { | 
				
			|||
                        list.remove(i); | 
				
			|||
                        i--; | 
				
			|||
                    } | 
				
			|||
                } | 
				
			|||
 | 
				
			|||
                if (list != null && list.size() > 0) { | 
				
			|||
                    fileds = list.toArray(new Field[0]); | 
				
			|||
                } else { | 
				
			|||
                    fileds = null; | 
				
			|||
                } | 
				
			|||
            } | 
				
			|||
            //---update-end-----autor:scott------date:20191016-------for:导出字段支持自定义--------
 | 
				
			|||
 | 
				
			|||
			ExcelTarget etarget = pojoClass.getAnnotation(ExcelTarget.class); | 
				
			|||
			String targetId = etarget == null ? null : etarget.value(); | 
				
			|||
			getAllExcelField(entity.getExclusions(), targetId, fileds, excelParams, pojoClass, null); | 
				
			|||
			//update-begin-author:taoyan date:20200304 for:在此方法循环内设置一下图片磁盘目录,便于导出
 | 
				
			|||
			reConfigExcelExportParams(excelParams,entity); | 
				
			|||
			//update-end-author:taoyan date:20200304 for:在此方法循环内设置一下图片磁盘目录,便于导出
 | 
				
			|||
			int index = entity.isCreateHeadRows() ? createHeaderAndTitle(entity, sheet, workbook, excelParams) : 0; | 
				
			|||
			int titleHeight = index; | 
				
			|||
			setCellWith(excelParams, sheet); | 
				
			|||
			short rowHeight = getRowHeight(excelParams); | 
				
			|||
			setCurrentIndex(1); | 
				
			|||
			Iterator<?> its = dataSet.iterator(); | 
				
			|||
			List<Object> tempList = new ArrayList<Object>(); | 
				
			|||
			while (its.hasNext()) { | 
				
			|||
				Object t = its.next(); | 
				
			|||
				index += createCells(patriarch, index, t, excelParams, sheet, workbook, rowHeight); | 
				
			|||
				tempList.add(t); | 
				
			|||
				if (index >= MAX_NUM) | 
				
			|||
					break; | 
				
			|||
			} | 
				
			|||
			mergeCells(sheet, excelParams, titleHeight); | 
				
			|||
 | 
				
			|||
			if (entity.getFreezeCol() != 0) { | 
				
			|||
				sheet.createFreezePane(entity.getFreezeCol(), 0, entity.getFreezeCol(), 0); | 
				
			|||
			} | 
				
			|||
 | 
				
			|||
			its = dataSet.iterator(); | 
				
			|||
			for (int i = 0, le = tempList.size(); i < le; i++) { | 
				
			|||
				its.next(); | 
				
			|||
				its.remove(); | 
				
			|||
			} | 
				
			|||
			// 创建合计信息
 | 
				
			|||
			addStatisticsRow(getExcelExportStyler().getStyles(true, null), sheet); | 
				
			|||
 | 
				
			|||
			// 发现还有剩余list 继续循环创建Sheet
 | 
				
			|||
			if (dataSet.size() > 0) { | 
				
			|||
				createSheet(workbook, entity, pojoClass, dataSet,exportFields); | 
				
			|||
			} | 
				
			|||
 | 
				
			|||
		} catch (Exception e) { | 
				
			|||
			LOGGER.error(e.getMessage(), e); | 
				
			|||
			throw new ExcelExportException(ExcelExportEnum.EXPORT_ERROR, e.getCause()); | 
				
			|||
		} | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void createSheetForMap(Workbook workbook, ExportParams entity, List<ExcelExportEntity> entityList, Collection<? extends Map<?, ?>> dataSet) { | 
				
			|||
		if (LOGGER.isDebugEnabled()) { | 
				
			|||
			LOGGER.debug("Excel version is {}", entity.getType().equals(ExcelType.HSSF) ? "03" : "07"); | 
				
			|||
		} | 
				
			|||
		if (workbook == null || entity == null || entityList == null || dataSet == null) { | 
				
			|||
			throw new ExcelExportException(ExcelExportEnum.PARAMETER_ERROR); | 
				
			|||
		} | 
				
			|||
		super.type = entity.getType(); | 
				
			|||
		if (type.equals(ExcelType.XSSF)) { | 
				
			|||
			MAX_NUM = 1000000; | 
				
			|||
		} | 
				
			|||
		Sheet sheet = null; | 
				
			|||
		try { | 
				
			|||
			sheet = workbook.createSheet(entity.getSheetName()); | 
				
			|||
		} catch (Exception e) { | 
				
			|||
			// 重复遍历,出现了重名现象,创建非指定的名称Sheet
 | 
				
			|||
			sheet = workbook.createSheet(); | 
				
			|||
		} | 
				
			|||
		try { | 
				
			|||
			dataHanlder = entity.getDataHanlder(); | 
				
			|||
			if (dataHanlder != null) { | 
				
			|||
				needHanlderList = Arrays.asList(dataHanlder.getNeedHandlerFields()); | 
				
			|||
			} | 
				
			|||
			// 创建表格样式
 | 
				
			|||
			setExcelExportStyler((IExcelExportStyler) entity.getStyle().getConstructor(Workbook.class).newInstance(workbook)); | 
				
			|||
			Drawing patriarch = sheet.createDrawingPatriarch(); | 
				
			|||
			List<ExcelExportEntity> excelParams = new ArrayList<ExcelExportEntity>(); | 
				
			|||
			if (entity.isAddIndex()) { | 
				
			|||
				excelParams.add(indexExcelEntity(entity)); | 
				
			|||
			} | 
				
			|||
			excelParams.addAll(entityList); | 
				
			|||
			sortAllParams(excelParams); | 
				
			|||
			int index = entity.isCreateHeadRows() ? createHeaderAndTitle(entity, sheet, workbook, excelParams) : 0; | 
				
			|||
			int titleHeight = index; | 
				
			|||
			setCellWith(excelParams, sheet); | 
				
			|||
			short rowHeight = getRowHeight(excelParams); | 
				
			|||
			setCurrentIndex(1); | 
				
			|||
			Iterator<?> its = dataSet.iterator(); | 
				
			|||
			List<Object> tempList = new ArrayList<Object>(); | 
				
			|||
			while (its.hasNext()) { | 
				
			|||
				Object t = its.next(); | 
				
			|||
				index += createCells(patriarch, index, t, excelParams, sheet, workbook, rowHeight); | 
				
			|||
				tempList.add(t); | 
				
			|||
				if (index >= MAX_NUM) | 
				
			|||
					break; | 
				
			|||
			} | 
				
			|||
			if (entity.getFreezeCol() != 0) { | 
				
			|||
				sheet.createFreezePane(entity.getFreezeCol(), 0, entity.getFreezeCol(), 0); | 
				
			|||
			} | 
				
			|||
 | 
				
			|||
			mergeCells(sheet, excelParams, titleHeight); | 
				
			|||
 | 
				
			|||
			its = dataSet.iterator(); | 
				
			|||
			for (int i = 0, le = tempList.size(); i < le; i++) { | 
				
			|||
				its.next(); | 
				
			|||
				its.remove(); | 
				
			|||
			} | 
				
			|||
			// 发现还有剩余list 继续循环创建Sheet
 | 
				
			|||
			if (dataSet.size() > 0) { | 
				
			|||
				createSheetForMap(workbook, entity, entityList, dataSet); | 
				
			|||
			} | 
				
			|||
 | 
				
			|||
		} catch (Exception e) { | 
				
			|||
			LOGGER.error(e.getMessage(), e); | 
				
			|||
			throw new ExcelExportException(ExcelExportEnum.EXPORT_ERROR, e.getCause()); | 
				
			|||
		} | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 创建表头 | 
				
			|||
	 * | 
				
			|||
	 * @param title | 
				
			|||
	 * @param index | 
				
			|||
	 */ | 
				
			|||
	private int createTitleRow(ExportParams title, Sheet sheet, Workbook workbook, int index, List<ExcelExportEntity> excelParams) { | 
				
			|||
		Row row = sheet.createRow(index); | 
				
			|||
		int rows = getRowNums(excelParams); | 
				
			|||
		row.setHeight((short) 450); | 
				
			|||
		Row listRow = null; | 
				
			|||
		if (rows == 2) { | 
				
			|||
			listRow = sheet.createRow(index + 1); | 
				
			|||
			listRow.setHeight((short) 450); | 
				
			|||
		} | 
				
			|||
		int cellIndex = 0; | 
				
			|||
		CellStyle titleStyle = getExcelExportStyler().getTitleStyle(title.getColor()); | 
				
			|||
		for (int i = 0, exportFieldTitleSize = excelParams.size(); i < exportFieldTitleSize; i++) { | 
				
			|||
			ExcelExportEntity entity = excelParams.get(i); | 
				
			|||
			//update-begin-author:taoyan date:20200319 for:建议autoPoi升级,优化数据返回List Map格式下的复合表头导出excel的体验 #873
 | 
				
			|||
			if(entity.isColspan()){ | 
				
			|||
				List<String> subList = entity.getSubColumnList(); | 
				
			|||
				if(subList==null || subList.size()==0){ | 
				
			|||
					continue; | 
				
			|||
				}else{ | 
				
			|||
					entity.initSubExportEntity(excelParams); | 
				
			|||
				} | 
				
			|||
			} | 
				
			|||
			//update-end-author:taoyan date:20200319 for:建议autoPoi升级,优化数据返回List Map格式下的复合表头导出excel的体验 #873
 | 
				
			|||
			if (StringUtils.isNotBlank(entity.getName())) { | 
				
			|||
				createStringCell(row, cellIndex, entity.getName(), titleStyle, entity); | 
				
			|||
			} | 
				
			|||
			if (entity.getList() != null) { | 
				
			|||
				List<ExcelExportEntity> sTitel = entity.getList(); | 
				
			|||
				if (StringUtils.isNotBlank(entity.getName())) { | 
				
			|||
					sheet.addMergedRegion(new CellRangeAddress(index, index, cellIndex, cellIndex + sTitel.size() - 1)); | 
				
			|||
				} | 
				
			|||
				for (int j = 0, size = sTitel.size(); j < size; j++) { | 
				
			|||
					createStringCell(rows == 2 ? listRow : row, cellIndex, sTitel.get(j).getName(), titleStyle, entity); | 
				
			|||
					cellIndex++; | 
				
			|||
				} | 
				
			|||
				cellIndex--; | 
				
			|||
			} else if (rows == 2) { | 
				
			|||
				createStringCell(listRow, cellIndex, "", titleStyle, entity); | 
				
			|||
				sheet.addMergedRegion(new CellRangeAddress(index, index + 1, cellIndex, cellIndex)); | 
				
			|||
			} | 
				
			|||
			cellIndex++; | 
				
			|||
		} | 
				
			|||
		return rows; | 
				
			|||
 | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 判断表头是只有一行还是两行 | 
				
			|||
	 * | 
				
			|||
	 * @param excelParams | 
				
			|||
	 * @return | 
				
			|||
	 */ | 
				
			|||
	private int getRowNums(List<ExcelExportEntity> excelParams) { | 
				
			|||
		for (int i = 0; i < excelParams.size(); i++) { | 
				
			|||
			//update-begin-author:taoyan date:20200319 for:建议autoPoi升级,优化数据返回List Map格式下的复合表头导出excel的体验 #873
 | 
				
			|||
			ExcelExportEntity temp = excelParams.get(i); | 
				
			|||
			if ((temp.getList() != null || temp.isColspan()) && StringUtils.isNotBlank(temp.getName())) { | 
				
			|||
				return 2; | 
				
			|||
			} | 
				
			|||
			//update-end-author:taoyan date:20200319 for:建议autoPoi升级,优化数据返回List Map格式下的复合表头导出excel的体验 #873
 | 
				
			|||
		} | 
				
			|||
		return 1; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	private ExcelExportEntity indexExcelEntity(ExportParams entity) { | 
				
			|||
		ExcelExportEntity exportEntity = new ExcelExportEntity(); | 
				
			|||
		exportEntity.setOrderNum(0); | 
				
			|||
		exportEntity.setName(entity.getIndexName()); | 
				
			|||
		exportEntity.setWidth(10); | 
				
			|||
		exportEntity.setFormat(PoiBaseConstants.IS_ADD_INDEX); | 
				
			|||
		return exportEntity; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
} | 
				
			|||
@ -0,0 +1,476 @@ | 
				
			|||
/** | 
				
			|||
 * Copyright 2013-2015 JEECG (jeecgos@163.com) | 
				
			|||
 * | 
				
			|||
 *  Licensed under the Apache License, Version 2.0 (the "License"); | 
				
			|||
 *  you may not use this file except in compliance with the License. | 
				
			|||
 *  You may obtain a copy of the License at | 
				
			|||
 * | 
				
			|||
 *     http://www.apache.org/licenses/LICENSE-2.0
 | 
				
			|||
 * | 
				
			|||
 *  Unless required by applicable law or agreed to in writing, software | 
				
			|||
 * distributed under the License is distributed on an "AS IS" BASIS, | 
				
			|||
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | 
				
			|||
 * See the License for the specific language governing permissions and | 
				
			|||
 * limitations under the License. | 
				
			|||
 */ | 
				
			|||
package cc.admin.poi.excel.export.base; | 
				
			|||
 | 
				
			|||
import cc.admin.poi.excel.entity.enmus.ExcelType; | 
				
			|||
import cc.admin.poi.excel.entity.params.ExcelExportEntity; | 
				
			|||
import cc.admin.poi.excel.entity.vo.PoiBaseConstants; | 
				
			|||
import cc.admin.poi.excel.export.styler.IExcelExportStyler; | 
				
			|||
import cc.admin.poi.util.PoiMergeCellUtil; | 
				
			|||
import cc.admin.poi.util.PoiPublicUtil; | 
				
			|||
import org.apache.commons.lang3.StringUtils; | 
				
			|||
import org.apache.poi.hssf.usermodel.HSSFClientAnchor; | 
				
			|||
import org.apache.poi.hssf.usermodel.HSSFRichTextString; | 
				
			|||
import org.apache.poi.ss.usermodel.*; | 
				
			|||
import org.apache.poi.ss.util.CellRangeAddress; | 
				
			|||
import org.apache.poi.xssf.usermodel.XSSFClientAnchor; | 
				
			|||
import org.apache.poi.xssf.usermodel.XSSFRichTextString; | 
				
			|||
import org.slf4j.Logger; | 
				
			|||
import org.slf4j.LoggerFactory; | 
				
			|||
 | 
				
			|||
import javax.imageio.ImageIO; | 
				
			|||
import java.awt.image.BufferedImage; | 
				
			|||
import java.io.ByteArrayOutputStream; | 
				
			|||
import java.io.File; | 
				
			|||
import java.io.IOException; | 
				
			|||
import java.io.InputStream; | 
				
			|||
import java.net.HttpURLConnection; | 
				
			|||
import java.net.URL; | 
				
			|||
import java.text.DecimalFormat; | 
				
			|||
import java.util.*; | 
				
			|||
 | 
				
			|||
/** | 
				
			|||
 * 提供POI基础操作服务 | 
				
			|||
 * | 
				
			|||
 * @author JEECG | 
				
			|||
 * @date 2014年6月17日 下午6:15:13 | 
				
			|||
 */ | 
				
			|||
public abstract class ExcelExportBase extends ExportBase { | 
				
			|||
 | 
				
			|||
	private static final Logger LOGGER = LoggerFactory.getLogger(ExcelExportBase.class); | 
				
			|||
 | 
				
			|||
	private int currentIndex = 0; | 
				
			|||
 | 
				
			|||
	protected ExcelType type = ExcelType.HSSF; | 
				
			|||
 | 
				
			|||
	private Map<Integer, Double> statistics = new HashMap<Integer, Double>(); | 
				
			|||
 | 
				
			|||
	private static final DecimalFormat DOUBLE_FORMAT = new DecimalFormat("######0.00"); | 
				
			|||
 | 
				
			|||
	private IExcelExportStyler excelExportStyler; | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 创建 最主要的 Cells | 
				
			|||
	 * | 
				
			|||
	 * @param rowHeight | 
				
			|||
	 * @throws Exception | 
				
			|||
	 */ | 
				
			|||
	public int createCells(Drawing patriarch, int index, Object t, List<ExcelExportEntity> excelParams, Sheet sheet, Workbook workbook, short rowHeight) throws Exception { | 
				
			|||
		ExcelExportEntity entity; | 
				
			|||
		Row row = sheet.createRow(index); | 
				
			|||
		row.setHeight(rowHeight); | 
				
			|||
		int maxHeight = 1, cellNum = 0; | 
				
			|||
		int indexKey = createIndexCell(row, index, excelParams.get(0)); | 
				
			|||
		cellNum += indexKey; | 
				
			|||
		for (int k = indexKey, paramSize = excelParams.size(); k < paramSize; k++) { | 
				
			|||
			entity = excelParams.get(k); | 
				
			|||
			//update-begin-author:taoyan date:20200319 for:建议autoPoi升级,优化数据返回List Map格式下的复合表头导出excel的体验 #873
 | 
				
			|||
			if(entity.isSubColumn()){ | 
				
			|||
				continue; | 
				
			|||
			} | 
				
			|||
			if(entity.isMergeColumn()){ | 
				
			|||
				Map<String,Object> subColumnMap = new HashMap<>(); | 
				
			|||
				List<String> mapKeys = entity.getSubColumnList(); | 
				
			|||
				for (String subKey : mapKeys) { | 
				
			|||
					Object subKeyValue = null; | 
				
			|||
					if (t instanceof Map) { | 
				
			|||
						subKeyValue = ((Map<?, ?>) t).get(subKey); | 
				
			|||
					}else{ | 
				
			|||
						subKeyValue = PoiPublicUtil.getParamsValue(subKey,t); | 
				
			|||
					} | 
				
			|||
					subColumnMap.put(subKey,subKeyValue); | 
				
			|||
				} | 
				
			|||
				createListCells(patriarch, index, cellNum, subColumnMap, entity.getList(), sheet, workbook); | 
				
			|||
				cellNum += entity.getSubColumnList().size(); | 
				
			|||
			//update-end-author:taoyan date:20200319 for:建议autoPoi升级,优化数据返回List Map格式下的复合表头导出excel的体验 #873
 | 
				
			|||
			} else if (entity.getList() != null) { | 
				
			|||
				Collection<?> list = getListCellValue(entity, t); | 
				
			|||
				int listC = 0; | 
				
			|||
				for (Object obj : list) { | 
				
			|||
					createListCells(patriarch, index + listC, cellNum, obj, entity.getList(), sheet, workbook); | 
				
			|||
					listC++; | 
				
			|||
				} | 
				
			|||
				cellNum += entity.getList().size(); | 
				
			|||
				if (list != null && list.size() > maxHeight) { | 
				
			|||
					maxHeight = list.size(); | 
				
			|||
				} | 
				
			|||
			} else { | 
				
			|||
				Object value = getCellValue(entity, t); | 
				
			|||
				//update-begin--Author:xuelin  Date:20171018 for:TASK #2372 【excel】easypoi 导出类型,type增加数字类型--------------------
 | 
				
			|||
				if (entity.getType() == 1) { | 
				
			|||
					createStringCell(row, cellNum++, value == null ? "" : value.toString(), index % 2 == 0 ? getStyles(false, entity) : getStyles(true, entity), entity); | 
				
			|||
				} else if (entity.getType() == 4){ | 
				
			|||
					createNumericCell(row, cellNum++, value == null ? "" : value.toString(), index % 2 == 0 ? getStyles(false, entity) : getStyles(true, entity), entity); | 
				
			|||
				} else { | 
				
			|||
					createImageCell(patriarch, entity, row, cellNum++, value == null ? "" : value.toString(), t); | 
				
			|||
				} | 
				
			|||
				//update-end--Author:xuelin  Date:20171018 for:TASK #2372 【excel】easypoi 导出类型,type增加数字类型--------------------
 | 
				
			|||
			} | 
				
			|||
		} | 
				
			|||
		// 合并需要合并的单元格
 | 
				
			|||
		cellNum = 0; | 
				
			|||
		for (int k = indexKey, paramSize = excelParams.size(); k < paramSize; k++) { | 
				
			|||
			entity = excelParams.get(k); | 
				
			|||
			if (entity.getList() != null) { | 
				
			|||
				cellNum += entity.getList().size(); | 
				
			|||
			} else if (entity.isNeedMerge()) { | 
				
			|||
				for (int i = index + 1; i < index + maxHeight; i++) { | 
				
			|||
					sheet.getRow(i).createCell(cellNum); | 
				
			|||
					sheet.getRow(i).getCell(cellNum).setCellStyle(getStyles(false, entity)); | 
				
			|||
				} | 
				
			|||
				sheet.addMergedRegion(new CellRangeAddress(index, index + maxHeight - 1, cellNum, cellNum)); | 
				
			|||
				cellNum++; | 
				
			|||
			} | 
				
			|||
		} | 
				
			|||
		return maxHeight; | 
				
			|||
 | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 图片类型的Cell | 
				
			|||
	 * | 
				
			|||
	 * @param patriarch | 
				
			|||
	 * @param entity | 
				
			|||
	 * @param row | 
				
			|||
	 * @param i | 
				
			|||
	 * @param imagePath | 
				
			|||
	 * @param obj | 
				
			|||
	 * @throws Exception | 
				
			|||
	 */ | 
				
			|||
	public void createImageCell(Drawing patriarch, ExcelExportEntity entity, Row row, int i, String imagePath, Object obj) throws Exception { | 
				
			|||
		row.setHeight((short) (50 * entity.getHeight())); | 
				
			|||
		row.createCell(i); | 
				
			|||
		ClientAnchor anchor; | 
				
			|||
		if (type.equals(ExcelType.HSSF)) { | 
				
			|||
			anchor = new HSSFClientAnchor(0, 0, 0, 0, (short) i, row.getRowNum(), (short) (i + 1), row.getRowNum() + 1); | 
				
			|||
		} else { | 
				
			|||
			anchor = new XSSFClientAnchor(0, 0, 0, 0, (short) i, row.getRowNum(), (short) (i + 1), row.getRowNum() + 1); | 
				
			|||
		} | 
				
			|||
 | 
				
			|||
		if (StringUtils.isEmpty(imagePath)) { | 
				
			|||
			return; | 
				
			|||
		} | 
				
			|||
 | 
				
			|||
		//update-beign-author:taoyan date:20200302 for:【多任务】online 专项集中问题 LOWCOD-159
 | 
				
			|||
		int imageType = entity.getExportImageType(); | 
				
			|||
		byte[] value = null; | 
				
			|||
		if(imageType == 2){ | 
				
			|||
			//原来逻辑 2
 | 
				
			|||
			value = (byte[]) (entity.getMethods() != null ? getFieldBySomeMethod(entity.getMethods(), obj) : entity.getMethod().invoke(obj, new Object[] {})); | 
				
			|||
		} else if(imageType==4 || imagePath.startsWith("http")){ | 
				
			|||
			//新增逻辑 网络图片4
 | 
				
			|||
			try { | 
				
			|||
				if (imagePath.indexOf(",") != -1) { | 
				
			|||
					if(imagePath.startsWith(",")){ | 
				
			|||
						imagePath = imagePath.substring(1); | 
				
			|||
					} | 
				
			|||
					String[] images = imagePath.split(","); | 
				
			|||
					imagePath = images[0]; | 
				
			|||
				} | 
				
			|||
				URL url = new URL(imagePath); | 
				
			|||
				HttpURLConnection conn = (HttpURLConnection) url.openConnection(); | 
				
			|||
				conn.setRequestMethod("GET"); | 
				
			|||
				conn.setConnectTimeout(5 * 1000); | 
				
			|||
				InputStream inStream = conn.getInputStream(); | 
				
			|||
				value = readInputStream(inStream); | 
				
			|||
			} catch (Exception exception) { | 
				
			|||
				LOGGER.warn(exception.getMessage()); | 
				
			|||
				//exception.printStackTrace();
 | 
				
			|||
			} | 
				
			|||
		} else { | 
				
			|||
			ByteArrayOutputStream byteArrayOut = new ByteArrayOutputStream(); | 
				
			|||
			BufferedImage bufferImg; | 
				
			|||
			String path = null; | 
				
			|||
			if(imageType == 1){ | 
				
			|||
				//原来逻辑 1
 | 
				
			|||
				path = PoiPublicUtil.getWebRootPath(imagePath); | 
				
			|||
				LOGGER.debug("--- createImageCell getWebRootPath ----filePath--- "+ path); | 
				
			|||
				path = path.replace("WEB-INF/classes/", ""); | 
				
			|||
				path = path.replace("file:/", ""); | 
				
			|||
			}else if(imageType==3){ | 
				
			|||
				//新增逻辑 本地图片3
 | 
				
			|||
				if(!entity.getImageBasePath().endsWith(File.separator) && !imagePath.startsWith(File.separator)){ | 
				
			|||
					path = entity.getImageBasePath()+File.separator+imagePath; | 
				
			|||
				}else{ | 
				
			|||
					path = entity.getImageBasePath()+imagePath; | 
				
			|||
				} | 
				
			|||
			} | 
				
			|||
			try { | 
				
			|||
				bufferImg = ImageIO.read(new File(path)); | 
				
			|||
				ImageIO.write(bufferImg, imagePath.substring(imagePath.indexOf(".") + 1, imagePath.length()), byteArrayOut); | 
				
			|||
				value = byteArrayOut.toByteArray(); | 
				
			|||
			} catch (IOException e) { | 
				
			|||
				LOGGER.error(e.getMessage(), e); | 
				
			|||
			} | 
				
			|||
		} | 
				
			|||
		if (value != null) { | 
				
			|||
			patriarch.createPicture(anchor, row.getSheet().getWorkbook().addPicture(value, getImageType(value))); | 
				
			|||
		} | 
				
			|||
		//update-end-author:taoyan date:20200302 for:【多任务】online 专项集中问题 LOWCOD-159
 | 
				
			|||
 | 
				
			|||
 | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * inStream读取到字节数组 | 
				
			|||
	 * @param inStream | 
				
			|||
	 * @return | 
				
			|||
	 * @throws Exception | 
				
			|||
	 */ | 
				
			|||
	private byte[] readInputStream(InputStream inStream) throws Exception { | 
				
			|||
		if(inStream==null){ | 
				
			|||
			return null; | 
				
			|||
		} | 
				
			|||
		ByteArrayOutputStream outStream = new ByteArrayOutputStream(); | 
				
			|||
		byte[] buffer = new byte[1024]; | 
				
			|||
		int len = 0; | 
				
			|||
		//每次读取的字符串长度,如果为-1,代表全部读取完毕
 | 
				
			|||
		while ((len = inStream.read(buffer)) != -1) { | 
				
			|||
			outStream.write(buffer, 0, len); | 
				
			|||
		} | 
				
			|||
		inStream.close(); | 
				
			|||
		return outStream.toByteArray(); | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	private int createIndexCell(Row row, int index, ExcelExportEntity excelExportEntity) { | 
				
			|||
		if (excelExportEntity.getName().equals("序号") && excelExportEntity.getFormat().equals(PoiBaseConstants.IS_ADD_INDEX)) { | 
				
			|||
			createStringCell(row, 0, currentIndex + "", index % 2 == 0 ? getStyles(false, null) : getStyles(true, null), null); | 
				
			|||
			currentIndex = currentIndex + 1; | 
				
			|||
			return 1; | 
				
			|||
		} | 
				
			|||
		return 0; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 创建List之后的各个Cells | 
				
			|||
	 * | 
				
			|||
	 */ | 
				
			|||
	public void createListCells(Drawing patriarch, int index, int cellNum, Object obj, List<ExcelExportEntity> excelParams, Sheet sheet, Workbook workbook) throws Exception { | 
				
			|||
		ExcelExportEntity entity; | 
				
			|||
		Row row; | 
				
			|||
		if (sheet.getRow(index) == null) { | 
				
			|||
			row = sheet.createRow(index); | 
				
			|||
			row.setHeight(getRowHeight(excelParams)); | 
				
			|||
		} else { | 
				
			|||
			row = sheet.getRow(index); | 
				
			|||
		} | 
				
			|||
		for (int k = 0, paramSize = excelParams.size(); k < paramSize; k++) { | 
				
			|||
			entity = excelParams.get(k); | 
				
			|||
			Object value = getCellValue(entity, obj); | 
				
			|||
			//update-begin--Author:xuelin  Date:20171018 for:TASK #2372 【excel】easypoi 导出类型,type增加数字类型--------------------
 | 
				
			|||
			if (entity.getType() == 1) { | 
				
			|||
				createStringCell(row, cellNum++, value == null ? "" : value.toString(), row.getRowNum() % 2 == 0 ? getStyles(false, entity) : getStyles(true, entity), entity); | 
				
			|||
			} else if (entity.getType() == 4){ | 
				
			|||
				createNumericCell(row, cellNum++, value == null ? "" : value.toString(), index % 2 == 0 ? getStyles(false, entity) : getStyles(true, entity), entity); | 
				
			|||
			}  else{ | 
				
			|||
				createImageCell(patriarch, entity, row, cellNum++, value == null ? "" : value.toString(), obj); | 
				
			|||
			} | 
				
			|||
			//update-end--Author:xuelin  Date:20171018 for:TASK #2372 【excel】easypoi 导出类型,type增加数字类型--------------------
 | 
				
			|||
		} | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	//update-begin--Author:xuelin  Date:20171018 for:TASK #2372 【excel】easypoi 导出类型,type增加数字类型--------------------
 | 
				
			|||
	public void createNumericCell (Row row, int index, String text, CellStyle style, ExcelExportEntity entity) { | 
				
			|||
		Cell cell = row.createCell(index); | 
				
			|||
		if(StringUtils.isEmpty(text)){ | 
				
			|||
			cell.setCellValue(""); | 
				
			|||
			cell.setCellType(CellType.BLANK); | 
				
			|||
		}else{ | 
				
			|||
			cell.setCellValue(Double.parseDouble(text)); | 
				
			|||
			cell.setCellType(CellType.NUMERIC); | 
				
			|||
		} | 
				
			|||
		if (style != null) { | 
				
			|||
			cell.setCellStyle(style); | 
				
			|||
		} | 
				
			|||
		addStatisticsData(index, text, entity); | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 创建文本类型的Cell | 
				
			|||
	 * | 
				
			|||
	 * @param row | 
				
			|||
	 * @param index | 
				
			|||
	 * @param text | 
				
			|||
	 * @param style | 
				
			|||
	 * @param entity | 
				
			|||
	 */ | 
				
			|||
	public void createStringCell(Row row, int index, String text, CellStyle style, ExcelExportEntity entity) { | 
				
			|||
		Cell cell = row.createCell(index); | 
				
			|||
		if (style != null && style.getDataFormat() > 0 && style.getDataFormat() < 12) { | 
				
			|||
			cell.setCellValue(Double.parseDouble(text)); | 
				
			|||
			cell.setCellType(CellType.NUMERIC); | 
				
			|||
		}else{ | 
				
			|||
			RichTextString Rtext; | 
				
			|||
			if (type.equals(ExcelType.HSSF)) { | 
				
			|||
				Rtext = new HSSFRichTextString(text); | 
				
			|||
			} else { | 
				
			|||
				Rtext = new XSSFRichTextString(text); | 
				
			|||
			} | 
				
			|||
			cell.setCellValue(Rtext); | 
				
			|||
		} | 
				
			|||
		if (style != null) { | 
				
			|||
			cell.setCellStyle(style); | 
				
			|||
		} | 
				
			|||
		addStatisticsData(index, text, entity); | 
				
			|||
	} | 
				
			|||
	//update-end--Author:xuelin  Date:20171018 for:TASK #2372 【excel】easypoi 导出类型,type增加数字类型----------------------
 | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 创建统计行 | 
				
			|||
	 * | 
				
			|||
	 * @param styles | 
				
			|||
	 * @param sheet | 
				
			|||
	 */ | 
				
			|||
	public void addStatisticsRow(CellStyle styles, Sheet sheet) { | 
				
			|||
		if (statistics.size() > 0) { | 
				
			|||
			Row row = sheet.createRow(sheet.getLastRowNum() + 1); | 
				
			|||
			Set<Integer> keys = statistics.keySet(); | 
				
			|||
			createStringCell(row, 0, "合计", styles, null); | 
				
			|||
			for (Integer key : keys) { | 
				
			|||
				createStringCell(row, key, DOUBLE_FORMAT.format(statistics.get(key)), styles, null); | 
				
			|||
			} | 
				
			|||
			statistics.clear(); | 
				
			|||
		} | 
				
			|||
 | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 合计统计信息 | 
				
			|||
	 * | 
				
			|||
	 * @param index | 
				
			|||
	 * @param text | 
				
			|||
	 * @param entity | 
				
			|||
	 */ | 
				
			|||
	private void addStatisticsData(Integer index, String text, ExcelExportEntity entity) { | 
				
			|||
		if (entity != null && entity.isStatistics()) { | 
				
			|||
			Double temp = 0D; | 
				
			|||
			if (!statistics.containsKey(index)) { | 
				
			|||
				statistics.put(index, temp); | 
				
			|||
			} | 
				
			|||
			try { | 
				
			|||
				temp = Double.valueOf(text); | 
				
			|||
			} catch (NumberFormatException e) { | 
				
			|||
			} | 
				
			|||
			statistics.put(index, statistics.get(index) + temp); | 
				
			|||
		} | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 获取导出报表的字段总长度 | 
				
			|||
	 * | 
				
			|||
	 * @param excelParams | 
				
			|||
	 * @return | 
				
			|||
	 */ | 
				
			|||
	public int getFieldWidth(List<ExcelExportEntity> excelParams) { | 
				
			|||
		int length = -1;// 从0开始计算单元格的
 | 
				
			|||
		for (ExcelExportEntity entity : excelParams) { | 
				
			|||
			length += entity.getList() != null ? entity.getList().size() : 1; | 
				
			|||
		} | 
				
			|||
		return length; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 获取图片类型,设置图片插入类型 | 
				
			|||
	 * | 
				
			|||
	 * @param value | 
				
			|||
	 * @return | 
				
			|||
	 * @Author JEECG | 
				
			|||
	 * @date 2013年11月25日 | 
				
			|||
	 */ | 
				
			|||
	public int getImageType(byte[] value) { | 
				
			|||
		String type = PoiPublicUtil.getFileExtendName(value); | 
				
			|||
		if (type.equalsIgnoreCase("JPG")) { | 
				
			|||
			return Workbook.PICTURE_TYPE_JPEG; | 
				
			|||
		} else if (type.equalsIgnoreCase("PNG")) { | 
				
			|||
			return Workbook.PICTURE_TYPE_PNG; | 
				
			|||
		} | 
				
			|||
		return Workbook.PICTURE_TYPE_JPEG; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	private Map<Integer, int[]> getMergeDataMap(List<ExcelExportEntity> excelParams) { | 
				
			|||
		Map<Integer, int[]> mergeMap = new HashMap<Integer, int[]>(); | 
				
			|||
		// 设置参数顺序,为之后合并单元格做准备
 | 
				
			|||
		int i = 0; | 
				
			|||
		for (ExcelExportEntity entity : excelParams) { | 
				
			|||
			if (entity.isMergeVertical()) { | 
				
			|||
				mergeMap.put(i, entity.getMergeRely()); | 
				
			|||
			} | 
				
			|||
			if (entity.getList() != null) { | 
				
			|||
				for (ExcelExportEntity inner : entity.getList()) { | 
				
			|||
					if (inner.isMergeVertical()) { | 
				
			|||
						mergeMap.put(i, inner.getMergeRely()); | 
				
			|||
					} | 
				
			|||
					i++; | 
				
			|||
				} | 
				
			|||
			} else { | 
				
			|||
				i++; | 
				
			|||
			} | 
				
			|||
		} | 
				
			|||
		return mergeMap; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 获取样式 | 
				
			|||
	 * | 
				
			|||
	 * @param entity | 
				
			|||
	 * @param needOne | 
				
			|||
	 * @return | 
				
			|||
	 */ | 
				
			|||
	public CellStyle getStyles(boolean needOne, ExcelExportEntity entity) { | 
				
			|||
		return excelExportStyler.getStyles(needOne, entity); | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 合并单元格 | 
				
			|||
	 * | 
				
			|||
	 * @param sheet | 
				
			|||
	 * @param excelParams | 
				
			|||
	 * @param titleHeight | 
				
			|||
	 */ | 
				
			|||
	public void mergeCells(Sheet sheet, List<ExcelExportEntity> excelParams, int titleHeight) { | 
				
			|||
		Map<Integer, int[]> mergeMap = getMergeDataMap(excelParams); | 
				
			|||
		PoiMergeCellUtil.mergeCells(sheet, mergeMap, titleHeight); | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setCellWith(List<ExcelExportEntity> excelParams, Sheet sheet) { | 
				
			|||
		int index = 0; | 
				
			|||
		for (int i = 0; i < excelParams.size(); i++) { | 
				
			|||
			if (excelParams.get(i).getList() != null) { | 
				
			|||
				List<ExcelExportEntity> list = excelParams.get(i).getList(); | 
				
			|||
				for (int j = 0; j < list.size(); j++) { | 
				
			|||
					sheet.setColumnWidth(index, (int) (256 * list.get(j).getWidth())); | 
				
			|||
					index++; | 
				
			|||
				} | 
				
			|||
			} else { | 
				
			|||
				sheet.setColumnWidth(index, (int) (256 * excelParams.get(i).getWidth())); | 
				
			|||
				index++; | 
				
			|||
			} | 
				
			|||
		} | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setCurrentIndex(int currentIndex) { | 
				
			|||
		this.currentIndex = currentIndex; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setExcelExportStyler(IExcelExportStyler excelExportStyler) { | 
				
			|||
		this.excelExportStyler = excelExportStyler; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public IExcelExportStyler getExcelExportStyler() { | 
				
			|||
		return excelExportStyler; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
} | 
				
			|||
@ -0,0 +1,452 @@ | 
				
			|||
/** | 
				
			|||
 * Copyright 2013-2015 JEECG (jeecgos@163.com) | 
				
			|||
 * | 
				
			|||
 *  Licensed under the Apache License, Version 2.0 (the "License"); | 
				
			|||
 *  you may not use this file except in compliance with the License. | 
				
			|||
 *  You may obtain a copy of the License at | 
				
			|||
 * | 
				
			|||
 *     http://www.apache.org/licenses/LICENSE-2.0
 | 
				
			|||
 * | 
				
			|||
 *  Unless required by applicable law or agreed to in writing, software | 
				
			|||
 * distributed under the License is distributed on an "AS IS" BASIS, | 
				
			|||
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | 
				
			|||
 * See the License for the specific language governing permissions and | 
				
			|||
 * limitations under the License. | 
				
			|||
 */ | 
				
			|||
package cc.admin.poi.excel.export.base; | 
				
			|||
 | 
				
			|||
import java.lang.reflect.Field; | 
				
			|||
import java.lang.reflect.Method; | 
				
			|||
import java.lang.reflect.ParameterizedType; | 
				
			|||
import java.text.DecimalFormat; | 
				
			|||
import java.text.SimpleDateFormat; | 
				
			|||
import java.util.*; | 
				
			|||
 | 
				
			|||
import cc.admin.poi.excel.entity.ExportParams; | 
				
			|||
import cc.admin.poi.util.PoiPublicUtil; | 
				
			|||
import org.apache.commons.lang3.StringUtils; | 
				
			|||
import cc.admin.core.util.ApplicationContextUtil; | 
				
			|||
import cc.admin.dict.service.AutoPoiDictServiceI; | 
				
			|||
import cc.admin.poi.excel.annotation.Excel; | 
				
			|||
import cc.admin.poi.excel.annotation.ExcelCollection; | 
				
			|||
import cc.admin.poi.excel.annotation.ExcelEntity; | 
				
			|||
import cc.admin.poi.excel.entity.params.ExcelExportEntity; | 
				
			|||
import cc.admin.poi.handler.inter.IExcelDataHandler; | 
				
			|||
 | 
				
			|||
/** | 
				
			|||
 * 导出基础处理,不设计POI,只设计对象,保证复用性 | 
				
			|||
 * | 
				
			|||
 * @author JEECG | 
				
			|||
 * @date 2014年8月9日 下午11:01:32 | 
				
			|||
 */ | 
				
			|||
public class ExportBase { | 
				
			|||
 | 
				
			|||
	protected IExcelDataHandler dataHanlder; | 
				
			|||
 | 
				
			|||
	protected List<String> needHanlderList; | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 创建导出实体对象 | 
				
			|||
	 * | 
				
			|||
	 * @param field | 
				
			|||
	 * @param targetId | 
				
			|||
	 * @param pojoClass | 
				
			|||
	 * @param getMethods | 
				
			|||
	 * @return | 
				
			|||
	 * @throws Exception | 
				
			|||
	 */ | 
				
			|||
	private ExcelExportEntity createExcelExportEntity(Field field, String targetId, Class<?> pojoClass, List<Method> getMethods) throws Exception { | 
				
			|||
		Excel excel = field.getAnnotation(Excel.class); | 
				
			|||
		ExcelExportEntity excelEntity = new ExcelExportEntity(); | 
				
			|||
		excelEntity.setType(excel.type()); | 
				
			|||
		getExcelField(targetId, field, excelEntity, excel, pojoClass); | 
				
			|||
		if (getMethods != null) { | 
				
			|||
			List<Method> newMethods = new ArrayList<Method>(); | 
				
			|||
			newMethods.addAll(getMethods); | 
				
			|||
			newMethods.add(excelEntity.getMethod()); | 
				
			|||
			excelEntity.setMethods(newMethods); | 
				
			|||
		} | 
				
			|||
		return excelEntity; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	private Object formatValue(Object value, ExcelExportEntity entity) throws Exception { | 
				
			|||
		Date temp = null; | 
				
			|||
		if (value instanceof String) { | 
				
			|||
			SimpleDateFormat format = new SimpleDateFormat(entity.getDatabaseFormat()); | 
				
			|||
			temp = format.parse(value.toString()); | 
				
			|||
		} else if (value instanceof Date) { | 
				
			|||
			temp = (Date) value; | 
				
			|||
		} | 
				
			|||
		if (temp != null) { | 
				
			|||
			SimpleDateFormat format = new SimpleDateFormat(entity.getFormat()); | 
				
			|||
			value = format.format(temp); | 
				
			|||
		} | 
				
			|||
		return value; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 获取需要导出的全部字段 | 
				
			|||
	 * | 
				
			|||
	 * @param exclusions | 
				
			|||
	 * @param targetId | 
				
			|||
	 *            目标ID | 
				
			|||
	 * @param fields | 
				
			|||
	 * @throws Exception | 
				
			|||
	 */ | 
				
			|||
	public void getAllExcelField(String[] exclusions, String targetId, Field[] fields, List<ExcelExportEntity> excelParams, Class<?> pojoClass, List<Method> getMethods) throws Exception { | 
				
			|||
		List<String> exclusionsList = exclusions != null ? Arrays.asList(exclusions) : null; | 
				
			|||
		ExcelExportEntity excelEntity; | 
				
			|||
		// 遍历整个filed
 | 
				
			|||
		for (int i = 0; i < fields.length; i++) { | 
				
			|||
			Field field = fields[i]; | 
				
			|||
			// 先判断是不是collection,在判断是不是java自带对象,之后就是我们自己的对象了
 | 
				
			|||
			if (PoiPublicUtil.isNotUserExcelUserThis(exclusionsList, field, targetId)) { | 
				
			|||
				continue; | 
				
			|||
			} | 
				
			|||
			// 首先判断Excel 可能一下特殊数据用户回自定义处理
 | 
				
			|||
			if (field.getAnnotation(Excel.class) != null) { | 
				
			|||
				excelParams.add(createExcelExportEntity(field, targetId, pojoClass, getMethods)); | 
				
			|||
			} else if (PoiPublicUtil.isCollection(field.getType())) { | 
				
			|||
				ExcelCollection excel = field.getAnnotation(ExcelCollection.class); | 
				
			|||
				ParameterizedType pt = (ParameterizedType) field.getGenericType(); | 
				
			|||
				Class<?> clz = (Class<?>) pt.getActualTypeArguments()[0]; | 
				
			|||
				List<ExcelExportEntity> list = new ArrayList<ExcelExportEntity>(); | 
				
			|||
				getAllExcelField(exclusions, StringUtils.isNotEmpty(excel.id()) ? excel.id() : targetId, PoiPublicUtil.getClassFields(clz), list, clz, null); | 
				
			|||
				excelEntity = new ExcelExportEntity(); | 
				
			|||
				excelEntity.setName(getExcelName(excel.name(), targetId)); | 
				
			|||
				excelEntity.setOrderNum(getCellOrder(excel.orderNum(), targetId)); | 
				
			|||
				excelEntity.setMethod(PoiPublicUtil.getMethod(field.getName(), pojoClass)); | 
				
			|||
				excelEntity.setList(list); | 
				
			|||
				excelParams.add(excelEntity); | 
				
			|||
			} else { | 
				
			|||
				List<Method> newMethods = new ArrayList<Method>(); | 
				
			|||
				if (getMethods != null) { | 
				
			|||
					newMethods.addAll(getMethods); | 
				
			|||
				} | 
				
			|||
				newMethods.add(PoiPublicUtil.getMethod(field.getName(), pojoClass)); | 
				
			|||
				ExcelEntity excel = field.getAnnotation(ExcelEntity.class); | 
				
			|||
				getAllExcelField(exclusions, StringUtils.isNotEmpty(excel.id()) ? excel.id() : targetId, PoiPublicUtil.getClassFields(field.getType()), excelParams, field.getType(), newMethods); | 
				
			|||
			} | 
				
			|||
		} | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 获取这个字段的顺序 | 
				
			|||
	 * | 
				
			|||
	 * @param orderNum | 
				
			|||
	 * @param targetId | 
				
			|||
	 * @return | 
				
			|||
	 */ | 
				
			|||
	public int getCellOrder(String orderNum, String targetId) { | 
				
			|||
		if (isInteger(orderNum) || targetId == null) { | 
				
			|||
			return Integer.valueOf(orderNum); | 
				
			|||
		} | 
				
			|||
		String[] arr = orderNum.split(","); | 
				
			|||
		String[] temp; | 
				
			|||
		for (String str : arr) { | 
				
			|||
			temp = str.split("_"); | 
				
			|||
			if (targetId.equals(temp[1])) { | 
				
			|||
				return Integer.valueOf(temp[0]); | 
				
			|||
			} | 
				
			|||
		} | 
				
			|||
		return 0; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 获取填如这个cell的值,提供一些附加功能 | 
				
			|||
	 * | 
				
			|||
	 * @param entity | 
				
			|||
	 * @param obj | 
				
			|||
	 * @return | 
				
			|||
	 * @throws Exception | 
				
			|||
	 */ | 
				
			|||
	public Object getCellValue(ExcelExportEntity entity, Object obj) throws Exception { | 
				
			|||
		Object value; | 
				
			|||
		if (obj instanceof Map) { | 
				
			|||
			value = ((Map<?, ?>) obj).get(entity.getKey()); | 
				
			|||
		} else { | 
				
			|||
			value = entity.getMethods() != null ? getFieldBySomeMethod(entity.getMethods(), obj) : entity.getMethod().invoke(obj, new Object[] {}); | 
				
			|||
		} | 
				
			|||
		//update-begin-author:taoyan date:2020319 for:Excel注解的numFormat方法似乎未实现 #970
 | 
				
			|||
		if (StringUtils.isNotEmpty(entity.getNumFormat()) && value!=null) { | 
				
			|||
			value = new DecimalFormat(entity.getNumFormat()).format(value); | 
				
			|||
		} | 
				
			|||
		//update-end-author:taoyan date:2020319 for:Excel注解的numFormat方法似乎未实现 #970
 | 
				
			|||
 | 
				
			|||
		if (StringUtils.isNotEmpty(entity.getFormat())) { | 
				
			|||
			value = formatValue(value, entity); | 
				
			|||
		} | 
				
			|||
		if (entity.getReplace() != null && entity.getReplace().length > 0) { | 
				
			|||
			//update-begin-author:taoyan date:20180731 for:TASK #3038 【bug】Excel 导出多个值(逗号隔开的情况下,导出字典值是ID值)
 | 
				
			|||
			if(value == null){ | 
				
			|||
				value = "";//String.valueOf(value) 如果value为null 则返回"null"
 | 
				
			|||
			} | 
				
			|||
			if(entity.isMultiReplace()){ | 
				
			|||
				value = multiReplaceValue(entity.getReplace(), String.valueOf(value)); | 
				
			|||
			}else{ | 
				
			|||
				value = replaceValue(entity.getReplace(), String.valueOf(value)); | 
				
			|||
			} | 
				
			|||
			//update-end-author:taoyan date:20180731 for:TASK #3038 【bug】Excel 导出多个值(逗号隔开的情况下,导出字典值是ID值)
 | 
				
			|||
		} | 
				
			|||
		if (needHanlderList != null && needHanlderList.contains(entity.getName())) { | 
				
			|||
			value = dataHanlder.exportHandler(obj, entity.getName(), value); | 
				
			|||
		} | 
				
			|||
		if (StringUtils.isNotEmpty(entity.getSuffix()) && value != null) { | 
				
			|||
			value = value + entity.getSuffix(); | 
				
			|||
		} | 
				
			|||
		return value == null ? "" : value.toString(); | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 获取集合的值 | 
				
			|||
	 * | 
				
			|||
	 * @param entity | 
				
			|||
	 * @param obj | 
				
			|||
	 * @return | 
				
			|||
	 * @throws Exception | 
				
			|||
	 */ | 
				
			|||
	public Collection<?> getListCellValue(ExcelExportEntity entity, Object obj) throws Exception { | 
				
			|||
		Object value; | 
				
			|||
		if (obj instanceof Map) { | 
				
			|||
			value = ((Map<?, ?>) obj).get(entity.getKey()); | 
				
			|||
		} else { | 
				
			|||
			value = (Collection<?>) entity.getMethod().invoke(obj, new Object[] {}); | 
				
			|||
		} | 
				
			|||
		return (Collection<?>) value; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 注解到导出对象的转换 | 
				
			|||
	 * | 
				
			|||
	 * @param targetId | 
				
			|||
	 * @param field | 
				
			|||
	 * @param excelEntity | 
				
			|||
	 * @param excel | 
				
			|||
	 * @param pojoClass | 
				
			|||
	 * @throws Exception | 
				
			|||
	 */ | 
				
			|||
	private void getExcelField(String targetId, Field field, ExcelExportEntity excelEntity, Excel excel, Class<?> pojoClass) throws Exception { | 
				
			|||
		excelEntity.setName(getExcelName(excel.name(), targetId)); | 
				
			|||
		excelEntity.setWidth(excel.width()); | 
				
			|||
		excelEntity.setHeight(excel.height()); | 
				
			|||
		excelEntity.setNeedMerge(excel.needMerge()); | 
				
			|||
		excelEntity.setMergeVertical(excel.mergeVertical()); | 
				
			|||
		excelEntity.setMergeRely(excel.mergeRely()); | 
				
			|||
		excelEntity.setReplace(excel.replace()); | 
				
			|||
		if(StringUtils.isNotEmpty(excel.dicCode())){ | 
				
			|||
			AutoPoiDictServiceI ccDictService = null; | 
				
			|||
			try { | 
				
			|||
				ccDictService = ApplicationContextUtil.getContext().getBean(AutoPoiDictServiceI.class); | 
				
			|||
			} catch (Exception e) { | 
				
			|||
			} | 
				
			|||
			if(ccDictService!=null){ | 
				
			|||
				 String[] dictReplace = ccDictService.queryDict(excel.dictTable(), excel.dicCode(), excel.dicText()); | 
				
			|||
				 if(excelEntity.getReplace()!=null && dictReplace!=null && dictReplace.length!=0){ | 
				
			|||
					 excelEntity.setReplace(dictReplace); | 
				
			|||
				 } | 
				
			|||
			} | 
				
			|||
		} | 
				
			|||
		excelEntity.setOrderNum(getCellOrder(excel.orderNum(), targetId)); | 
				
			|||
		excelEntity.setWrap(excel.isWrap()); | 
				
			|||
		excelEntity.setExportImageType(excel.imageType()); | 
				
			|||
		excelEntity.setSuffix(excel.suffix()); | 
				
			|||
		excelEntity.setDatabaseFormat(excel.databaseFormat()); | 
				
			|||
		excelEntity.setFormat(StringUtils.isNotEmpty(excel.exportFormat()) ? excel.exportFormat() : excel.format()); | 
				
			|||
		excelEntity.setStatistics(excel.isStatistics()); | 
				
			|||
		String fieldname = field.getName(); | 
				
			|||
		//update-begin-author:taoyan date:20200319 for:autopoi 双表头问题 #862 基于注解的解决方案
 | 
				
			|||
		excelEntity.setKey(fieldname); | 
				
			|||
		//update-end-author:taoyan date:20200319 for:autopoi 双表头问题 #862 基于注解的解决方案
 | 
				
			|||
		//update-begin-author:taoyan date:20200319 for:Excel注解的numFormat方法似乎未实现 #970
 | 
				
			|||
		excelEntity.setNumFormat(excel.numFormat()); | 
				
			|||
		//update-end-author:taoyan date:20200319 for:Excel注解的numFormat方法似乎未实现 #970
 | 
				
			|||
		//update-begin-author:taoyan date:20180615 for:TASK #2798 【例子】导入扩展方法,支持自定义导入字段转换规则
 | 
				
			|||
		excelEntity.setMethod(PoiPublicUtil.getMethod(fieldname, pojoClass,excel.exportConvert())); | 
				
			|||
		//update-end-author:taoyan date:20180615 for:TASK #2798 【例子】导入扩展方法,支持自定义导入字段转换规则
 | 
				
			|||
		//update-begin-author:taoyan date:20180801 for:TASK #3038 【bug】Excel 导出多个值(逗号隔开的情况下,导出字典值是ID值)
 | 
				
			|||
		excelEntity.setMultiReplace(excel.multiReplace()); | 
				
			|||
		//update-end-author:taoyan date:20180801 for:TASK #3038 【bug】Excel 导出多个值(逗号隔开的情况下,导出字典值是ID值)
 | 
				
			|||
		//update-begin-author:taoyan date:20200319 for:autopoi 双表头问题 #862 基于实体注解的解决方案
 | 
				
			|||
		if(StringUtils.isNotEmpty(excel.groupName())){ | 
				
			|||
			excelEntity.setGroupName(excel.groupName()); | 
				
			|||
			excelEntity.setColspan(true); | 
				
			|||
		} | 
				
			|||
		//update-end-author:taoyan date:20200319 for:autopoi 双表头问题 #862 基于实体注解的解决方案
 | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 判断在这个单元格显示的名称 | 
				
			|||
	 * | 
				
			|||
	 * @param exportName | 
				
			|||
	 * @param targetId | 
				
			|||
	 * @return | 
				
			|||
	 */ | 
				
			|||
	public String getExcelName(String exportName, String targetId) { | 
				
			|||
		if (exportName.indexOf(",") < 0 || targetId==null) { | 
				
			|||
			return exportName; | 
				
			|||
		} | 
				
			|||
		String[] arr = exportName.split(","); | 
				
			|||
		for (String str : arr) { | 
				
			|||
			if (str.indexOf(targetId) != -1) { | 
				
			|||
				return str.split("_")[0]; | 
				
			|||
			} | 
				
			|||
		} | 
				
			|||
		return null; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 多个反射获取值 | 
				
			|||
	 * | 
				
			|||
	 * @param list | 
				
			|||
	 * @param t | 
				
			|||
	 * @return | 
				
			|||
	 * @throws Exception | 
				
			|||
	 */ | 
				
			|||
	public Object getFieldBySomeMethod(List<Method> list, Object t) throws Exception { | 
				
			|||
		for (Method m : list) { | 
				
			|||
			if (t == null) { | 
				
			|||
				t = ""; | 
				
			|||
				break; | 
				
			|||
			} | 
				
			|||
			t = m.invoke(t, new Object[] {}); | 
				
			|||
		} | 
				
			|||
		return t; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 根据注解获取行高 | 
				
			|||
	 * | 
				
			|||
	 * @param excelParams | 
				
			|||
	 * @return | 
				
			|||
	 */ | 
				
			|||
	public short getRowHeight(List<ExcelExportEntity> excelParams) { | 
				
			|||
		double maxHeight = 0; | 
				
			|||
		for (int i = 0; i < excelParams.size(); i++) { | 
				
			|||
			maxHeight = maxHeight > excelParams.get(i).getHeight() ? maxHeight : excelParams.get(i).getHeight(); | 
				
			|||
			if (excelParams.get(i).getList() != null) { | 
				
			|||
				for (int j = 0; j < excelParams.get(i).getList().size(); j++) { | 
				
			|||
					maxHeight = maxHeight > excelParams.get(i).getList().get(j).getHeight() ? maxHeight : excelParams.get(i).getList().get(j).getHeight(); | 
				
			|||
				} | 
				
			|||
			} | 
				
			|||
		} | 
				
			|||
		return (short) (maxHeight * 50); | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 判断字符串是否是整数 | 
				
			|||
	 */ | 
				
			|||
	public boolean isInteger(String value) { | 
				
			|||
		try { | 
				
			|||
			Integer.parseInt(value); | 
				
			|||
			return true; | 
				
			|||
		} catch (NumberFormatException e) { | 
				
			|||
			return false; | 
				
			|||
		} | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	private Object replaceValue(String[] replace, String value) { | 
				
			|||
		String[] temp; | 
				
			|||
		for (String str : replace) { | 
				
			|||
			temp = str.split("_"); | 
				
			|||
			if (value.equals(temp[1])) { | 
				
			|||
				value = temp[0]; | 
				
			|||
				break; | 
				
			|||
			} | 
				
			|||
		} | 
				
			|||
		return value; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	//update-begin-author:taoyan date:20180731 for:TASK #3038 【bug】Excel 导出多个值(逗号隔开的情况下,导出字典值是ID值)
 | 
				
			|||
	/** | 
				
			|||
	 * 如果需要被替换的值是多选项,则每一项之间有逗号隔开,走以下方法 | 
				
			|||
	 * @author taoYan | 
				
			|||
	 * @since 2018年7月31日 | 
				
			|||
	 */ | 
				
			|||
	private Object multiReplaceValue(String[] replace, String value) { | 
				
			|||
		if(value.indexOf(",")>0){ | 
				
			|||
			String[] radioVals = value.split(","); | 
				
			|||
			String[] temp; | 
				
			|||
			String result = ""; | 
				
			|||
			for(int i =0;i<radioVals.length;i++){ | 
				
			|||
				String radio = radioVals[i]; | 
				
			|||
				for (String str : replace) { | 
				
			|||
					temp = str.split("_"); | 
				
			|||
					if (radio.equals(temp[1])) { | 
				
			|||
						result = result.concat(temp[0])+","; | 
				
			|||
						break; | 
				
			|||
					} | 
				
			|||
				} | 
				
			|||
			} | 
				
			|||
			if(result.equals("")){ | 
				
			|||
				result = value; | 
				
			|||
			}else{ | 
				
			|||
				result = result.substring(0, result.length()-1); | 
				
			|||
			} | 
				
			|||
			return result; | 
				
			|||
		}else{ | 
				
			|||
			return replaceValue(replace, value); | 
				
			|||
		} | 
				
			|||
	} | 
				
			|||
	//update-end-author:taoyan date:20180731 for:TASK #3038 【bug】Excel 导出多个值(逗号隔开的情况下,导出字典值是ID值)
 | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 对字段根据用户设置排序 | 
				
			|||
	 */ | 
				
			|||
	public void sortAllParams(List<ExcelExportEntity> excelParams) { | 
				
			|||
		Collections.sort(excelParams); | 
				
			|||
		for (ExcelExportEntity entity : excelParams) { | 
				
			|||
			if (entity.getList() != null) { | 
				
			|||
				Collections.sort(entity.getList()); | 
				
			|||
			} | 
				
			|||
		} | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 循环ExcelExportEntity集合 附加配置信息<br> | 
				
			|||
	 * 1.列排序<br> | 
				
			|||
	 * 2.读取图片根路径设置(如果有字段是图片类型 并且存储在本地 则设置磁盘路径获取全地址导出)<br> | 
				
			|||
	 * 3.多表头配置(仅限于单表 会走这个逻辑处理) | 
				
			|||
	 */ | 
				
			|||
	public void reConfigExcelExportParams(List<ExcelExportEntity> excelParams, ExportParams exportParams) { | 
				
			|||
		Set<String> NameSet = new HashSet<String>(); | 
				
			|||
		Map<String,List<String>> groupAndColumnList = new HashMap<String,List<String>>(); | 
				
			|||
		Map<String,Integer> groupOrder = new HashMap<>(); | 
				
			|||
		int index = -99; | 
				
			|||
		for (ExcelExportEntity entity : excelParams) { | 
				
			|||
			if(entity.getOrderNum()==0){ | 
				
			|||
				entity.setOrderNum(index++); | 
				
			|||
			} | 
				
			|||
			if(entity.getExportImageType()==3){ | 
				
			|||
				entity.setImageBasePath(exportParams.getImageBasePath()); | 
				
			|||
			} | 
				
			|||
			if (entity.getList() != null) { | 
				
			|||
				Collections.sort(entity.getList()); | 
				
			|||
			} | 
				
			|||
			String groupName = entity.getGroupName(); | 
				
			|||
			if(StringUtils.isNotEmpty(groupName)){ | 
				
			|||
				List<String> ls = groupAndColumnList.get(groupName); | 
				
			|||
				if(ls==null){ | 
				
			|||
					ls = new ArrayList<String>(); | 
				
			|||
					groupAndColumnList.put(groupName,ls); | 
				
			|||
				} | 
				
			|||
				ls.add(entity.getKey().toString()); | 
				
			|||
 | 
				
			|||
				Integer order = groupOrder.get(groupName); | 
				
			|||
				if(order==null || entity.getOrderNum()<order){ | 
				
			|||
					order = entity.getOrderNum(); | 
				
			|||
				} | 
				
			|||
				groupOrder.put(groupName,order); | 
				
			|||
			} | 
				
			|||
		} | 
				
			|||
 | 
				
			|||
		for(String key: groupAndColumnList.keySet()){ | 
				
			|||
			ExcelExportEntity temp = new ExcelExportEntity(key); | 
				
			|||
			temp.setColspan(true); | 
				
			|||
			temp.setSubColumnList(groupAndColumnList.get(key)); | 
				
			|||
			temp.setOrderNum(groupOrder.get(key)); | 
				
			|||
			excelParams.add(temp); | 
				
			|||
		} | 
				
			|||
		Collections.sort(excelParams); | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
} | 
				
			|||
@ -0,0 +1,336 @@ | 
				
			|||
/** | 
				
			|||
 * Copyright 2013-2015 JEECG (jeecgos@163.com) | 
				
			|||
 * | 
				
			|||
 *  Licensed under the Apache License, Version 2.0 (the "License"); | 
				
			|||
 *  you may not use this file except in compliance with the License. | 
				
			|||
 *  You may obtain a copy of the License at | 
				
			|||
 * | 
				
			|||
 *     http://www.apache.org/licenses/LICENSE-2.0
 | 
				
			|||
 * | 
				
			|||
 *  Unless required by applicable law or agreed to in writing, software | 
				
			|||
 * distributed under the License is distributed on an "AS IS" BASIS, | 
				
			|||
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | 
				
			|||
 * See the License for the specific language governing permissions and | 
				
			|||
 * limitations under the License. | 
				
			|||
 */ | 
				
			|||
package cc.admin.poi.excel.export.export; | 
				
			|||
 | 
				
			|||
import cc.admin.poi.excel.annotation.ExcelTarget; | 
				
			|||
import cc.admin.poi.excel.entity.ExportParams; | 
				
			|||
import cc.admin.poi.excel.entity.enmus.ExcelType; | 
				
			|||
import cc.admin.poi.excel.entity.params.ExcelExportEntity; | 
				
			|||
import cc.admin.poi.excel.entity.vo.PoiBaseConstants; | 
				
			|||
import cc.admin.poi.excel.export.base.ExcelExportBase; | 
				
			|||
import cc.admin.poi.excel.export.styler.IExcelExportStyler; | 
				
			|||
import cc.admin.poi.exception.excel.ExcelExportException; | 
				
			|||
import cc.admin.poi.exception.excel.enums.ExcelExportEnum; | 
				
			|||
import cc.admin.poi.util.PoiPublicUtil; | 
				
			|||
import org.apache.commons.lang3.StringUtils; | 
				
			|||
import org.apache.poi.ss.usermodel.*; | 
				
			|||
import org.apache.poi.ss.util.CellRangeAddress; | 
				
			|||
import org.slf4j.Logger; | 
				
			|||
import org.slf4j.LoggerFactory; | 
				
			|||
 | 
				
			|||
import java.lang.reflect.Field; | 
				
			|||
import java.util.*; | 
				
			|||
 | 
				
			|||
/** | 
				
			|||
 * Excel导出服务 | 
				
			|||
 * | 
				
			|||
 * @author JEECG | 
				
			|||
 * @date 2014年6月17日 下午5:30:54 | 
				
			|||
 */ | 
				
			|||
public class ExcelExportServer extends ExcelExportBase { | 
				
			|||
 | 
				
			|||
	private final static Logger LOGGER = LoggerFactory.getLogger(ExcelExportServer.class); | 
				
			|||
 | 
				
			|||
	// 最大行数,超过自动多Sheet
 | 
				
			|||
	private int MAX_NUM = 60000; | 
				
			|||
 | 
				
			|||
	private int createHeaderAndTitle(ExportParams entity, Sheet sheet, Workbook workbook, List<ExcelExportEntity> excelParams) { | 
				
			|||
		int rows = 0, feildWidth = getFieldWidth(excelParams); | 
				
			|||
		if (entity.getTitle() != null) { | 
				
			|||
			rows += createHeaderRow(entity, sheet, workbook, feildWidth); | 
				
			|||
		} | 
				
			|||
		rows += createTitleRow(entity, sheet, workbook, rows, excelParams); | 
				
			|||
		sheet.createFreezePane(0, rows, 0, rows); | 
				
			|||
		return rows; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 创建 表头改变 | 
				
			|||
	 * | 
				
			|||
	 * @param entity | 
				
			|||
	 * @param sheet | 
				
			|||
	 * @param workbook | 
				
			|||
	 * @param feildWidth | 
				
			|||
	 */ | 
				
			|||
	public int createHeaderRow(ExportParams entity, Sheet sheet, Workbook workbook, int feildWidth) { | 
				
			|||
		Row row = sheet.createRow(0); | 
				
			|||
		row.setHeight(entity.getTitleHeight()); | 
				
			|||
		createStringCell(row, 0, entity.getTitle(), getExcelExportStyler().getHeaderStyle(entity.getHeaderColor()), null); | 
				
			|||
		for (int i = 1; i <= feildWidth; i++) { | 
				
			|||
			createStringCell(row, i, "", getExcelExportStyler().getHeaderStyle(entity.getHeaderColor()), null); | 
				
			|||
		} | 
				
			|||
		sheet.addMergedRegion(new CellRangeAddress(0, 0, 0, feildWidth)); | 
				
			|||
		if (entity.getSecondTitle() != null) { | 
				
			|||
			row = sheet.createRow(1); | 
				
			|||
			row.setHeight(entity.getSecondTitleHeight()); | 
				
			|||
			CellStyle style = workbook.createCellStyle(); | 
				
			|||
			style.setAlignment(HorizontalAlignment.RIGHT); | 
				
			|||
			createStringCell(row, 0, entity.getSecondTitle(), style, null); | 
				
			|||
			for (int i = 1; i <= feildWidth; i++) { | 
				
			|||
				createStringCell(row, i, "", getExcelExportStyler().getHeaderStyle(entity.getHeaderColor()), null); | 
				
			|||
			} | 
				
			|||
			sheet.addMergedRegion(new CellRangeAddress(1, 1, 0, feildWidth)); | 
				
			|||
			return 2; | 
				
			|||
		} | 
				
			|||
		return 1; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void createSheet(Workbook workbook, ExportParams entity, Class<?> pojoClass, Collection<?> dataSet, String[] exportFields) { | 
				
			|||
		if (LOGGER.isDebugEnabled()) { | 
				
			|||
			LOGGER.debug("Excel export start ,class is {}", pojoClass); | 
				
			|||
			LOGGER.debug("Excel version is {}", entity.getType().equals(ExcelType.HSSF) ? "03" : "07"); | 
				
			|||
		} | 
				
			|||
		if (workbook == null || entity == null || pojoClass == null || dataSet == null) { | 
				
			|||
			throw new ExcelExportException(ExcelExportEnum.PARAMETER_ERROR); | 
				
			|||
		} | 
				
			|||
		super.type = entity.getType(); | 
				
			|||
		if (type.equals(ExcelType.XSSF)) { | 
				
			|||
			MAX_NUM = 1000000; | 
				
			|||
		} | 
				
			|||
		Sheet sheet = null; | 
				
			|||
		try { | 
				
			|||
			sheet = workbook.createSheet(entity.getSheetName()); | 
				
			|||
		} catch (Exception e) { | 
				
			|||
			// 重复遍历,出现了重名现象,创建非指定的名称Sheet
 | 
				
			|||
			sheet = workbook.createSheet(); | 
				
			|||
		} | 
				
			|||
		try { | 
				
			|||
			dataHanlder = entity.getDataHanlder(); | 
				
			|||
			if (dataHanlder != null) { | 
				
			|||
				needHanlderList = Arrays.asList(dataHanlder.getNeedHandlerFields()); | 
				
			|||
			} | 
				
			|||
			// 创建表格样式
 | 
				
			|||
			setExcelExportStyler((IExcelExportStyler) entity.getStyle().getConstructor(Workbook.class).newInstance(workbook)); | 
				
			|||
			Drawing patriarch = sheet.createDrawingPatriarch(); | 
				
			|||
			List<ExcelExportEntity> excelParams = new ArrayList<ExcelExportEntity>(); | 
				
			|||
			if (entity.isAddIndex()) { | 
				
			|||
				excelParams.add(indexExcelEntity(entity)); | 
				
			|||
			} | 
				
			|||
			// 得到所有字段
 | 
				
			|||
			Field fileds[] = PoiPublicUtil.getClassFields(pojoClass); | 
				
			|||
 | 
				
			|||
            //---update-begin-----autor:scott------date:20191016-------for:导出字段支持自定义--------
 | 
				
			|||
            //支持自定义导出字段
 | 
				
			|||
            if (exportFields != null) { | 
				
			|||
                List<Field> list = new ArrayList<Field>(Arrays.asList(fileds)); | 
				
			|||
                for (int i = 0; i < list.size(); i++) { | 
				
			|||
                    if (!Arrays.asList(exportFields).contains(list.get(i).getName())) { | 
				
			|||
                        list.remove(i); | 
				
			|||
                        i--; | 
				
			|||
                    } | 
				
			|||
                } | 
				
			|||
 | 
				
			|||
                if (list != null && list.size() > 0) { | 
				
			|||
                    fileds = list.toArray(new Field[0]); | 
				
			|||
                } else { | 
				
			|||
                    fileds = null; | 
				
			|||
                } | 
				
			|||
            } | 
				
			|||
            //---update-end-----autor:scott------date:20191016-------for:导出字段支持自定义--------
 | 
				
			|||
 | 
				
			|||
			ExcelTarget etarget = pojoClass.getAnnotation(ExcelTarget.class); | 
				
			|||
			String targetId = etarget == null ? null : etarget.value(); | 
				
			|||
			getAllExcelField(entity.getExclusions(), targetId, fileds, excelParams, pojoClass, null); | 
				
			|||
			//update-begin-author:taoyan date:20200304 for:在此方法循环内设置一下图片磁盘目录,便于导出
 | 
				
			|||
			reConfigExcelExportParams(excelParams,entity); | 
				
			|||
			//update-end-author:taoyan date:20200304 for:在此方法循环内设置一下图片磁盘目录,便于导出
 | 
				
			|||
			int index = entity.isCreateHeadRows() ? createHeaderAndTitle(entity, sheet, workbook, excelParams) : 0; | 
				
			|||
			int titleHeight = index; | 
				
			|||
			setCellWith(excelParams, sheet); | 
				
			|||
			short rowHeight = getRowHeight(excelParams); | 
				
			|||
			setCurrentIndex(1); | 
				
			|||
			Iterator<?> its = dataSet.iterator(); | 
				
			|||
			List<Object> tempList = new ArrayList<Object>(); | 
				
			|||
			while (its.hasNext()) { | 
				
			|||
				Object t = its.next(); | 
				
			|||
				index += createCells(patriarch, index, t, excelParams, sheet, workbook, rowHeight); | 
				
			|||
				tempList.add(t); | 
				
			|||
				if (index >= MAX_NUM) | 
				
			|||
					break; | 
				
			|||
			} | 
				
			|||
			mergeCells(sheet, excelParams, titleHeight); | 
				
			|||
 | 
				
			|||
			if (entity.getFreezeCol() != 0) { | 
				
			|||
				sheet.createFreezePane(entity.getFreezeCol(), 0, entity.getFreezeCol(), 0); | 
				
			|||
			} | 
				
			|||
 | 
				
			|||
			its = dataSet.iterator(); | 
				
			|||
			for (int i = 0, le = tempList.size(); i < le; i++) { | 
				
			|||
				its.next(); | 
				
			|||
				its.remove(); | 
				
			|||
			} | 
				
			|||
			// 创建合计信息
 | 
				
			|||
			addStatisticsRow(getExcelExportStyler().getStyles(true, null), sheet); | 
				
			|||
 | 
				
			|||
			// 发现还有剩余list 继续循环创建Sheet
 | 
				
			|||
			if (dataSet.size() > 0) { | 
				
			|||
				createSheet(workbook, entity, pojoClass, dataSet,exportFields); | 
				
			|||
			} | 
				
			|||
 | 
				
			|||
		} catch (Exception e) { | 
				
			|||
			LOGGER.error(e.getMessage(), e); | 
				
			|||
			throw new ExcelExportException(ExcelExportEnum.EXPORT_ERROR, e.getCause()); | 
				
			|||
		} | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void createSheetForMap(Workbook workbook, ExportParams entity, List<ExcelExportEntity> entityList, Collection<? extends Map<?, ?>> dataSet) { | 
				
			|||
		if (LOGGER.isDebugEnabled()) { | 
				
			|||
			LOGGER.debug("Excel version is {}", entity.getType().equals(ExcelType.HSSF) ? "03" : "07"); | 
				
			|||
		} | 
				
			|||
		if (workbook == null || entity == null || entityList == null || dataSet == null) { | 
				
			|||
			throw new ExcelExportException(ExcelExportEnum.PARAMETER_ERROR); | 
				
			|||
		} | 
				
			|||
		super.type = entity.getType(); | 
				
			|||
		if (type.equals(ExcelType.XSSF)) { | 
				
			|||
			MAX_NUM = 1000000; | 
				
			|||
		} | 
				
			|||
		Sheet sheet = null; | 
				
			|||
		try { | 
				
			|||
			sheet = workbook.createSheet(entity.getSheetName()); | 
				
			|||
		} catch (Exception e) { | 
				
			|||
			// 重复遍历,出现了重名现象,创建非指定的名称Sheet
 | 
				
			|||
			sheet = workbook.createSheet(); | 
				
			|||
		} | 
				
			|||
		try { | 
				
			|||
			dataHanlder = entity.getDataHanlder(); | 
				
			|||
			if (dataHanlder != null) { | 
				
			|||
				needHanlderList = Arrays.asList(dataHanlder.getNeedHandlerFields()); | 
				
			|||
			} | 
				
			|||
			// 创建表格样式
 | 
				
			|||
			setExcelExportStyler((IExcelExportStyler) entity.getStyle().getConstructor(Workbook.class).newInstance(workbook)); | 
				
			|||
			Drawing patriarch = sheet.createDrawingPatriarch(); | 
				
			|||
			List<ExcelExportEntity> excelParams = new ArrayList<ExcelExportEntity>(); | 
				
			|||
			if (entity.isAddIndex()) { | 
				
			|||
				excelParams.add(indexExcelEntity(entity)); | 
				
			|||
			} | 
				
			|||
			excelParams.addAll(entityList); | 
				
			|||
			sortAllParams(excelParams); | 
				
			|||
			int index = entity.isCreateHeadRows() ? createHeaderAndTitle(entity, sheet, workbook, excelParams) : 0; | 
				
			|||
			int titleHeight = index; | 
				
			|||
			setCellWith(excelParams, sheet); | 
				
			|||
			short rowHeight = getRowHeight(excelParams); | 
				
			|||
			setCurrentIndex(1); | 
				
			|||
			Iterator<?> its = dataSet.iterator(); | 
				
			|||
			List<Object> tempList = new ArrayList<Object>(); | 
				
			|||
			while (its.hasNext()) { | 
				
			|||
				Object t = its.next(); | 
				
			|||
				index += createCells(patriarch, index, t, excelParams, sheet, workbook, rowHeight); | 
				
			|||
				tempList.add(t); | 
				
			|||
				if (index >= MAX_NUM) | 
				
			|||
					break; | 
				
			|||
			} | 
				
			|||
			if (entity.getFreezeCol() != 0) { | 
				
			|||
				sheet.createFreezePane(entity.getFreezeCol(), 0, entity.getFreezeCol(), 0); | 
				
			|||
			} | 
				
			|||
 | 
				
			|||
			mergeCells(sheet, excelParams, titleHeight); | 
				
			|||
 | 
				
			|||
			its = dataSet.iterator(); | 
				
			|||
			for (int i = 0, le = tempList.size(); i < le; i++) { | 
				
			|||
				its.next(); | 
				
			|||
				its.remove(); | 
				
			|||
			} | 
				
			|||
			// 发现还有剩余list 继续循环创建Sheet
 | 
				
			|||
			if (dataSet.size() > 0) { | 
				
			|||
				createSheetForMap(workbook, entity, entityList, dataSet); | 
				
			|||
			} | 
				
			|||
 | 
				
			|||
		} catch (Exception e) { | 
				
			|||
			LOGGER.error(e.getMessage(), e); | 
				
			|||
			throw new ExcelExportException(ExcelExportEnum.EXPORT_ERROR, e.getCause()); | 
				
			|||
		} | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 创建表头 | 
				
			|||
	 * | 
				
			|||
	 * @param title | 
				
			|||
	 * @param index | 
				
			|||
	 */ | 
				
			|||
	private int createTitleRow(ExportParams title, Sheet sheet, Workbook workbook, int index, List<ExcelExportEntity> excelParams) { | 
				
			|||
		Row row = sheet.createRow(index); | 
				
			|||
		int rows = getRowNums(excelParams); | 
				
			|||
		row.setHeight((short) 450); | 
				
			|||
		Row listRow = null; | 
				
			|||
		if (rows == 2) { | 
				
			|||
			listRow = sheet.createRow(index + 1); | 
				
			|||
			listRow.setHeight((short) 450); | 
				
			|||
		} | 
				
			|||
		int cellIndex = 0; | 
				
			|||
		CellStyle titleStyle = getExcelExportStyler().getTitleStyle(title.getColor()); | 
				
			|||
		for (int i = 0, exportFieldTitleSize = excelParams.size(); i < exportFieldTitleSize; i++) { | 
				
			|||
			ExcelExportEntity entity = excelParams.get(i); | 
				
			|||
			//update-begin-author:taoyan date:20200319 for:建议autoPoi升级,优化数据返回List Map格式下的复合表头导出excel的体验 #873
 | 
				
			|||
			if(entity.isColspan()){ | 
				
			|||
				List<String> subList = entity.getSubColumnList(); | 
				
			|||
				if(subList==null || subList.size()==0){ | 
				
			|||
					continue; | 
				
			|||
				}else{ | 
				
			|||
					entity.initSubExportEntity(excelParams); | 
				
			|||
				} | 
				
			|||
			} | 
				
			|||
			//update-end-author:taoyan date:20200319 for:建议autoPoi升级,优化数据返回List Map格式下的复合表头导出excel的体验 #873
 | 
				
			|||
			if (StringUtils.isNotBlank(entity.getName())) { | 
				
			|||
				createStringCell(row, cellIndex, entity.getName(), titleStyle, entity); | 
				
			|||
			} | 
				
			|||
			if (entity.getList() != null) { | 
				
			|||
				List<ExcelExportEntity> sTitel = entity.getList(); | 
				
			|||
				if (StringUtils.isNotBlank(entity.getName())) { | 
				
			|||
					sheet.addMergedRegion(new CellRangeAddress(index, index, cellIndex, cellIndex + sTitel.size() - 1)); | 
				
			|||
				} | 
				
			|||
				for (int j = 0, size = sTitel.size(); j < size; j++) { | 
				
			|||
					createStringCell(rows == 2 ? listRow : row, cellIndex, sTitel.get(j).getName(), titleStyle, entity); | 
				
			|||
					cellIndex++; | 
				
			|||
				} | 
				
			|||
				cellIndex--; | 
				
			|||
			} else if (rows == 2) { | 
				
			|||
				createStringCell(listRow, cellIndex, "", titleStyle, entity); | 
				
			|||
				sheet.addMergedRegion(new CellRangeAddress(index, index + 1, cellIndex, cellIndex)); | 
				
			|||
			} | 
				
			|||
			cellIndex++; | 
				
			|||
		} | 
				
			|||
		return rows; | 
				
			|||
 | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 判断表头是只有一行还是两行 | 
				
			|||
	 * | 
				
			|||
	 * @param excelParams | 
				
			|||
	 * @return | 
				
			|||
	 */ | 
				
			|||
	private int getRowNums(List<ExcelExportEntity> excelParams) { | 
				
			|||
		for (int i = 0; i < excelParams.size(); i++) { | 
				
			|||
			//update-begin-author:taoyan date:20200319 for:建议autoPoi升级,优化数据返回List Map格式下的复合表头导出excel的体验 #873
 | 
				
			|||
			ExcelExportEntity temp = excelParams.get(i); | 
				
			|||
			if ((temp.getList() != null || temp.isColspan()) && StringUtils.isNotBlank(temp.getName())) { | 
				
			|||
				return 2; | 
				
			|||
			} | 
				
			|||
			//update-end-author:taoyan date:20200319 for:建议autoPoi升级,优化数据返回List Map格式下的复合表头导出excel的体验 #873
 | 
				
			|||
		} | 
				
			|||
		return 1; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	private ExcelExportEntity indexExcelEntity(ExportParams entity) { | 
				
			|||
		ExcelExportEntity exportEntity = new ExcelExportEntity(); | 
				
			|||
		exportEntity.setOrderNum(0); | 
				
			|||
		exportEntity.setName(entity.getIndexName()); | 
				
			|||
		exportEntity.setWidth(10); | 
				
			|||
		exportEntity.setFormat(PoiBaseConstants.IS_ADD_INDEX); | 
				
			|||
		return exportEntity; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
} | 
				
			|||
@ -0,0 +1,477 @@ | 
				
			|||
/** | 
				
			|||
 * Copyright 2013-2015 JEECG (jeecgos@163.com) | 
				
			|||
 * | 
				
			|||
 *  Licensed under the Apache License, Version 2.0 (the "License"); | 
				
			|||
 *  you may not use this file except in compliance with the License. | 
				
			|||
 *  You may obtain a copy of the License at | 
				
			|||
 * | 
				
			|||
 *     http://www.apache.org/licenses/LICENSE-2.0
 | 
				
			|||
 * | 
				
			|||
 *  Unless required by applicable law or agreed to in writing, software | 
				
			|||
 * distributed under the License is distributed on an "AS IS" BASIS, | 
				
			|||
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | 
				
			|||
 * See the License for the specific language governing permissions and | 
				
			|||
 * limitations under the License. | 
				
			|||
 */ | 
				
			|||
package cc.admin.poi.excel.export.export.base; | 
				
			|||
 | 
				
			|||
import cc.admin.poi.excel.entity.enmus.ExcelType; | 
				
			|||
import cc.admin.poi.excel.entity.params.ExcelExportEntity; | 
				
			|||
import cc.admin.poi.excel.entity.vo.PoiBaseConstants; | 
				
			|||
import cc.admin.poi.excel.export.base.ExportBase; | 
				
			|||
import cc.admin.poi.excel.export.styler.IExcelExportStyler; | 
				
			|||
import cc.admin.poi.util.PoiMergeCellUtil; | 
				
			|||
import cc.admin.poi.util.PoiPublicUtil; | 
				
			|||
import org.apache.commons.lang3.StringUtils; | 
				
			|||
import org.apache.poi.hssf.usermodel.HSSFClientAnchor; | 
				
			|||
import org.apache.poi.hssf.usermodel.HSSFRichTextString; | 
				
			|||
import org.apache.poi.ss.usermodel.*; | 
				
			|||
import org.apache.poi.ss.util.CellRangeAddress; | 
				
			|||
import org.apache.poi.xssf.usermodel.XSSFClientAnchor; | 
				
			|||
import org.apache.poi.xssf.usermodel.XSSFRichTextString; | 
				
			|||
import org.slf4j.Logger; | 
				
			|||
import org.slf4j.LoggerFactory; | 
				
			|||
 | 
				
			|||
import javax.imageio.ImageIO; | 
				
			|||
import java.awt.image.BufferedImage; | 
				
			|||
import java.io.ByteArrayOutputStream; | 
				
			|||
import java.io.File; | 
				
			|||
import java.io.IOException; | 
				
			|||
import java.io.InputStream; | 
				
			|||
import java.net.HttpURLConnection; | 
				
			|||
import java.net.URL; | 
				
			|||
import java.text.DecimalFormat; | 
				
			|||
import java.util.*; | 
				
			|||
 | 
				
			|||
/** | 
				
			|||
 * 提供POI基础操作服务 | 
				
			|||
 * | 
				
			|||
 * @author JEECG | 
				
			|||
 * @date 2014年6月17日 下午6:15:13 | 
				
			|||
 */ | 
				
			|||
public abstract class ExcelExportBase extends ExportBase { | 
				
			|||
 | 
				
			|||
	private static final Logger LOGGER = LoggerFactory.getLogger(ExcelExportBase.class); | 
				
			|||
 | 
				
			|||
	private int currentIndex = 0; | 
				
			|||
 | 
				
			|||
	protected ExcelType type = ExcelType.HSSF; | 
				
			|||
 | 
				
			|||
	private Map<Integer, Double> statistics = new HashMap<Integer, Double>(); | 
				
			|||
 | 
				
			|||
	private static final DecimalFormat DOUBLE_FORMAT = new DecimalFormat("######0.00"); | 
				
			|||
 | 
				
			|||
	private IExcelExportStyler excelExportStyler; | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 创建 最主要的 Cells | 
				
			|||
	 * | 
				
			|||
	 * @param rowHeight | 
				
			|||
	 * @throws Exception | 
				
			|||
	 */ | 
				
			|||
	public int createCells(Drawing patriarch, int index, Object t, List<ExcelExportEntity> excelParams, Sheet sheet, Workbook workbook, short rowHeight) throws Exception { | 
				
			|||
		ExcelExportEntity entity; | 
				
			|||
		Row row = sheet.createRow(index); | 
				
			|||
		row.setHeight(rowHeight); | 
				
			|||
		int maxHeight = 1, cellNum = 0; | 
				
			|||
		int indexKey = createIndexCell(row, index, excelParams.get(0)); | 
				
			|||
		cellNum += indexKey; | 
				
			|||
		for (int k = indexKey, paramSize = excelParams.size(); k < paramSize; k++) { | 
				
			|||
			entity = excelParams.get(k); | 
				
			|||
			//update-begin-author:taoyan date:20200319 for:建议autoPoi升级,优化数据返回List Map格式下的复合表头导出excel的体验 #873
 | 
				
			|||
			if(entity.isSubColumn()){ | 
				
			|||
				continue; | 
				
			|||
			} | 
				
			|||
			if(entity.isMergeColumn()){ | 
				
			|||
				Map<String,Object> subColumnMap = new HashMap<>(); | 
				
			|||
				List<String> mapKeys = entity.getSubColumnList(); | 
				
			|||
				for (String subKey : mapKeys) { | 
				
			|||
					Object subKeyValue = null; | 
				
			|||
					if (t instanceof Map) { | 
				
			|||
						subKeyValue = ((Map<?, ?>) t).get(subKey); | 
				
			|||
					}else{ | 
				
			|||
						subKeyValue = PoiPublicUtil.getParamsValue(subKey,t); | 
				
			|||
					} | 
				
			|||
					subColumnMap.put(subKey,subKeyValue); | 
				
			|||
				} | 
				
			|||
				createListCells(patriarch, index, cellNum, subColumnMap, entity.getList(), sheet, workbook); | 
				
			|||
				cellNum += entity.getSubColumnList().size(); | 
				
			|||
			//update-end-author:taoyan date:20200319 for:建议autoPoi升级,优化数据返回List Map格式下的复合表头导出excel的体验 #873
 | 
				
			|||
			} else if (entity.getList() != null) { | 
				
			|||
				Collection<?> list = getListCellValue(entity, t); | 
				
			|||
				int listC = 0; | 
				
			|||
				for (Object obj : list) { | 
				
			|||
					createListCells(patriarch, index + listC, cellNum, obj, entity.getList(), sheet, workbook); | 
				
			|||
					listC++; | 
				
			|||
				} | 
				
			|||
				cellNum += entity.getList().size(); | 
				
			|||
				if (list != null && list.size() > maxHeight) { | 
				
			|||
					maxHeight = list.size(); | 
				
			|||
				} | 
				
			|||
			} else { | 
				
			|||
				Object value = getCellValue(entity, t); | 
				
			|||
				//update-begin--Author:xuelin  Date:20171018 for:TASK #2372 【excel】easypoi 导出类型,type增加数字类型--------------------
 | 
				
			|||
				if (entity.getType() == 1) { | 
				
			|||
					createStringCell(row, cellNum++, value == null ? "" : value.toString(), index % 2 == 0 ? getStyles(false, entity) : getStyles(true, entity), entity); | 
				
			|||
				} else if (entity.getType() == 4){ | 
				
			|||
					createNumericCell(row, cellNum++, value == null ? "" : value.toString(), index % 2 == 0 ? getStyles(false, entity) : getStyles(true, entity), entity); | 
				
			|||
				} else { | 
				
			|||
					createImageCell(patriarch, entity, row, cellNum++, value == null ? "" : value.toString(), t); | 
				
			|||
				} | 
				
			|||
				//update-end--Author:xuelin  Date:20171018 for:TASK #2372 【excel】easypoi 导出类型,type增加数字类型--------------------
 | 
				
			|||
			} | 
				
			|||
		} | 
				
			|||
		// 合并需要合并的单元格
 | 
				
			|||
		cellNum = 0; | 
				
			|||
		for (int k = indexKey, paramSize = excelParams.size(); k < paramSize; k++) { | 
				
			|||
			entity = excelParams.get(k); | 
				
			|||
			if (entity.getList() != null) { | 
				
			|||
				cellNum += entity.getList().size(); | 
				
			|||
			} else if (entity.isNeedMerge()) { | 
				
			|||
				for (int i = index + 1; i < index + maxHeight; i++) { | 
				
			|||
					sheet.getRow(i).createCell(cellNum); | 
				
			|||
					sheet.getRow(i).getCell(cellNum).setCellStyle(getStyles(false, entity)); | 
				
			|||
				} | 
				
			|||
				sheet.addMergedRegion(new CellRangeAddress(index, index + maxHeight - 1, cellNum, cellNum)); | 
				
			|||
				cellNum++; | 
				
			|||
			} | 
				
			|||
		} | 
				
			|||
		return maxHeight; | 
				
			|||
 | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 图片类型的Cell | 
				
			|||
	 * | 
				
			|||
	 * @param patriarch | 
				
			|||
	 * @param entity | 
				
			|||
	 * @param row | 
				
			|||
	 * @param i | 
				
			|||
	 * @param imagePath | 
				
			|||
	 * @param obj | 
				
			|||
	 * @throws Exception | 
				
			|||
	 */ | 
				
			|||
	public void createImageCell(Drawing patriarch, ExcelExportEntity entity, Row row, int i, String imagePath, Object obj) throws Exception { | 
				
			|||
		row.setHeight((short) (50 * entity.getHeight())); | 
				
			|||
		row.createCell(i); | 
				
			|||
		ClientAnchor anchor; | 
				
			|||
		if (type.equals(ExcelType.HSSF)) { | 
				
			|||
			anchor = new HSSFClientAnchor(0, 0, 0, 0, (short) i, row.getRowNum(), (short) (i + 1), row.getRowNum() + 1); | 
				
			|||
		} else { | 
				
			|||
			anchor = new XSSFClientAnchor(0, 0, 0, 0, (short) i, row.getRowNum(), (short) (i + 1), row.getRowNum() + 1); | 
				
			|||
		} | 
				
			|||
 | 
				
			|||
		if (StringUtils.isEmpty(imagePath)) { | 
				
			|||
			return; | 
				
			|||
		} | 
				
			|||
 | 
				
			|||
		//update-beign-author:taoyan date:20200302 for:【多任务】online 专项集中问题 LOWCOD-159
 | 
				
			|||
		int imageType = entity.getExportImageType(); | 
				
			|||
		byte[] value = null; | 
				
			|||
		if(imageType == 2){ | 
				
			|||
			//原来逻辑 2
 | 
				
			|||
			value = (byte[]) (entity.getMethods() != null ? getFieldBySomeMethod(entity.getMethods(), obj) : entity.getMethod().invoke(obj, new Object[] {})); | 
				
			|||
		} else if(imageType==4 || imagePath.startsWith("http")){ | 
				
			|||
			//新增逻辑 网络图片4
 | 
				
			|||
			try { | 
				
			|||
				if (imagePath.indexOf(",") != -1) { | 
				
			|||
					if(imagePath.startsWith(",")){ | 
				
			|||
						imagePath = imagePath.substring(1); | 
				
			|||
					} | 
				
			|||
					String[] images = imagePath.split(","); | 
				
			|||
					imagePath = images[0]; | 
				
			|||
				} | 
				
			|||
				URL url = new URL(imagePath); | 
				
			|||
				HttpURLConnection conn = (HttpURLConnection) url.openConnection(); | 
				
			|||
				conn.setRequestMethod("GET"); | 
				
			|||
				conn.setConnectTimeout(5 * 1000); | 
				
			|||
				InputStream inStream = conn.getInputStream(); | 
				
			|||
				value = readInputStream(inStream); | 
				
			|||
			} catch (Exception exception) { | 
				
			|||
				LOGGER.warn(exception.getMessage()); | 
				
			|||
				//exception.printStackTrace();
 | 
				
			|||
			} | 
				
			|||
		} else { | 
				
			|||
			ByteArrayOutputStream byteArrayOut = new ByteArrayOutputStream(); | 
				
			|||
			BufferedImage bufferImg; | 
				
			|||
			String path = null; | 
				
			|||
			if(imageType == 1){ | 
				
			|||
				//原来逻辑 1
 | 
				
			|||
				path = PoiPublicUtil.getWebRootPath(imagePath); | 
				
			|||
				LOGGER.debug("--- createImageCell getWebRootPath ----filePath--- "+ path); | 
				
			|||
				path = path.replace("WEB-INF/classes/", ""); | 
				
			|||
				path = path.replace("file:/", ""); | 
				
			|||
			}else if(imageType==3){ | 
				
			|||
				//新增逻辑 本地图片3
 | 
				
			|||
				if(!entity.getImageBasePath().endsWith(File.separator) && !imagePath.startsWith(File.separator)){ | 
				
			|||
					path = entity.getImageBasePath()+File.separator+imagePath; | 
				
			|||
				}else{ | 
				
			|||
					path = entity.getImageBasePath()+imagePath; | 
				
			|||
				} | 
				
			|||
			} | 
				
			|||
			try { | 
				
			|||
				bufferImg = ImageIO.read(new File(path)); | 
				
			|||
				ImageIO.write(bufferImg, imagePath.substring(imagePath.indexOf(".") + 1, imagePath.length()), byteArrayOut); | 
				
			|||
				value = byteArrayOut.toByteArray(); | 
				
			|||
			} catch (IOException e) { | 
				
			|||
				LOGGER.error(e.getMessage(), e); | 
				
			|||
			} | 
				
			|||
		} | 
				
			|||
		if (value != null) { | 
				
			|||
			patriarch.createPicture(anchor, row.getSheet().getWorkbook().addPicture(value, getImageType(value))); | 
				
			|||
		} | 
				
			|||
		//update-end-author:taoyan date:20200302 for:【多任务】online 专项集中问题 LOWCOD-159
 | 
				
			|||
 | 
				
			|||
 | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * inStream读取到字节数组 | 
				
			|||
	 * @param inStream | 
				
			|||
	 * @return | 
				
			|||
	 * @throws Exception | 
				
			|||
	 */ | 
				
			|||
	private byte[] readInputStream(InputStream inStream) throws Exception { | 
				
			|||
		if(inStream==null){ | 
				
			|||
			return null; | 
				
			|||
		} | 
				
			|||
		ByteArrayOutputStream outStream = new ByteArrayOutputStream(); | 
				
			|||
		byte[] buffer = new byte[1024]; | 
				
			|||
		int len = 0; | 
				
			|||
		//每次读取的字符串长度,如果为-1,代表全部读取完毕
 | 
				
			|||
		while ((len = inStream.read(buffer)) != -1) { | 
				
			|||
			outStream.write(buffer, 0, len); | 
				
			|||
		} | 
				
			|||
		inStream.close(); | 
				
			|||
		return outStream.toByteArray(); | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	private int createIndexCell(Row row, int index, ExcelExportEntity excelExportEntity) { | 
				
			|||
		if (excelExportEntity.getName().equals("序号") && excelExportEntity.getFormat().equals(PoiBaseConstants.IS_ADD_INDEX)) { | 
				
			|||
			createStringCell(row, 0, currentIndex + "", index % 2 == 0 ? getStyles(false, null) : getStyles(true, null), null); | 
				
			|||
			currentIndex = currentIndex + 1; | 
				
			|||
			return 1; | 
				
			|||
		} | 
				
			|||
		return 0; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 创建List之后的各个Cells | 
				
			|||
	 * | 
				
			|||
	 */ | 
				
			|||
	public void createListCells(Drawing patriarch, int index, int cellNum, Object obj, List<ExcelExportEntity> excelParams, Sheet sheet, Workbook workbook) throws Exception { | 
				
			|||
		ExcelExportEntity entity; | 
				
			|||
		Row row; | 
				
			|||
		if (sheet.getRow(index) == null) { | 
				
			|||
			row = sheet.createRow(index); | 
				
			|||
			row.setHeight(getRowHeight(excelParams)); | 
				
			|||
		} else { | 
				
			|||
			row = sheet.getRow(index); | 
				
			|||
		} | 
				
			|||
		for (int k = 0, paramSize = excelParams.size(); k < paramSize; k++) { | 
				
			|||
			entity = excelParams.get(k); | 
				
			|||
			Object value = getCellValue(entity, obj); | 
				
			|||
			//update-begin--Author:xuelin  Date:20171018 for:TASK #2372 【excel】easypoi 导出类型,type增加数字类型--------------------
 | 
				
			|||
			if (entity.getType() == 1) { | 
				
			|||
				createStringCell(row, cellNum++, value == null ? "" : value.toString(), row.getRowNum() % 2 == 0 ? getStyles(false, entity) : getStyles(true, entity), entity); | 
				
			|||
			} else if (entity.getType() == 4){ | 
				
			|||
				createNumericCell(row, cellNum++, value == null ? "" : value.toString(), index % 2 == 0 ? getStyles(false, entity) : getStyles(true, entity), entity); | 
				
			|||
			}  else{ | 
				
			|||
				createImageCell(patriarch, entity, row, cellNum++, value == null ? "" : value.toString(), obj); | 
				
			|||
			} | 
				
			|||
			//update-end--Author:xuelin  Date:20171018 for:TASK #2372 【excel】easypoi 导出类型,type增加数字类型--------------------
 | 
				
			|||
		} | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	//update-begin--Author:xuelin  Date:20171018 for:TASK #2372 【excel】easypoi 导出类型,type增加数字类型--------------------
 | 
				
			|||
	public void createNumericCell (Row row, int index, String text, CellStyle style, ExcelExportEntity entity) { | 
				
			|||
		Cell cell = row.createCell(index); | 
				
			|||
		if(StringUtils.isEmpty(text)){ | 
				
			|||
			cell.setCellValue(""); | 
				
			|||
			cell.setCellType(CellType.BLANK); | 
				
			|||
		}else{ | 
				
			|||
			cell.setCellValue(Double.parseDouble(text)); | 
				
			|||
			cell.setCellType(CellType.NUMERIC); | 
				
			|||
		} | 
				
			|||
		if (style != null) { | 
				
			|||
			cell.setCellStyle(style); | 
				
			|||
		} | 
				
			|||
		addStatisticsData(index, text, entity); | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 创建文本类型的Cell | 
				
			|||
	 * | 
				
			|||
	 * @param row | 
				
			|||
	 * @param index | 
				
			|||
	 * @param text | 
				
			|||
	 * @param style | 
				
			|||
	 * @param entity | 
				
			|||
	 */ | 
				
			|||
	public void createStringCell(Row row, int index, String text, CellStyle style, ExcelExportEntity entity) { | 
				
			|||
		Cell cell = row.createCell(index); | 
				
			|||
		if (style != null && style.getDataFormat() > 0 && style.getDataFormat() < 12) { | 
				
			|||
			cell.setCellValue(Double.parseDouble(text)); | 
				
			|||
			cell.setCellType(CellType.NUMERIC); | 
				
			|||
		}else{ | 
				
			|||
			RichTextString Rtext; | 
				
			|||
			if (type.equals(ExcelType.HSSF)) { | 
				
			|||
				Rtext = new HSSFRichTextString(text); | 
				
			|||
			} else { | 
				
			|||
				Rtext = new XSSFRichTextString(text); | 
				
			|||
			} | 
				
			|||
			cell.setCellValue(Rtext); | 
				
			|||
		} | 
				
			|||
		if (style != null) { | 
				
			|||
			cell.setCellStyle(style); | 
				
			|||
		} | 
				
			|||
		addStatisticsData(index, text, entity); | 
				
			|||
	} | 
				
			|||
	//update-end--Author:xuelin  Date:20171018 for:TASK #2372 【excel】easypoi 导出类型,type增加数字类型----------------------
 | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 创建统计行 | 
				
			|||
	 * | 
				
			|||
	 * @param styles | 
				
			|||
	 * @param sheet | 
				
			|||
	 */ | 
				
			|||
	public void addStatisticsRow(CellStyle styles, Sheet sheet) { | 
				
			|||
		if (statistics.size() > 0) { | 
				
			|||
			Row row = sheet.createRow(sheet.getLastRowNum() + 1); | 
				
			|||
			Set<Integer> keys = statistics.keySet(); | 
				
			|||
			createStringCell(row, 0, "合计", styles, null); | 
				
			|||
			for (Integer key : keys) { | 
				
			|||
				createStringCell(row, key, DOUBLE_FORMAT.format(statistics.get(key)), styles, null); | 
				
			|||
			} | 
				
			|||
			statistics.clear(); | 
				
			|||
		} | 
				
			|||
 | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 合计统计信息 | 
				
			|||
	 * | 
				
			|||
	 * @param index | 
				
			|||
	 * @param text | 
				
			|||
	 * @param entity | 
				
			|||
	 */ | 
				
			|||
	private void addStatisticsData(Integer index, String text, ExcelExportEntity entity) { | 
				
			|||
		if (entity != null && entity.isStatistics()) { | 
				
			|||
			Double temp = 0D; | 
				
			|||
			if (!statistics.containsKey(index)) { | 
				
			|||
				statistics.put(index, temp); | 
				
			|||
			} | 
				
			|||
			try { | 
				
			|||
				temp = Double.valueOf(text); | 
				
			|||
			} catch (NumberFormatException e) { | 
				
			|||
			} | 
				
			|||
			statistics.put(index, statistics.get(index) + temp); | 
				
			|||
		} | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 获取导出报表的字段总长度 | 
				
			|||
	 * | 
				
			|||
	 * @param excelParams | 
				
			|||
	 * @return | 
				
			|||
	 */ | 
				
			|||
	public int getFieldWidth(List<ExcelExportEntity> excelParams) { | 
				
			|||
		int length = -1;// 从0开始计算单元格的
 | 
				
			|||
		for (ExcelExportEntity entity : excelParams) { | 
				
			|||
			length += entity.getList() != null ? entity.getList().size() : 1; | 
				
			|||
		} | 
				
			|||
		return length; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 获取图片类型,设置图片插入类型 | 
				
			|||
	 * | 
				
			|||
	 * @param value | 
				
			|||
	 * @return | 
				
			|||
	 * @Author JEECG | 
				
			|||
	 * @date 2013年11月25日 | 
				
			|||
	 */ | 
				
			|||
	public int getImageType(byte[] value) { | 
				
			|||
		String type = PoiPublicUtil.getFileExtendName(value); | 
				
			|||
		if (type.equalsIgnoreCase("JPG")) { | 
				
			|||
			return Workbook.PICTURE_TYPE_JPEG; | 
				
			|||
		} else if (type.equalsIgnoreCase("PNG")) { | 
				
			|||
			return Workbook.PICTURE_TYPE_PNG; | 
				
			|||
		} | 
				
			|||
		return Workbook.PICTURE_TYPE_JPEG; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	private Map<Integer, int[]> getMergeDataMap(List<ExcelExportEntity> excelParams) { | 
				
			|||
		Map<Integer, int[]> mergeMap = new HashMap<Integer, int[]>(); | 
				
			|||
		// 设置参数顺序,为之后合并单元格做准备
 | 
				
			|||
		int i = 0; | 
				
			|||
		for (ExcelExportEntity entity : excelParams) { | 
				
			|||
			if (entity.isMergeVertical()) { | 
				
			|||
				mergeMap.put(i, entity.getMergeRely()); | 
				
			|||
			} | 
				
			|||
			if (entity.getList() != null) { | 
				
			|||
				for (ExcelExportEntity inner : entity.getList()) { | 
				
			|||
					if (inner.isMergeVertical()) { | 
				
			|||
						mergeMap.put(i, inner.getMergeRely()); | 
				
			|||
					} | 
				
			|||
					i++; | 
				
			|||
				} | 
				
			|||
			} else { | 
				
			|||
				i++; | 
				
			|||
			} | 
				
			|||
		} | 
				
			|||
		return mergeMap; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 获取样式 | 
				
			|||
	 * | 
				
			|||
	 * @param entity | 
				
			|||
	 * @param needOne | 
				
			|||
	 * @return | 
				
			|||
	 */ | 
				
			|||
	public CellStyle getStyles(boolean needOne, ExcelExportEntity entity) { | 
				
			|||
		return excelExportStyler.getStyles(needOne, entity); | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 合并单元格 | 
				
			|||
	 * | 
				
			|||
	 * @param sheet | 
				
			|||
	 * @param excelParams | 
				
			|||
	 * @param titleHeight | 
				
			|||
	 */ | 
				
			|||
	public void mergeCells(Sheet sheet, List<ExcelExportEntity> excelParams, int titleHeight) { | 
				
			|||
		Map<Integer, int[]> mergeMap = getMergeDataMap(excelParams); | 
				
			|||
		PoiMergeCellUtil.mergeCells(sheet, mergeMap, titleHeight); | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setCellWith(List<ExcelExportEntity> excelParams, Sheet sheet) { | 
				
			|||
		int index = 0; | 
				
			|||
		for (int i = 0; i < excelParams.size(); i++) { | 
				
			|||
			if (excelParams.get(i).getList() != null) { | 
				
			|||
				List<ExcelExportEntity> list = excelParams.get(i).getList(); | 
				
			|||
				for (int j = 0; j < list.size(); j++) { | 
				
			|||
					sheet.setColumnWidth(index, (int) (256 * list.get(j).getWidth())); | 
				
			|||
					index++; | 
				
			|||
				} | 
				
			|||
			} else { | 
				
			|||
				sheet.setColumnWidth(index, (int) (256 * excelParams.get(i).getWidth())); | 
				
			|||
				index++; | 
				
			|||
			} | 
				
			|||
		} | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setCurrentIndex(int currentIndex) { | 
				
			|||
		this.currentIndex = currentIndex; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void setExcelExportStyler(IExcelExportStyler excelExportStyler) { | 
				
			|||
		this.excelExportStyler = excelExportStyler; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public IExcelExportStyler getExcelExportStyler() { | 
				
			|||
		return excelExportStyler; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
} | 
				
			|||
@ -0,0 +1,452 @@ | 
				
			|||
/** | 
				
			|||
 * Copyright 2013-2015 JEECG (jeecgos@163.com) | 
				
			|||
 * | 
				
			|||
 *  Licensed under the Apache License, Version 2.0 (the "License"); | 
				
			|||
 *  you may not use this file except in compliance with the License. | 
				
			|||
 *  You may obtain a copy of the License at | 
				
			|||
 * | 
				
			|||
 *     http://www.apache.org/licenses/LICENSE-2.0
 | 
				
			|||
 * | 
				
			|||
 *  Unless required by applicable law or agreed to in writing, software | 
				
			|||
 * distributed under the License is distributed on an "AS IS" BASIS, | 
				
			|||
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | 
				
			|||
 * See the License for the specific language governing permissions and | 
				
			|||
 * limitations under the License. | 
				
			|||
 */ | 
				
			|||
package cc.admin.poi.excel.export.export.base; | 
				
			|||
 | 
				
			|||
import cc.admin.core.util.ApplicationContextUtil; | 
				
			|||
import cc.admin.dict.service.AutoPoiDictServiceI; | 
				
			|||
import cc.admin.poi.excel.annotation.Excel; | 
				
			|||
import cc.admin.poi.excel.annotation.ExcelCollection; | 
				
			|||
import cc.admin.poi.excel.annotation.ExcelEntity; | 
				
			|||
import cc.admin.poi.excel.entity.ExportParams; | 
				
			|||
import cc.admin.poi.excel.entity.params.ExcelExportEntity; | 
				
			|||
import cc.admin.poi.handler.inter.IExcelDataHandler; | 
				
			|||
import cc.admin.poi.util.PoiPublicUtil; | 
				
			|||
import org.apache.commons.lang3.StringUtils; | 
				
			|||
 | 
				
			|||
import java.lang.reflect.Field; | 
				
			|||
import java.lang.reflect.Method; | 
				
			|||
import java.lang.reflect.ParameterizedType; | 
				
			|||
import java.text.DecimalFormat; | 
				
			|||
import java.text.SimpleDateFormat; | 
				
			|||
import java.util.*; | 
				
			|||
 | 
				
			|||
/** | 
				
			|||
 * 导出基础处理,不设计POI,只设计对象,保证复用性 | 
				
			|||
 * | 
				
			|||
 * @author JEECG | 
				
			|||
 * @date 2014年8月9日 下午11:01:32 | 
				
			|||
 */ | 
				
			|||
public class ExportBase { | 
				
			|||
 | 
				
			|||
	protected IExcelDataHandler dataHanlder; | 
				
			|||
 | 
				
			|||
	protected List<String> needHanlderList; | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 创建导出实体对象 | 
				
			|||
	 * | 
				
			|||
	 * @param field | 
				
			|||
	 * @param targetId | 
				
			|||
	 * @param pojoClass | 
				
			|||
	 * @param getMethods | 
				
			|||
	 * @return | 
				
			|||
	 * @throws Exception | 
				
			|||
	 */ | 
				
			|||
	private ExcelExportEntity createExcelExportEntity(Field field, String targetId, Class<?> pojoClass, List<Method> getMethods) throws Exception { | 
				
			|||
		Excel excel = field.getAnnotation(Excel.class); | 
				
			|||
		ExcelExportEntity excelEntity = new ExcelExportEntity(); | 
				
			|||
		excelEntity.setType(excel.type()); | 
				
			|||
		getExcelField(targetId, field, excelEntity, excel, pojoClass); | 
				
			|||
		if (getMethods != null) { | 
				
			|||
			List<Method> newMethods = new ArrayList<Method>(); | 
				
			|||
			newMethods.addAll(getMethods); | 
				
			|||
			newMethods.add(excelEntity.getMethod()); | 
				
			|||
			excelEntity.setMethods(newMethods); | 
				
			|||
		} | 
				
			|||
		return excelEntity; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	private Object formatValue(Object value, ExcelExportEntity entity) throws Exception { | 
				
			|||
		Date temp = null; | 
				
			|||
		if (value instanceof String) { | 
				
			|||
			SimpleDateFormat format = new SimpleDateFormat(entity.getDatabaseFormat()); | 
				
			|||
			temp = format.parse(value.toString()); | 
				
			|||
		} else if (value instanceof Date) { | 
				
			|||
			temp = (Date) value; | 
				
			|||
		} | 
				
			|||
		if (temp != null) { | 
				
			|||
			SimpleDateFormat format = new SimpleDateFormat(entity.getFormat()); | 
				
			|||
			value = format.format(temp); | 
				
			|||
		} | 
				
			|||
		return value; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 获取需要导出的全部字段 | 
				
			|||
	 * | 
				
			|||
	 * @param exclusions | 
				
			|||
	 * @param targetId | 
				
			|||
	 *            目标ID | 
				
			|||
	 * @param fields | 
				
			|||
	 * @throws Exception | 
				
			|||
	 */ | 
				
			|||
	public void getAllExcelField(String[] exclusions, String targetId, Field[] fields, List<ExcelExportEntity> excelParams, Class<?> pojoClass, List<Method> getMethods) throws Exception { | 
				
			|||
		List<String> exclusionsList = exclusions != null ? Arrays.asList(exclusions) : null; | 
				
			|||
		ExcelExportEntity excelEntity; | 
				
			|||
		// 遍历整个filed
 | 
				
			|||
		for (int i = 0; i < fields.length; i++) { | 
				
			|||
			Field field = fields[i]; | 
				
			|||
			// 先判断是不是collection,在判断是不是java自带对象,之后就是我们自己的对象了
 | 
				
			|||
			if (PoiPublicUtil.isNotUserExcelUserThis(exclusionsList, field, targetId)) { | 
				
			|||
				continue; | 
				
			|||
			} | 
				
			|||
			// 首先判断Excel 可能一下特殊数据用户回自定义处理
 | 
				
			|||
			if (field.getAnnotation(Excel.class) != null) { | 
				
			|||
				excelParams.add(createExcelExportEntity(field, targetId, pojoClass, getMethods)); | 
				
			|||
			} else if (PoiPublicUtil.isCollection(field.getType())) { | 
				
			|||
				ExcelCollection excel = field.getAnnotation(ExcelCollection.class); | 
				
			|||
				ParameterizedType pt = (ParameterizedType) field.getGenericType(); | 
				
			|||
				Class<?> clz = (Class<?>) pt.getActualTypeArguments()[0]; | 
				
			|||
				List<ExcelExportEntity> list = new ArrayList<ExcelExportEntity>(); | 
				
			|||
				getAllExcelField(exclusions, StringUtils.isNotEmpty(excel.id()) ? excel.id() : targetId, PoiPublicUtil.getClassFields(clz), list, clz, null); | 
				
			|||
				excelEntity = new ExcelExportEntity(); | 
				
			|||
				excelEntity.setName(getExcelName(excel.name(), targetId)); | 
				
			|||
				excelEntity.setOrderNum(getCellOrder(excel.orderNum(), targetId)); | 
				
			|||
				excelEntity.setMethod(PoiPublicUtil.getMethod(field.getName(), pojoClass)); | 
				
			|||
				excelEntity.setList(list); | 
				
			|||
				excelParams.add(excelEntity); | 
				
			|||
			} else { | 
				
			|||
				List<Method> newMethods = new ArrayList<Method>(); | 
				
			|||
				if (getMethods != null) { | 
				
			|||
					newMethods.addAll(getMethods); | 
				
			|||
				} | 
				
			|||
				newMethods.add(PoiPublicUtil.getMethod(field.getName(), pojoClass)); | 
				
			|||
				ExcelEntity excel = field.getAnnotation(ExcelEntity.class); | 
				
			|||
				getAllExcelField(exclusions, StringUtils.isNotEmpty(excel.id()) ? excel.id() : targetId, PoiPublicUtil.getClassFields(field.getType()), excelParams, field.getType(), newMethods); | 
				
			|||
			} | 
				
			|||
		} | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 获取这个字段的顺序 | 
				
			|||
	 * | 
				
			|||
	 * @param orderNum | 
				
			|||
	 * @param targetId | 
				
			|||
	 * @return | 
				
			|||
	 */ | 
				
			|||
	public int getCellOrder(String orderNum, String targetId) { | 
				
			|||
		if (isInteger(orderNum) || targetId == null) { | 
				
			|||
			return Integer.valueOf(orderNum); | 
				
			|||
		} | 
				
			|||
		String[] arr = orderNum.split(","); | 
				
			|||
		String[] temp; | 
				
			|||
		for (String str : arr) { | 
				
			|||
			temp = str.split("_"); | 
				
			|||
			if (targetId.equals(temp[1])) { | 
				
			|||
				return Integer.valueOf(temp[0]); | 
				
			|||
			} | 
				
			|||
		} | 
				
			|||
		return 0; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 获取填如这个cell的值,提供一些附加功能 | 
				
			|||
	 * | 
				
			|||
	 * @param entity | 
				
			|||
	 * @param obj | 
				
			|||
	 * @return | 
				
			|||
	 * @throws Exception | 
				
			|||
	 */ | 
				
			|||
	public Object getCellValue(ExcelExportEntity entity, Object obj) throws Exception { | 
				
			|||
		Object value; | 
				
			|||
		if (obj instanceof Map) { | 
				
			|||
			value = ((Map<?, ?>) obj).get(entity.getKey()); | 
				
			|||
		} else { | 
				
			|||
			value = entity.getMethods() != null ? getFieldBySomeMethod(entity.getMethods(), obj) : entity.getMethod().invoke(obj, new Object[] {}); | 
				
			|||
		} | 
				
			|||
		//update-begin-author:taoyan date:2020319 for:Excel注解的numFormat方法似乎未实现 #970
 | 
				
			|||
		if (StringUtils.isNotEmpty(entity.getNumFormat()) && value!=null) { | 
				
			|||
			value = new DecimalFormat(entity.getNumFormat()).format(value); | 
				
			|||
		} | 
				
			|||
		//update-end-author:taoyan date:2020319 for:Excel注解的numFormat方法似乎未实现 #970
 | 
				
			|||
 | 
				
			|||
		if (StringUtils.isNotEmpty(entity.getFormat())) { | 
				
			|||
			value = formatValue(value, entity); | 
				
			|||
		} | 
				
			|||
		if (entity.getReplace() != null && entity.getReplace().length > 0) { | 
				
			|||
			//update-begin-author:taoyan date:20180731 for:TASK #3038 【bug】Excel 导出多个值(逗号隔开的情况下,导出字典值是ID值)
 | 
				
			|||
			if(value == null){ | 
				
			|||
				value = "";//String.valueOf(value) 如果value为null 则返回"null"
 | 
				
			|||
			} | 
				
			|||
			if(entity.isMultiReplace()){ | 
				
			|||
				value = multiReplaceValue(entity.getReplace(), String.valueOf(value)); | 
				
			|||
			}else{ | 
				
			|||
				value = replaceValue(entity.getReplace(), String.valueOf(value)); | 
				
			|||
			} | 
				
			|||
			//update-end-author:taoyan date:20180731 for:TASK #3038 【bug】Excel 导出多个值(逗号隔开的情况下,导出字典值是ID值)
 | 
				
			|||
		} | 
				
			|||
		if (needHanlderList != null && needHanlderList.contains(entity.getName())) { | 
				
			|||
			value = dataHanlder.exportHandler(obj, entity.getName(), value); | 
				
			|||
		} | 
				
			|||
		if (StringUtils.isNotEmpty(entity.getSuffix()) && value != null) { | 
				
			|||
			value = value + entity.getSuffix(); | 
				
			|||
		} | 
				
			|||
		return value == null ? "" : value.toString(); | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 获取集合的值 | 
				
			|||
	 * | 
				
			|||
	 * @param entity | 
				
			|||
	 * @param obj | 
				
			|||
	 * @return | 
				
			|||
	 * @throws Exception | 
				
			|||
	 */ | 
				
			|||
	public Collection<?> getListCellValue(ExcelExportEntity entity, Object obj) throws Exception { | 
				
			|||
		Object value; | 
				
			|||
		if (obj instanceof Map) { | 
				
			|||
			value = ((Map<?, ?>) obj).get(entity.getKey()); | 
				
			|||
		} else { | 
				
			|||
			value = (Collection<?>) entity.getMethod().invoke(obj, new Object[] {}); | 
				
			|||
		} | 
				
			|||
		return (Collection<?>) value; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 注解到导出对象的转换 | 
				
			|||
	 * | 
				
			|||
	 * @param targetId | 
				
			|||
	 * @param field | 
				
			|||
	 * @param excelEntity | 
				
			|||
	 * @param excel | 
				
			|||
	 * @param pojoClass | 
				
			|||
	 * @throws Exception | 
				
			|||
	 */ | 
				
			|||
	private void getExcelField(String targetId, Field field, ExcelExportEntity excelEntity, Excel excel, Class<?> pojoClass) throws Exception { | 
				
			|||
		excelEntity.setName(getExcelName(excel.name(), targetId)); | 
				
			|||
		excelEntity.setWidth(excel.width()); | 
				
			|||
		excelEntity.setHeight(excel.height()); | 
				
			|||
		excelEntity.setNeedMerge(excel.needMerge()); | 
				
			|||
		excelEntity.setMergeVertical(excel.mergeVertical()); | 
				
			|||
		excelEntity.setMergeRely(excel.mergeRely()); | 
				
			|||
		excelEntity.setReplace(excel.replace()); | 
				
			|||
		if(StringUtils.isNotEmpty(excel.dicCode())){ | 
				
			|||
			AutoPoiDictServiceI ccDictService = null; | 
				
			|||
			try { | 
				
			|||
				ccDictService = ApplicationContextUtil.getContext().getBean(AutoPoiDictServiceI.class); | 
				
			|||
			} catch (Exception e) { | 
				
			|||
			} | 
				
			|||
			if(ccDictService!=null){ | 
				
			|||
				 String[] dictReplace = ccDictService.queryDict(excel.dictTable(), excel.dicCode(), excel.dicText()); | 
				
			|||
				 if(excelEntity.getReplace()!=null && dictReplace!=null && dictReplace.length!=0){ | 
				
			|||
					 excelEntity.setReplace(dictReplace); | 
				
			|||
				 } | 
				
			|||
			} | 
				
			|||
		} | 
				
			|||
		excelEntity.setOrderNum(getCellOrder(excel.orderNum(), targetId)); | 
				
			|||
		excelEntity.setWrap(excel.isWrap()); | 
				
			|||
		excelEntity.setExportImageType(excel.imageType()); | 
				
			|||
		excelEntity.setSuffix(excel.suffix()); | 
				
			|||
		excelEntity.setDatabaseFormat(excel.databaseFormat()); | 
				
			|||
		excelEntity.setFormat(StringUtils.isNotEmpty(excel.exportFormat()) ? excel.exportFormat() : excel.format()); | 
				
			|||
		excelEntity.setStatistics(excel.isStatistics()); | 
				
			|||
		String fieldname = field.getName(); | 
				
			|||
		//update-begin-author:taoyan date:20200319 for:autopoi 双表头问题 #862 基于注解的解决方案
 | 
				
			|||
		excelEntity.setKey(fieldname); | 
				
			|||
		//update-end-author:taoyan date:20200319 for:autopoi 双表头问题 #862 基于注解的解决方案
 | 
				
			|||
		//update-begin-author:taoyan date:20200319 for:Excel注解的numFormat方法似乎未实现 #970
 | 
				
			|||
		excelEntity.setNumFormat(excel.numFormat()); | 
				
			|||
		//update-end-author:taoyan date:20200319 for:Excel注解的numFormat方法似乎未实现 #970
 | 
				
			|||
		//update-begin-author:taoyan date:20180615 for:TASK #2798 【例子】导入扩展方法,支持自定义导入字段转换规则
 | 
				
			|||
		excelEntity.setMethod(PoiPublicUtil.getMethod(fieldname, pojoClass,excel.exportConvert())); | 
				
			|||
		//update-end-author:taoyan date:20180615 for:TASK #2798 【例子】导入扩展方法,支持自定义导入字段转换规则
 | 
				
			|||
		//update-begin-author:taoyan date:20180801 for:TASK #3038 【bug】Excel 导出多个值(逗号隔开的情况下,导出字典值是ID值)
 | 
				
			|||
		excelEntity.setMultiReplace(excel.multiReplace()); | 
				
			|||
		//update-end-author:taoyan date:20180801 for:TASK #3038 【bug】Excel 导出多个值(逗号隔开的情况下,导出字典值是ID值)
 | 
				
			|||
		//update-begin-author:taoyan date:20200319 for:autopoi 双表头问题 #862 基于实体注解的解决方案
 | 
				
			|||
		if(StringUtils.isNotEmpty(excel.groupName())){ | 
				
			|||
			excelEntity.setGroupName(excel.groupName()); | 
				
			|||
			excelEntity.setColspan(true); | 
				
			|||
		} | 
				
			|||
		//update-end-author:taoyan date:20200319 for:autopoi 双表头问题 #862 基于实体注解的解决方案
 | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 判断在这个单元格显示的名称 | 
				
			|||
	 * | 
				
			|||
	 * @param exportName | 
				
			|||
	 * @param targetId | 
				
			|||
	 * @return | 
				
			|||
	 */ | 
				
			|||
	public String getExcelName(String exportName, String targetId) { | 
				
			|||
		if (exportName.indexOf(",") < 0 || targetId==null) { | 
				
			|||
			return exportName; | 
				
			|||
		} | 
				
			|||
		String[] arr = exportName.split(","); | 
				
			|||
		for (String str : arr) { | 
				
			|||
			if (str.indexOf(targetId) != -1) { | 
				
			|||
				return str.split("_")[0]; | 
				
			|||
			} | 
				
			|||
		} | 
				
			|||
		return null; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 多个反射获取值 | 
				
			|||
	 * | 
				
			|||
	 * @param list | 
				
			|||
	 * @param t | 
				
			|||
	 * @return | 
				
			|||
	 * @throws Exception | 
				
			|||
	 */ | 
				
			|||
	public Object getFieldBySomeMethod(List<Method> list, Object t) throws Exception { | 
				
			|||
		for (Method m : list) { | 
				
			|||
			if (t == null) { | 
				
			|||
				t = ""; | 
				
			|||
				break; | 
				
			|||
			} | 
				
			|||
			t = m.invoke(t, new Object[] {}); | 
				
			|||
		} | 
				
			|||
		return t; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 根据注解获取行高 | 
				
			|||
	 * | 
				
			|||
	 * @param excelParams | 
				
			|||
	 * @return | 
				
			|||
	 */ | 
				
			|||
	public short getRowHeight(List<ExcelExportEntity> excelParams) { | 
				
			|||
		double maxHeight = 0; | 
				
			|||
		for (int i = 0; i < excelParams.size(); i++) { | 
				
			|||
			maxHeight = maxHeight > excelParams.get(i).getHeight() ? maxHeight : excelParams.get(i).getHeight(); | 
				
			|||
			if (excelParams.get(i).getList() != null) { | 
				
			|||
				for (int j = 0; j < excelParams.get(i).getList().size(); j++) { | 
				
			|||
					maxHeight = maxHeight > excelParams.get(i).getList().get(j).getHeight() ? maxHeight : excelParams.get(i).getList().get(j).getHeight(); | 
				
			|||
				} | 
				
			|||
			} | 
				
			|||
		} | 
				
			|||
		return (short) (maxHeight * 50); | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 判断字符串是否是整数 | 
				
			|||
	 */ | 
				
			|||
	public boolean isInteger(String value) { | 
				
			|||
		try { | 
				
			|||
			Integer.parseInt(value); | 
				
			|||
			return true; | 
				
			|||
		} catch (NumberFormatException e) { | 
				
			|||
			return false; | 
				
			|||
		} | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	private Object replaceValue(String[] replace, String value) { | 
				
			|||
		String[] temp; | 
				
			|||
		for (String str : replace) { | 
				
			|||
			temp = str.split("_"); | 
				
			|||
			if (value.equals(temp[1])) { | 
				
			|||
				value = temp[0]; | 
				
			|||
				break; | 
				
			|||
			} | 
				
			|||
		} | 
				
			|||
		return value; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	//update-begin-author:taoyan date:20180731 for:TASK #3038 【bug】Excel 导出多个值(逗号隔开的情况下,导出字典值是ID值)
 | 
				
			|||
	/** | 
				
			|||
	 * 如果需要被替换的值是多选项,则每一项之间有逗号隔开,走以下方法 | 
				
			|||
	 * @author taoYan | 
				
			|||
	 * @since 2018年7月31日 | 
				
			|||
	 */ | 
				
			|||
	private Object multiReplaceValue(String[] replace, String value) { | 
				
			|||
		if(value.indexOf(",")>0){ | 
				
			|||
			String[] radioVals = value.split(","); | 
				
			|||
			String[] temp; | 
				
			|||
			String result = ""; | 
				
			|||
			for(int i =0;i<radioVals.length;i++){ | 
				
			|||
				String radio = radioVals[i]; | 
				
			|||
				for (String str : replace) { | 
				
			|||
					temp = str.split("_"); | 
				
			|||
					if (radio.equals(temp[1])) { | 
				
			|||
						result = result.concat(temp[0])+","; | 
				
			|||
						break; | 
				
			|||
					} | 
				
			|||
				} | 
				
			|||
			} | 
				
			|||
			if(result.equals("")){ | 
				
			|||
				result = value; | 
				
			|||
			}else{ | 
				
			|||
				result = result.substring(0, result.length()-1); | 
				
			|||
			} | 
				
			|||
			return result; | 
				
			|||
		}else{ | 
				
			|||
			return replaceValue(replace, value); | 
				
			|||
		} | 
				
			|||
	} | 
				
			|||
	//update-end-author:taoyan date:20180731 for:TASK #3038 【bug】Excel 导出多个值(逗号隔开的情况下,导出字典值是ID值)
 | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 对字段根据用户设置排序 | 
				
			|||
	 */ | 
				
			|||
	public void sortAllParams(List<ExcelExportEntity> excelParams) { | 
				
			|||
		Collections.sort(excelParams); | 
				
			|||
		for (ExcelExportEntity entity : excelParams) { | 
				
			|||
			if (entity.getList() != null) { | 
				
			|||
				Collections.sort(entity.getList()); | 
				
			|||
			} | 
				
			|||
		} | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 循环ExcelExportEntity集合 附加配置信息<br> | 
				
			|||
	 * 1.列排序<br> | 
				
			|||
	 * 2.读取图片根路径设置(如果有字段是图片类型 并且存储在本地 则设置磁盘路径获取全地址导出)<br> | 
				
			|||
	 * 3.多表头配置(仅限于单表 会走这个逻辑处理) | 
				
			|||
	 */ | 
				
			|||
	public void reConfigExcelExportParams(List<ExcelExportEntity> excelParams, ExportParams exportParams) { | 
				
			|||
		Set<String> NameSet = new HashSet<String>(); | 
				
			|||
		Map<String,List<String>> groupAndColumnList = new HashMap<String,List<String>>(); | 
				
			|||
		Map<String,Integer> groupOrder = new HashMap<>(); | 
				
			|||
		int index = -99; | 
				
			|||
		for (ExcelExportEntity entity : excelParams) { | 
				
			|||
			if(entity.getOrderNum()==0){ | 
				
			|||
				entity.setOrderNum(index++); | 
				
			|||
			} | 
				
			|||
			if(entity.getExportImageType()==3){ | 
				
			|||
				entity.setImageBasePath(exportParams.getImageBasePath()); | 
				
			|||
			} | 
				
			|||
			if (entity.getList() != null) { | 
				
			|||
				Collections.sort(entity.getList()); | 
				
			|||
			} | 
				
			|||
			String groupName = entity.getGroupName(); | 
				
			|||
			if(StringUtils.isNotEmpty(groupName)){ | 
				
			|||
				List<String> ls = groupAndColumnList.get(groupName); | 
				
			|||
				if(ls==null){ | 
				
			|||
					ls = new ArrayList<String>(); | 
				
			|||
					groupAndColumnList.put(groupName,ls); | 
				
			|||
				} | 
				
			|||
				ls.add(entity.getKey().toString()); | 
				
			|||
 | 
				
			|||
				Integer order = groupOrder.get(groupName); | 
				
			|||
				if(order==null || entity.getOrderNum()<order){ | 
				
			|||
					order = entity.getOrderNum(); | 
				
			|||
				} | 
				
			|||
				groupOrder.put(groupName,order); | 
				
			|||
			} | 
				
			|||
		} | 
				
			|||
 | 
				
			|||
		for(String key: groupAndColumnList.keySet()){ | 
				
			|||
			ExcelExportEntity temp = new ExcelExportEntity(key); | 
				
			|||
			temp.setColspan(true); | 
				
			|||
			temp.setSubColumnList(groupAndColumnList.get(key)); | 
				
			|||
			temp.setOrderNum(groupOrder.get(key)); | 
				
			|||
			excelParams.add(temp); | 
				
			|||
		} | 
				
			|||
		Collections.sort(excelParams); | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
} | 
				
			|||
@ -0,0 +1,72 @@ | 
				
			|||
/** | 
				
			|||
 * Copyright 2013-2015 JEECG (jeecgos@163.com) | 
				
			|||
 * | 
				
			|||
 *  Licensed under the Apache License, Version 2.0 (the "License"); | 
				
			|||
 *  you may not use this file except in compliance with the License. | 
				
			|||
 *  You may obtain a copy of the License at | 
				
			|||
 * | 
				
			|||
 *     http://www.apache.org/licenses/LICENSE-2.0
 | 
				
			|||
 * | 
				
			|||
 *  Unless required by applicable law or agreed to in writing, software | 
				
			|||
 * distributed under the License is distributed on an "AS IS" BASIS, | 
				
			|||
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | 
				
			|||
 * See the License for the specific language governing permissions and | 
				
			|||
 * limitations under the License. | 
				
			|||
 */ | 
				
			|||
package cc.admin.poi.excel.export.export.styler; | 
				
			|||
 | 
				
			|||
import cc.admin.poi.excel.entity.params.ExcelExportEntity; | 
				
			|||
import cc.admin.poi.excel.export.styler.IExcelExportStyler; | 
				
			|||
import org.apache.poi.ss.usermodel.BuiltinFormats; | 
				
			|||
import org.apache.poi.ss.usermodel.CellStyle; | 
				
			|||
import org.apache.poi.ss.usermodel.Workbook; | 
				
			|||
 | 
				
			|||
/** | 
				
			|||
 * 抽象接口提供两个公共方法 | 
				
			|||
 * | 
				
			|||
 * @author JEECG | 
				
			|||
 * @date 2015年1月9日 下午5:48:55 | 
				
			|||
 */ | 
				
			|||
public abstract class AbstractExcelExportStyler implements IExcelExportStyler { | 
				
			|||
	// 单行
 | 
				
			|||
	protected CellStyle stringNoneStyle; | 
				
			|||
	protected CellStyle stringNoneWrapStyle; | 
				
			|||
	// 间隔行
 | 
				
			|||
	protected CellStyle stringSeptailStyle; | 
				
			|||
	protected CellStyle stringSeptailWrapStyle; | 
				
			|||
 | 
				
			|||
	protected Workbook workbook; | 
				
			|||
 | 
				
			|||
	protected static final short STRING_FORMAT = (short) BuiltinFormats.getBuiltinFormat("TEXT"); | 
				
			|||
 | 
				
			|||
	protected void createStyles(Workbook workbook) { | 
				
			|||
		this.stringNoneStyle = stringNoneStyle(workbook, false); | 
				
			|||
		this.stringNoneWrapStyle = stringNoneStyle(workbook, true); | 
				
			|||
		this.stringSeptailStyle = stringSeptailStyle(workbook, false); | 
				
			|||
		this.stringSeptailWrapStyle = stringSeptailStyle(workbook, true); | 
				
			|||
		this.workbook = workbook; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	@Override | 
				
			|||
	public CellStyle getStyles(boolean noneStyler, ExcelExportEntity entity) { | 
				
			|||
		if (noneStyler && (entity == null || entity.isWrap())) { | 
				
			|||
			return stringNoneWrapStyle; | 
				
			|||
		} | 
				
			|||
		if (noneStyler) { | 
				
			|||
			return stringNoneStyle; | 
				
			|||
		} | 
				
			|||
		if (noneStyler == false && (entity == null || entity.isWrap())) { | 
				
			|||
			return stringSeptailWrapStyle; | 
				
			|||
		} | 
				
			|||
		return stringSeptailStyle; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public CellStyle stringNoneStyle(Workbook workbook, boolean isWarp) { | 
				
			|||
		return null; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public CellStyle stringSeptailStyle(Workbook workbook, boolean isWarp) { | 
				
			|||
		return null; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
} | 
				
			|||
@ -0,0 +1,88 @@ | 
				
			|||
/** | 
				
			|||
 * Copyright 2013-2015 JEECG (jeecgos@163.com) | 
				
			|||
 * | 
				
			|||
 *  Licensed under the Apache License, Version 2.0 (the "License"); | 
				
			|||
 *  you may not use this file except in compliance with the License. | 
				
			|||
 *  You may obtain a copy of the License at | 
				
			|||
 * | 
				
			|||
 *     http://www.apache.org/licenses/LICENSE-2.0
 | 
				
			|||
 * | 
				
			|||
 *  Unless required by applicable law or agreed to in writing, software | 
				
			|||
 * distributed under the License is distributed on an "AS IS" BASIS, | 
				
			|||
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | 
				
			|||
 * See the License for the specific language governing permissions and | 
				
			|||
 * limitations under the License. | 
				
			|||
 */ | 
				
			|||
package cc.admin.poi.excel.export.export.styler; | 
				
			|||
 | 
				
			|||
import cc.admin.poi.excel.export.styler.AbstractExcelExportStyler; | 
				
			|||
import cc.admin.poi.excel.export.styler.IExcelExportStyler; | 
				
			|||
import org.apache.poi.ss.usermodel.*; | 
				
			|||
 | 
				
			|||
/** | 
				
			|||
 * 带有边框的Excel样式 | 
				
			|||
 * | 
				
			|||
 * @author JEECG | 
				
			|||
 * @date 2015年1月9日 下午5:55:29 | 
				
			|||
 */ | 
				
			|||
public class ExcelExportStylerBorderImpl extends AbstractExcelExportStyler implements IExcelExportStyler { | 
				
			|||
 | 
				
			|||
	public ExcelExportStylerBorderImpl(Workbook workbook) { | 
				
			|||
		super.createStyles(workbook); | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	@Override | 
				
			|||
	public CellStyle getHeaderStyle(short color) { | 
				
			|||
		CellStyle titleStyle = workbook.createCellStyle(); | 
				
			|||
		Font font = workbook.createFont(); | 
				
			|||
		font.setFontHeightInPoints((short) 12); | 
				
			|||
		titleStyle.setFont(font); | 
				
			|||
		titleStyle.setBorderLeft(BorderStyle.THIN); // 左边框
 | 
				
			|||
		titleStyle.setBorderRight(BorderStyle.THIN); // 右边框
 | 
				
			|||
		titleStyle.setBorderBottom( BorderStyle.THIN); | 
				
			|||
		titleStyle.setBorderTop(BorderStyle.THIN); | 
				
			|||
 | 
				
			|||
		// 设置对齐方式
 | 
				
			|||
		titleStyle.setAlignment(HorizontalAlignment.CENTER); | 
				
			|||
		titleStyle.setVerticalAlignment(VerticalAlignment.CENTER); | 
				
			|||
 | 
				
			|||
		return titleStyle; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	@Override | 
				
			|||
	public CellStyle stringNoneStyle(Workbook workbook, boolean isWarp) { | 
				
			|||
		CellStyle style = workbook.createCellStyle(); | 
				
			|||
		style.setBorderLeft(BorderStyle.THIN); // 左边框
 | 
				
			|||
		style.setBorderRight(BorderStyle.THIN); // 右边框
 | 
				
			|||
		style.setBorderBottom(BorderStyle.THIN); | 
				
			|||
		style.setBorderTop(BorderStyle.THIN); | 
				
			|||
		// 设置对齐方式
 | 
				
			|||
		style.setAlignment(HorizontalAlignment.CENTER); | 
				
			|||
		style.setVerticalAlignment(VerticalAlignment.CENTER); | 
				
			|||
		style.setDataFormat(STRING_FORMAT); | 
				
			|||
		if (isWarp) { | 
				
			|||
			style.setWrapText(true); | 
				
			|||
		} | 
				
			|||
		return style; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	@Override | 
				
			|||
	public CellStyle getTitleStyle(short color) { | 
				
			|||
		CellStyle titleStyle = workbook.createCellStyle(); | 
				
			|||
		titleStyle.setBorderLeft(BorderStyle.THIN); // 左边框
 | 
				
			|||
		titleStyle.setBorderRight(BorderStyle.THIN); // 右边框
 | 
				
			|||
		titleStyle.setBorderBottom(BorderStyle.THIN); | 
				
			|||
		titleStyle.setBorderTop(BorderStyle.THIN); | 
				
			|||
		// 设置对齐方式
 | 
				
			|||
		titleStyle.setAlignment(HorizontalAlignment.CENTER); | 
				
			|||
		titleStyle.setVerticalAlignment(VerticalAlignment.CENTER); | 
				
			|||
		titleStyle.setWrapText(true); | 
				
			|||
		return titleStyle; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	@Override | 
				
			|||
	public CellStyle stringSeptailStyle(Workbook workbook, boolean isWarp) { | 
				
			|||
		return isWarp ? stringNoneWrapStyle : stringNoneStyle; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
} | 
				
			|||
@ -0,0 +1,91 @@ | 
				
			|||
/** | 
				
			|||
 * Copyright 2013-2015 JEECG (jeecgos@163.com) | 
				
			|||
 * | 
				
			|||
 *  Licensed under the Apache License, Version 2.0 (the "License"); | 
				
			|||
 *  you may not use this file except in compliance with the License. | 
				
			|||
 *  You may obtain a copy of the License at | 
				
			|||
 * | 
				
			|||
 *     http://www.apache.org/licenses/LICENSE-2.0
 | 
				
			|||
 * | 
				
			|||
 *  Unless required by applicable law or agreed to in writing, software | 
				
			|||
 * distributed under the License is distributed on an "AS IS" BASIS, | 
				
			|||
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | 
				
			|||
 * See the License for the specific language governing permissions and | 
				
			|||
 * limitations under the License. | 
				
			|||
 */ | 
				
			|||
package cc.admin.poi.excel.export.export.styler; | 
				
			|||
 | 
				
			|||
import cc.admin.poi.excel.export.styler.AbstractExcelExportStyler; | 
				
			|||
import cc.admin.poi.excel.export.styler.IExcelExportStyler; | 
				
			|||
import org.apache.poi.ss.usermodel.*; | 
				
			|||
 | 
				
			|||
/** | 
				
			|||
 * 带有样式的导出服务 | 
				
			|||
 * | 
				
			|||
 * @author JEECG | 
				
			|||
 * @date 2015年1月9日 下午4:54:15 | 
				
			|||
 */ | 
				
			|||
public class ExcelExportStylerColorImpl extends AbstractExcelExportStyler implements IExcelExportStyler { | 
				
			|||
 | 
				
			|||
	public ExcelExportStylerColorImpl(Workbook workbook) { | 
				
			|||
		super.createStyles(workbook); | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	@Override | 
				
			|||
	public CellStyle getHeaderStyle(short headerColor) { | 
				
			|||
		CellStyle titleStyle = workbook.createCellStyle(); | 
				
			|||
		Font font = workbook.createFont(); | 
				
			|||
		font.setFontHeightInPoints((short) 24); | 
				
			|||
		titleStyle.setFont(font); | 
				
			|||
		titleStyle.setFillForegroundColor(headerColor); | 
				
			|||
		titleStyle.setAlignment(HorizontalAlignment.CENTER); | 
				
			|||
		titleStyle.setVerticalAlignment(VerticalAlignment.CENTER); | 
				
			|||
		return titleStyle; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	@Override | 
				
			|||
	public CellStyle stringNoneStyle(Workbook workbook, boolean isWarp) { | 
				
			|||
		CellStyle style = workbook.createCellStyle(); | 
				
			|||
		style.setBorderLeft(BorderStyle.THIN); // 左边框
 | 
				
			|||
		style.setBorderRight(BorderStyle.THIN); // 右边框
 | 
				
			|||
		style.setBorderBottom(BorderStyle.THIN); | 
				
			|||
		style.setBorderTop(BorderStyle.THIN); | 
				
			|||
		style.setAlignment(HorizontalAlignment.CENTER); | 
				
			|||
		style.setVerticalAlignment(VerticalAlignment.CENTER); | 
				
			|||
		style.setDataFormat(STRING_FORMAT); | 
				
			|||
		if (isWarp) { | 
				
			|||
			style.setWrapText(true); | 
				
			|||
		} | 
				
			|||
		return style; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	@Override | 
				
			|||
	public CellStyle getTitleStyle(short color) { | 
				
			|||
		CellStyle titleStyle = workbook.createCellStyle(); | 
				
			|||
		titleStyle.setFillForegroundColor(color); // 填充的背景颜色
 | 
				
			|||
		titleStyle.setAlignment(HorizontalAlignment.CENTER); | 
				
			|||
		titleStyle.setVerticalAlignment(VerticalAlignment.CENTER); | 
				
			|||
		titleStyle.setFillPattern(FillPatternType.SOLID_FOREGROUND); | 
				
			|||
		titleStyle.setWrapText(true); | 
				
			|||
		return titleStyle; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	@Override | 
				
			|||
	public CellStyle stringSeptailStyle(Workbook workbook, boolean isWarp) { | 
				
			|||
		CellStyle style = workbook.createCellStyle(); | 
				
			|||
		style.setBorderLeft(BorderStyle.THIN); // 左边框
 | 
				
			|||
		style.setBorderRight(BorderStyle.THIN); // 右边框
 | 
				
			|||
		style.setBorderBottom(BorderStyle.THIN); | 
				
			|||
		style.setBorderTop(BorderStyle.THIN); | 
				
			|||
		style.setFillForegroundColor((short) 41); // 填充的背景颜色
 | 
				
			|||
		style.setFillPattern(FillPatternType.SOLID_FOREGROUND); | 
				
			|||
		style.setAlignment(HorizontalAlignment.CENTER); | 
				
			|||
		style.setVerticalAlignment(VerticalAlignment.CENTER); | 
				
			|||
		style.setDataFormat(STRING_FORMAT); | 
				
			|||
		if (isWarp) { | 
				
			|||
			style.setWrapText(true); | 
				
			|||
		} | 
				
			|||
		return style; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
} | 
				
			|||
@ -0,0 +1,78 @@ | 
				
			|||
/** | 
				
			|||
 * Copyright 2013-2015 JEECG (jeecgos@163.com) | 
				
			|||
 * | 
				
			|||
 *  Licensed under the Apache License, Version 2.0 (the "License"); | 
				
			|||
 *  you may not use this file except in compliance with the License. | 
				
			|||
 *  You may obtain a copy of the License at | 
				
			|||
 * | 
				
			|||
 *     http://www.apache.org/licenses/LICENSE-2.0
 | 
				
			|||
 * | 
				
			|||
 *  Unless required by applicable law or agreed to in writing, software | 
				
			|||
 * distributed under the License is distributed on an "AS IS" BASIS, | 
				
			|||
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | 
				
			|||
 * See the License for the specific language governing permissions and | 
				
			|||
 * limitations under the License. | 
				
			|||
 */ | 
				
			|||
package cc.admin.poi.excel.export.export.styler; | 
				
			|||
 | 
				
			|||
import cc.admin.poi.excel.export.styler.AbstractExcelExportStyler; | 
				
			|||
import cc.admin.poi.excel.export.styler.IExcelExportStyler; | 
				
			|||
import org.apache.poi.ss.usermodel.*; | 
				
			|||
 | 
				
			|||
/** | 
				
			|||
 * 样式的默认实现 | 
				
			|||
 * | 
				
			|||
 * @author JEECG | 
				
			|||
 * @date 2015年1月9日 下午5:36:08 | 
				
			|||
 */ | 
				
			|||
public class ExcelExportStylerDefaultImpl extends AbstractExcelExportStyler implements IExcelExportStyler { | 
				
			|||
 | 
				
			|||
	public ExcelExportStylerDefaultImpl(Workbook workbook) { | 
				
			|||
		super.createStyles(workbook); | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	@Override | 
				
			|||
	public CellStyle getTitleStyle(short color) { | 
				
			|||
		CellStyle titleStyle = workbook.createCellStyle(); | 
				
			|||
		titleStyle.setAlignment(HorizontalAlignment.CENTER); | 
				
			|||
		titleStyle.setVerticalAlignment(VerticalAlignment.CENTER); | 
				
			|||
		titleStyle.setWrapText(true); | 
				
			|||
		return titleStyle; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	@Override | 
				
			|||
	public CellStyle stringSeptailStyle(Workbook workbook, boolean isWarp) { | 
				
			|||
		CellStyle style = workbook.createCellStyle(); | 
				
			|||
		style.setAlignment(HorizontalAlignment.CENTER); | 
				
			|||
		style.setVerticalAlignment(VerticalAlignment.CENTER); | 
				
			|||
		style.setDataFormat(STRING_FORMAT); | 
				
			|||
		if (isWarp) { | 
				
			|||
			style.setWrapText(true); | 
				
			|||
		} | 
				
			|||
		return style; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	@Override | 
				
			|||
	public CellStyle getHeaderStyle(short color) { | 
				
			|||
		CellStyle titleStyle = workbook.createCellStyle(); | 
				
			|||
		Font font = workbook.createFont(); | 
				
			|||
		font.setFontHeightInPoints((short) 12); | 
				
			|||
		titleStyle.setFont(font); | 
				
			|||
		titleStyle.setAlignment(HorizontalAlignment.CENTER); | 
				
			|||
		titleStyle.setVerticalAlignment(VerticalAlignment.CENTER); | 
				
			|||
		return titleStyle; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	@Override | 
				
			|||
	public CellStyle stringNoneStyle(Workbook workbook, boolean isWarp) { | 
				
			|||
		CellStyle style = workbook.createCellStyle(); | 
				
			|||
		style.setAlignment(HorizontalAlignment.CENTER); | 
				
			|||
		style.setVerticalAlignment(VerticalAlignment.CENTER); | 
				
			|||
		style.setDataFormat(STRING_FORMAT); | 
				
			|||
		if (isWarp) { | 
				
			|||
			style.setWrapText(true); | 
				
			|||
		} | 
				
			|||
		return style; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
} | 
				
			|||
@ -0,0 +1,54 @@ | 
				
			|||
/** | 
				
			|||
 * Copyright 2013-2015 JEECG (jeecgos@163.com) | 
				
			|||
 * | 
				
			|||
 *  Licensed under the Apache License, Version 2.0 (the "License"); | 
				
			|||
 *  you may not use this file except in compliance with the License. | 
				
			|||
 *  You may obtain a copy of the License at | 
				
			|||
 * | 
				
			|||
 *     http://www.apache.org/licenses/LICENSE-2.0
 | 
				
			|||
 * | 
				
			|||
 *  Unless required by applicable law or agreed to in writing, software | 
				
			|||
 * distributed under the License is distributed on an "AS IS" BASIS, | 
				
			|||
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | 
				
			|||
 * See the License for the specific language governing permissions and | 
				
			|||
 * limitations under the License. | 
				
			|||
 */ | 
				
			|||
package cc.admin.poi.excel.export.export.styler; | 
				
			|||
 | 
				
			|||
import cc.admin.poi.excel.entity.params.ExcelExportEntity; | 
				
			|||
import org.apache.poi.ss.usermodel.CellStyle; | 
				
			|||
 | 
				
			|||
/** | 
				
			|||
 * Excel导出样式接口 | 
				
			|||
 * | 
				
			|||
 * @author JEECG | 
				
			|||
 * @date 2015年1月9日 下午5:32:30 | 
				
			|||
 */ | 
				
			|||
public interface IExcelExportStyler { | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 列表头样式 | 
				
			|||
	 * | 
				
			|||
	 * @param headerColor | 
				
			|||
	 * @return | 
				
			|||
	 */ | 
				
			|||
	public CellStyle getHeaderStyle(short headerColor); | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 标题样式 | 
				
			|||
	 * | 
				
			|||
	 * @param color | 
				
			|||
	 * @return | 
				
			|||
	 */ | 
				
			|||
	public CellStyle getTitleStyle(short color); | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 获取样式方法 | 
				
			|||
	 * | 
				
			|||
	 * @param noneStyler | 
				
			|||
	 * @param entity | 
				
			|||
	 * @return | 
				
			|||
	 */ | 
				
			|||
	public CellStyle getStyles(boolean noneStyler, ExcelExportEntity entity); | 
				
			|||
 | 
				
			|||
} | 
				
			|||
@ -0,0 +1,454 @@ | 
				
			|||
/** | 
				
			|||
 * Copyright 2013-2015 JEECG (jeecgos@163.com) | 
				
			|||
 * | 
				
			|||
 *  Licensed under the Apache License, Version 2.0 (the "License"); | 
				
			|||
 *  you may not use this file except in compliance with the License. | 
				
			|||
 *  You may obtain a copy of the License at | 
				
			|||
 * | 
				
			|||
 *     http://www.apache.org/licenses/LICENSE-2.0
 | 
				
			|||
 * | 
				
			|||
 *  Unless required by applicable law or agreed to in writing, software | 
				
			|||
 * distributed under the License is distributed on an "AS IS" BASIS, | 
				
			|||
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | 
				
			|||
 * See the License for the specific language governing permissions and | 
				
			|||
 * limitations under the License. | 
				
			|||
 */ | 
				
			|||
package cc.admin.poi.excel.export.export.template; | 
				
			|||
 | 
				
			|||
import cc.admin.poi.cache.ExcelCache; | 
				
			|||
import cc.admin.poi.excel.annotation.ExcelTarget; | 
				
			|||
import cc.admin.poi.excel.entity.TemplateExportParams; | 
				
			|||
import cc.admin.poi.excel.entity.enmus.ExcelType; | 
				
			|||
import cc.admin.poi.excel.entity.params.ExcelExportEntity; | 
				
			|||
import cc.admin.poi.excel.entity.params.ExcelTemplateParams; | 
				
			|||
import cc.admin.poi.excel.export.base.ExcelExportBase; | 
				
			|||
import cc.admin.poi.excel.export.styler.IExcelExportStyler; | 
				
			|||
import cc.admin.poi.exception.excel.ExcelExportException; | 
				
			|||
import cc.admin.poi.exception.excel.enums.ExcelExportEnum; | 
				
			|||
import cc.admin.poi.util.PoiElUtil; | 
				
			|||
import cc.admin.poi.util.PoiPublicUtil; | 
				
			|||
import cc.admin.poi.util.PoiSheetUtility; | 
				
			|||
import org.apache.commons.lang3.StringUtils; | 
				
			|||
import org.apache.poi.ss.usermodel.*; | 
				
			|||
import org.apache.poi.xssf.usermodel.XSSFWorkbook; | 
				
			|||
import org.slf4j.Logger; | 
				
			|||
import org.slf4j.LoggerFactory; | 
				
			|||
 | 
				
			|||
import java.lang.reflect.Field; | 
				
			|||
import java.util.*; | 
				
			|||
 | 
				
			|||
/** | 
				
			|||
 * Excel 导出根据模板导出 | 
				
			|||
 * | 
				
			|||
 * @author JEECG | 
				
			|||
 * @date 2013-10-17 | 
				
			|||
 * @version 1.0 | 
				
			|||
 */ | 
				
			|||
public final class ExcelExportOfTemplateUtil extends ExcelExportBase { | 
				
			|||
 | 
				
			|||
	private static final Logger LOGGER = LoggerFactory.getLogger(ExcelExportOfTemplateUtil.class); | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 缓存TEMP 的for each创建的cell ,跳过这个cell的模板语法查找,提高效率 | 
				
			|||
	 */ | 
				
			|||
	private Set<String> tempCreateCellSet = new HashSet<String>(); | 
				
			|||
	/** | 
				
			|||
	 * 模板参数,全局都用到 | 
				
			|||
	 */ | 
				
			|||
	private TemplateExportParams teplateParams; | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 往Sheet 填充正常数据,根据表头信息 使用导入的部分逻辑,坐对象映射 | 
				
			|||
	 * | 
				
			|||
	 * @param pojoClass | 
				
			|||
	 * @param dataSet | 
				
			|||
	 * @param workbook | 
				
			|||
	 */ | 
				
			|||
	private void addDataToSheet(Class<?> pojoClass, Collection<?> dataSet, Sheet sheet, Workbook workbook) throws Exception { | 
				
			|||
 | 
				
			|||
		if (workbook instanceof XSSFWorkbook) { | 
				
			|||
			super.type = ExcelType.XSSF; | 
				
			|||
		} | 
				
			|||
		// 获取表头数据
 | 
				
			|||
		Map<String, Integer> titlemap = getTitleMap(sheet); | 
				
			|||
		Drawing patriarch = sheet.createDrawingPatriarch(); | 
				
			|||
		// 得到所有字段
 | 
				
			|||
		Field[] fileds = PoiPublicUtil.getClassFields(pojoClass); | 
				
			|||
		ExcelTarget etarget = pojoClass.getAnnotation(ExcelTarget.class); | 
				
			|||
		String targetId = null; | 
				
			|||
		if (etarget != null) { | 
				
			|||
			targetId = etarget.value(); | 
				
			|||
		} | 
				
			|||
		// 获取实体对象的导出数据
 | 
				
			|||
		List<ExcelExportEntity> excelParams = new ArrayList<ExcelExportEntity>(); | 
				
			|||
		getAllExcelField(null, targetId, fileds, excelParams, pojoClass, null); | 
				
			|||
		// 根据表头进行筛选排序
 | 
				
			|||
		sortAndFilterExportField(excelParams, titlemap); | 
				
			|||
		short rowHeight = getRowHeight(excelParams); | 
				
			|||
		int index = teplateParams.getHeadingRows() + teplateParams.getHeadingStartRow(), titleHeight = index; | 
				
			|||
		// 下移数据,模拟插入
 | 
				
			|||
		sheet.shiftRows(teplateParams.getHeadingRows() + teplateParams.getHeadingStartRow(), sheet.getLastRowNum(), getShiftRows(dataSet, excelParams), true, true); | 
				
			|||
		if (excelParams.size() == 0) { | 
				
			|||
			return; | 
				
			|||
		} | 
				
			|||
		Iterator<?> its = dataSet.iterator(); | 
				
			|||
		while (its.hasNext()) { | 
				
			|||
			Object t = its.next(); | 
				
			|||
			index += createCells(patriarch, index, t, excelParams, sheet, workbook, rowHeight); | 
				
			|||
		} | 
				
			|||
		// 合并同类项
 | 
				
			|||
		mergeCells(sheet, excelParams, titleHeight); | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 下移数据 | 
				
			|||
	 * | 
				
			|||
	 * @param excelParams | 
				
			|||
	 * @return | 
				
			|||
	 */ | 
				
			|||
	private int getShiftRows(Collection<?> dataSet, List<ExcelExportEntity> excelParams) throws Exception { | 
				
			|||
		int size = 0; | 
				
			|||
		Iterator<?> its = dataSet.iterator(); | 
				
			|||
		while (its.hasNext()) { | 
				
			|||
			Object t = its.next(); | 
				
			|||
			size += getOneObjectSize(t, excelParams); | 
				
			|||
		} | 
				
			|||
		return size; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 获取单个对象的高度,主要是处理一堆多的情况 | 
				
			|||
	 * @throws Exception | 
				
			|||
	 */ | 
				
			|||
	public int getOneObjectSize(Object t, List<ExcelExportEntity> excelParams) throws Exception { | 
				
			|||
		ExcelExportEntity entity; | 
				
			|||
		int maxHeight = 1; | 
				
			|||
		for (int k = 0, paramSize = excelParams.size(); k < paramSize; k++) { | 
				
			|||
			entity = excelParams.get(k); | 
				
			|||
			if (entity.getList() != null) { | 
				
			|||
				Collection<?> list = (Collection<?>) entity.getMethod().invoke(t, new Object[] {}); | 
				
			|||
				if (list != null && list.size() > maxHeight) { | 
				
			|||
					maxHeight = list.size(); | 
				
			|||
				} | 
				
			|||
			} | 
				
			|||
		} | 
				
			|||
		return maxHeight; | 
				
			|||
 | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public Workbook createExcleByTemplate(TemplateExportParams params, Class<?> pojoClass, Collection<?> dataSet, Map<String, Object> map) { | 
				
			|||
		// step 1. 判断模板的地址
 | 
				
			|||
		if (params == null || map == null || StringUtils.isEmpty(params.getTemplateUrl())) { | 
				
			|||
			throw new ExcelExportException(ExcelExportEnum.PARAMETER_ERROR); | 
				
			|||
		} | 
				
			|||
		Workbook wb = null; | 
				
			|||
		// step 2. 判断模板的Excel类型,解析模板
 | 
				
			|||
		try { | 
				
			|||
			this.teplateParams = params; | 
				
			|||
			wb = getCloneWorkBook(); | 
				
			|||
			// 创建表格样式
 | 
				
			|||
			setExcelExportStyler((IExcelExportStyler) teplateParams.getStyle().getConstructor(Workbook.class).newInstance(wb)); | 
				
			|||
			// step 3. 解析模板
 | 
				
			|||
			for (int i = 0, le = params.isScanAllsheet() ? wb.getNumberOfSheets() : params.getSheetNum().length; i < le; i++) { | 
				
			|||
				if (params.getSheetName() != null && params.getSheetName().length > i && StringUtils.isNotEmpty(params.getSheetName()[i])) { | 
				
			|||
					wb.setSheetName(i, params.getSheetName()[i]); | 
				
			|||
				} | 
				
			|||
				tempCreateCellSet.clear(); | 
				
			|||
				parseTemplate(wb.getSheetAt(i), map); | 
				
			|||
			} | 
				
			|||
			if (dataSet != null) { | 
				
			|||
				// step 4. 正常的数据填充
 | 
				
			|||
				dataHanlder = params.getDataHanlder(); | 
				
			|||
				if (dataHanlder != null) { | 
				
			|||
					needHanlderList = Arrays.asList(dataHanlder.getNeedHandlerFields()); | 
				
			|||
				} | 
				
			|||
				addDataToSheet(pojoClass, dataSet, wb.getSheetAt(params.getDataSheetNum()), wb); | 
				
			|||
			} | 
				
			|||
		} catch (Exception e) { | 
				
			|||
			LOGGER.error(e.getMessage(), e); | 
				
			|||
			return null; | 
				
			|||
		} | 
				
			|||
		return wb; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 克隆excel防止操作原对象,workbook无法克隆,只能对excel进行克隆 | 
				
			|||
	 * | 
				
			|||
	 * @throws Exception | 
				
			|||
	 * @Author JEECG | 
				
			|||
	 * @date 2013-11-11 | 
				
			|||
	 */ | 
				
			|||
	private Workbook getCloneWorkBook() throws Exception { | 
				
			|||
		return ExcelCache.getWorkbook(teplateParams.getTemplateUrl(), teplateParams.getSheetNum(), teplateParams.isScanAllsheet()); | 
				
			|||
 | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 获取表头数据,设置表头的序号 | 
				
			|||
	 * | 
				
			|||
	 * @param sheet | 
				
			|||
	 * @return | 
				
			|||
	 */ | 
				
			|||
	private Map<String, Integer> getTitleMap(Sheet sheet) { | 
				
			|||
		Row row = null; | 
				
			|||
		Iterator<Cell> cellTitle; | 
				
			|||
		Map<String, Integer> titlemap = new HashMap<String, Integer>(); | 
				
			|||
		for (int j = 0; j < teplateParams.getHeadingRows(); j++) { | 
				
			|||
			row = sheet.getRow(j + teplateParams.getHeadingStartRow()); | 
				
			|||
			cellTitle = row.cellIterator(); | 
				
			|||
			int i = row.getFirstCellNum(); | 
				
			|||
			while (cellTitle.hasNext()) { | 
				
			|||
				Cell cell = cellTitle.next(); | 
				
			|||
				String value = cell.getStringCellValue(); | 
				
			|||
				if (!StringUtils.isEmpty(value)) { | 
				
			|||
					titlemap.put(value, i); | 
				
			|||
				} | 
				
			|||
				i = i + 1; | 
				
			|||
			} | 
				
			|||
		} | 
				
			|||
		return titlemap; | 
				
			|||
 | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	private void parseTemplate(Sheet sheet, Map<String, Object> map) throws Exception { | 
				
			|||
		deleteCell(sheet, map); | 
				
			|||
		Row row = null; | 
				
			|||
		int index = 0; | 
				
			|||
		while (index <= sheet.getLastRowNum()) { | 
				
			|||
			row = sheet.getRow(index++); | 
				
			|||
			if (row == null) { | 
				
			|||
				continue; | 
				
			|||
			} | 
				
			|||
			for (int i = row.getFirstCellNum(); i < row.getLastCellNum(); i++) { | 
				
			|||
				if (row.getCell(i) != null && !tempCreateCellSet.contains(row.getRowNum() + "_" + row.getCell(i).getColumnIndex())) { | 
				
			|||
					setValueForCellByMap(row.getCell(i), map); | 
				
			|||
				} | 
				
			|||
			} | 
				
			|||
		} | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 先判断删除,省得影响效率 | 
				
			|||
	 * | 
				
			|||
	 * @param sheet | 
				
			|||
	 * @param map | 
				
			|||
	 * @throws Exception | 
				
			|||
	 */ | 
				
			|||
	private void deleteCell(Sheet sheet, Map<String, Object> map) throws Exception { | 
				
			|||
		Row row = null; | 
				
			|||
		Cell cell = null; | 
				
			|||
		int index = 0; | 
				
			|||
		while (index <= sheet.getLastRowNum()) { | 
				
			|||
			row = sheet.getRow(index++); | 
				
			|||
			if (row == null) { | 
				
			|||
				continue; | 
				
			|||
			} | 
				
			|||
			for (int i = row.getFirstCellNum(); i < row.getLastCellNum(); i++) { | 
				
			|||
				cell = row.getCell(i); | 
				
			|||
				if (row.getCell(i) != null && (cell.getCellType() == CellType.STRING || cell.getCellType() == CellType.NUMERIC)) { | 
				
			|||
					cell.setCellType(CellType.STRING); | 
				
			|||
					String text = cell.getStringCellValue(); | 
				
			|||
					if (text.contains(PoiElUtil.IF_DELETE)) { | 
				
			|||
						if (Boolean.valueOf(PoiElUtil.eval(text.substring(text.indexOf(PoiElUtil.START_STR) + 2, text.indexOf(PoiElUtil.END_STR)).trim(), map).toString())) { | 
				
			|||
							PoiSheetUtility.deleteColumn(sheet, i); | 
				
			|||
						} | 
				
			|||
						cell.setCellValue(""); | 
				
			|||
					} | 
				
			|||
				} | 
				
			|||
			} | 
				
			|||
		} | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 给每个Cell通过解析方式set值 | 
				
			|||
	 * | 
				
			|||
	 * @param cell | 
				
			|||
	 * @param map | 
				
			|||
	 */ | 
				
			|||
	private void setValueForCellByMap(Cell cell, Map<String, Object> map) throws Exception { | 
				
			|||
		CellType cellType = cell.getCellType(); | 
				
			|||
		if (cellType != CellType.STRING && cellType != CellType.NUMERIC) { | 
				
			|||
			return; | 
				
			|||
		} | 
				
			|||
		String oldString; | 
				
			|||
		cell.setCellType(CellType.STRING); | 
				
			|||
		oldString = cell.getStringCellValue(); | 
				
			|||
		if (oldString != null && oldString.indexOf(PoiElUtil.START_STR) != -1 && !oldString.contains(PoiElUtil.FOREACH)) { | 
				
			|||
			// step 2. 判断是否含有解析函数
 | 
				
			|||
			String params = null; | 
				
			|||
			boolean isNumber = false; | 
				
			|||
			if (isNumber(oldString)) { | 
				
			|||
				isNumber = true; | 
				
			|||
				oldString = oldString.replace(PoiElUtil.NUMBER_SYMBOL, ""); | 
				
			|||
			} | 
				
			|||
			while (oldString.indexOf(PoiElUtil.START_STR) != -1) { | 
				
			|||
				params = oldString.substring(oldString.indexOf(PoiElUtil.START_STR) + 2, oldString.indexOf(PoiElUtil.END_STR)); | 
				
			|||
 | 
				
			|||
				oldString = oldString.replace(PoiElUtil.START_STR + params + PoiElUtil.END_STR, PoiElUtil.eval(params, map).toString()); | 
				
			|||
			} | 
				
			|||
			// 如何是数值 类型,就按照数值类型进行设置
 | 
				
			|||
			if (isNumber && StringUtils.isNotBlank(oldString)) { | 
				
			|||
				cell.setCellValue(Double.parseDouble(oldString)); | 
				
			|||
				cell.setCellType(CellType.NUMERIC); | 
				
			|||
			} else { | 
				
			|||
				cell.setCellValue(oldString); | 
				
			|||
			} | 
				
			|||
		} | 
				
			|||
		// 判断foreach 这种方法
 | 
				
			|||
		if (oldString != null && oldString.contains(PoiElUtil.FOREACH)) { | 
				
			|||
			addListDataToExcel(cell, map, oldString.trim()); | 
				
			|||
		} | 
				
			|||
 | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	private boolean isNumber(String text) { | 
				
			|||
		return text.startsWith(PoiElUtil.NUMBER_SYMBOL) || text.contains("{" + PoiElUtil.NUMBER_SYMBOL) || text.contains(" " + PoiElUtil.NUMBER_SYMBOL); | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 利用foreach循环输出数据 | 
				
			|||
	 * | 
				
			|||
	 * @param cell | 
				
			|||
	 * @param map | 
				
			|||
	 * @throws Exception | 
				
			|||
	 */ | 
				
			|||
	private void addListDataToExcel(Cell cell, Map<String, Object> map, String name) throws Exception { | 
				
			|||
		boolean isCreate = !name.contains(PoiElUtil.FOREACH_NOT_CREATE); | 
				
			|||
		boolean isShift = name.contains(PoiElUtil.FOREACH_AND_SHIFT); | 
				
			|||
		name = name.replace(PoiElUtil.FOREACH_NOT_CREATE, PoiElUtil.EMPTY).replace(PoiElUtil.FOREACH_AND_SHIFT, PoiElUtil.EMPTY).replace(PoiElUtil.FOREACH, PoiElUtil.EMPTY).replace(PoiElUtil.START_STR, PoiElUtil.EMPTY); | 
				
			|||
		String[] keys = name.replaceAll("\\s{1,}", " ").trim().split(" "); | 
				
			|||
		Collection<?> datas = (Collection<?>) PoiPublicUtil.getParamsValue(keys[0], map); | 
				
			|||
		List<ExcelTemplateParams> columns = getAllDataColumns(cell, name.replace(keys[0], PoiElUtil.EMPTY)); | 
				
			|||
		if (datas == null) { | 
				
			|||
			return; | 
				
			|||
		} | 
				
			|||
		Iterator<?> its = datas.iterator(); | 
				
			|||
		Row row; | 
				
			|||
		int rowIndex = cell.getRow().getRowNum() + 1; | 
				
			|||
		// 处理当前行
 | 
				
			|||
		if (its.hasNext()) { | 
				
			|||
			Object t = its.next(); | 
				
			|||
			cell.getRow().setHeight(columns.get(0).getHeight()); | 
				
			|||
			setForEeachCellValue(isCreate, cell.getRow(), cell.getColumnIndex(), t, columns, map); | 
				
			|||
		} | 
				
			|||
		if (isShift) { | 
				
			|||
			cell.getRow().getSheet().shiftRows(cell.getRowIndex() + 1, cell.getRow().getSheet().getLastRowNum(), datas.size() - 1, true, true); | 
				
			|||
		} | 
				
			|||
		while (its.hasNext()) { | 
				
			|||
			Object t = its.next(); | 
				
			|||
			if (isCreate) { | 
				
			|||
				row = cell.getRow().getSheet().createRow(rowIndex++); | 
				
			|||
			} else { | 
				
			|||
				row = cell.getRow().getSheet().getRow(rowIndex++); | 
				
			|||
				if (row == null) { | 
				
			|||
					row = cell.getRow().getSheet().createRow(rowIndex - 1); | 
				
			|||
				} | 
				
			|||
			} | 
				
			|||
			row.setHeight(columns.get(0).getHeight()); | 
				
			|||
			setForEeachCellValue(isCreate, row, cell.getColumnIndex(), t, columns, map); | 
				
			|||
		} | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	private void setForEeachCellValue(boolean isCreate, Row row, int columnIndex, Object t, List<ExcelTemplateParams> columns, Map<String, Object> map) throws Exception { | 
				
			|||
		for (int i = 0, max = columnIndex + columns.size(); i < max; i++) { | 
				
			|||
			if (row.getCell(i) == null) | 
				
			|||
				row.createCell(i); | 
				
			|||
		} | 
				
			|||
		for (int i = 0, max = columns.size(); i < max; i++) { | 
				
			|||
			boolean isNumber = false; | 
				
			|||
			String tempStr = new String(columns.get(i).getName()); | 
				
			|||
			if (isNumber(tempStr)) { | 
				
			|||
				isNumber = true; | 
				
			|||
				tempStr = tempStr.replace(PoiElUtil.NUMBER_SYMBOL, ""); | 
				
			|||
			} | 
				
			|||
			map.put(teplateParams.getTempParams(), t); | 
				
			|||
			String val = PoiElUtil.eval(tempStr, map).toString(); | 
				
			|||
			if (isNumber && StringUtils.isNotEmpty(val)) { | 
				
			|||
				row.getCell(i + columnIndex).setCellValue(Double.parseDouble(val)); | 
				
			|||
				row.getCell(i + columnIndex).setCellType(CellType.NUMERIC); | 
				
			|||
			} else { | 
				
			|||
				row.getCell(i + columnIndex).setCellValue(val); | 
				
			|||
			} | 
				
			|||
			row.getCell(i + columnIndex).setCellStyle(columns.get(i).getCellStyle()); | 
				
			|||
			tempCreateCellSet.add(row.getRowNum() + "_" + (i + columnIndex)); | 
				
			|||
		} | 
				
			|||
 | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 获取迭代的数据的值 | 
				
			|||
	 * | 
				
			|||
	 * @param cell | 
				
			|||
	 * @param name | 
				
			|||
	 * @return | 
				
			|||
	 */ | 
				
			|||
	private List<ExcelTemplateParams> getAllDataColumns(Cell cell, String name) { | 
				
			|||
		List<ExcelTemplateParams> columns = new ArrayList<ExcelTemplateParams>(); | 
				
			|||
		cell.setCellValue(""); | 
				
			|||
		if (name.contains(PoiElUtil.END_STR)) { | 
				
			|||
			columns.add(new ExcelTemplateParams(name.replace(PoiElUtil.END_STR, PoiElUtil.EMPTY).trim(), cell.getCellStyle(), cell.getRow().getHeight())); | 
				
			|||
			return columns; | 
				
			|||
		} | 
				
			|||
		columns.add(new ExcelTemplateParams(name.trim(), cell.getCellStyle(), cell.getRow().getHeight())); | 
				
			|||
		int index = cell.getColumnIndex(); | 
				
			|||
		Cell tempCell; | 
				
			|||
		while (true) { | 
				
			|||
			tempCell = cell.getRow().getCell(++index); | 
				
			|||
			if (tempCell == null) { | 
				
			|||
				break; | 
				
			|||
			} | 
				
			|||
			String cellStringString; | 
				
			|||
			try {// 允许为空,单表示已经完结了,因为可能被删除了
 | 
				
			|||
				cellStringString = tempCell.getStringCellValue(); | 
				
			|||
				if (StringUtils.isBlank(cellStringString)) { | 
				
			|||
					break; | 
				
			|||
				} | 
				
			|||
			} catch (Exception e) { | 
				
			|||
				throw new ExcelExportException("for each 当中存在空字符串,请检查模板"); | 
				
			|||
			} | 
				
			|||
			// 把读取过的cell 置为空
 | 
				
			|||
			tempCell.setCellValue(""); | 
				
			|||
			if (cellStringString.contains(PoiElUtil.END_STR)) { | 
				
			|||
				columns.add(new ExcelTemplateParams(cellStringString.trim().replace(PoiElUtil.END_STR, ""), tempCell.getCellStyle(), tempCell.getRow().getHeight())); | 
				
			|||
				break; | 
				
			|||
			} else { | 
				
			|||
				if (cellStringString.trim().contains(teplateParams.getTempParams())) { | 
				
			|||
					columns.add(new ExcelTemplateParams(cellStringString.trim(), tempCell.getCellStyle(), tempCell.getRow().getHeight())); | 
				
			|||
				} else { | 
				
			|||
					// 最后一行被删除了
 | 
				
			|||
					break; | 
				
			|||
				} | 
				
			|||
			} | 
				
			|||
 | 
				
			|||
		} | 
				
			|||
		return columns; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 对导出序列进行排序和塞选 | 
				
			|||
	 * | 
				
			|||
	 * @param excelParams | 
				
			|||
	 * @param titlemap | 
				
			|||
	 * @return | 
				
			|||
	 */ | 
				
			|||
	private void sortAndFilterExportField(List<ExcelExportEntity> excelParams, Map<String, Integer> titlemap) { | 
				
			|||
		for (int i = excelParams.size() - 1; i >= 0; i--) { | 
				
			|||
			if (excelParams.get(i).getList() != null && excelParams.get(i).getList().size() > 0) { | 
				
			|||
				sortAndFilterExportField(excelParams.get(i).getList(), titlemap); | 
				
			|||
				if (excelParams.get(i).getList().size() == 0) { | 
				
			|||
					excelParams.remove(i); | 
				
			|||
				} else { | 
				
			|||
					excelParams.get(i).setOrderNum(i); | 
				
			|||
				} | 
				
			|||
			} else { | 
				
			|||
				if (titlemap.containsKey(excelParams.get(i).getName())) { | 
				
			|||
					excelParams.get(i).setOrderNum(i); | 
				
			|||
				} else { | 
				
			|||
					excelParams.remove(i); | 
				
			|||
				} | 
				
			|||
			} | 
				
			|||
		} | 
				
			|||
		sortAllParams(excelParams); | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
} | 
				
			|||
@ -0,0 +1,71 @@ | 
				
			|||
/** | 
				
			|||
 * Copyright 2013-2015 JEECG (jeecgos@163.com) | 
				
			|||
 * | 
				
			|||
 *  Licensed under the Apache License, Version 2.0 (the "License"); | 
				
			|||
 *  you may not use this file except in compliance with the License. | 
				
			|||
 *  You may obtain a copy of the License at | 
				
			|||
 * | 
				
			|||
 *     http://www.apache.org/licenses/LICENSE-2.0
 | 
				
			|||
 * | 
				
			|||
 *  Unless required by applicable law or agreed to in writing, software | 
				
			|||
 * distributed under the License is distributed on an "AS IS" BASIS, | 
				
			|||
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | 
				
			|||
 * See the License for the specific language governing permissions and | 
				
			|||
 * limitations under the License. | 
				
			|||
 */ | 
				
			|||
package cc.admin.poi.excel.export.styler; | 
				
			|||
 | 
				
			|||
import org.apache.poi.ss.usermodel.BuiltinFormats; | 
				
			|||
import org.apache.poi.ss.usermodel.CellStyle; | 
				
			|||
import org.apache.poi.ss.usermodel.Workbook; | 
				
			|||
import cc.admin.poi.excel.entity.params.ExcelExportEntity; | 
				
			|||
 | 
				
			|||
/** | 
				
			|||
 * 抽象接口提供两个公共方法 | 
				
			|||
 * | 
				
			|||
 * @author JEECG | 
				
			|||
 * @date 2015年1月9日 下午5:48:55 | 
				
			|||
 */ | 
				
			|||
public abstract class AbstractExcelExportStyler implements IExcelExportStyler { | 
				
			|||
	// 单行
 | 
				
			|||
	protected CellStyle stringNoneStyle; | 
				
			|||
	protected CellStyle stringNoneWrapStyle; | 
				
			|||
	// 间隔行
 | 
				
			|||
	protected CellStyle stringSeptailStyle; | 
				
			|||
	protected CellStyle stringSeptailWrapStyle; | 
				
			|||
 | 
				
			|||
	protected Workbook workbook; | 
				
			|||
 | 
				
			|||
	protected static final short STRING_FORMAT = (short) BuiltinFormats.getBuiltinFormat("TEXT"); | 
				
			|||
 | 
				
			|||
	protected void createStyles(Workbook workbook) { | 
				
			|||
		this.stringNoneStyle = stringNoneStyle(workbook, false); | 
				
			|||
		this.stringNoneWrapStyle = stringNoneStyle(workbook, true); | 
				
			|||
		this.stringSeptailStyle = stringSeptailStyle(workbook, false); | 
				
			|||
		this.stringSeptailWrapStyle = stringSeptailStyle(workbook, true); | 
				
			|||
		this.workbook = workbook; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	@Override | 
				
			|||
	public CellStyle getStyles(boolean noneStyler, ExcelExportEntity entity) { | 
				
			|||
		if (noneStyler && (entity == null || entity.isWrap())) { | 
				
			|||
			return stringNoneWrapStyle; | 
				
			|||
		} | 
				
			|||
		if (noneStyler) { | 
				
			|||
			return stringNoneStyle; | 
				
			|||
		} | 
				
			|||
		if (noneStyler == false && (entity == null || entity.isWrap())) { | 
				
			|||
			return stringSeptailWrapStyle; | 
				
			|||
		} | 
				
			|||
		return stringSeptailStyle; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public CellStyle stringNoneStyle(Workbook workbook, boolean isWarp) { | 
				
			|||
		return null; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public CellStyle stringSeptailStyle(Workbook workbook, boolean isWarp) { | 
				
			|||
		return null; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
} | 
				
			|||
@ -0,0 +1,86 @@ | 
				
			|||
/** | 
				
			|||
 * Copyright 2013-2015 JEECG (jeecgos@163.com) | 
				
			|||
 * | 
				
			|||
 *  Licensed under the Apache License, Version 2.0 (the "License"); | 
				
			|||
 *  you may not use this file except in compliance with the License. | 
				
			|||
 *  You may obtain a copy of the License at | 
				
			|||
 * | 
				
			|||
 *     http://www.apache.org/licenses/LICENSE-2.0
 | 
				
			|||
 * | 
				
			|||
 *  Unless required by applicable law or agreed to in writing, software | 
				
			|||
 * distributed under the License is distributed on an "AS IS" BASIS, | 
				
			|||
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | 
				
			|||
 * See the License for the specific language governing permissions and | 
				
			|||
 * limitations under the License. | 
				
			|||
 */ | 
				
			|||
package cc.admin.poi.excel.export.styler; | 
				
			|||
 | 
				
			|||
import org.apache.poi.ss.usermodel.*; | 
				
			|||
 | 
				
			|||
/** | 
				
			|||
 * 带有边框的Excel样式 | 
				
			|||
 * | 
				
			|||
 * @author JEECG | 
				
			|||
 * @date 2015年1月9日 下午5:55:29 | 
				
			|||
 */ | 
				
			|||
public class ExcelExportStylerBorderImpl extends AbstractExcelExportStyler implements IExcelExportStyler { | 
				
			|||
 | 
				
			|||
	public ExcelExportStylerBorderImpl(Workbook workbook) { | 
				
			|||
		super.createStyles(workbook); | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	@Override | 
				
			|||
	public CellStyle getHeaderStyle(short color) { | 
				
			|||
		CellStyle titleStyle = workbook.createCellStyle(); | 
				
			|||
		Font font = workbook.createFont(); | 
				
			|||
		font.setFontHeightInPoints((short) 12); | 
				
			|||
		titleStyle.setFont(font); | 
				
			|||
		titleStyle.setBorderLeft(BorderStyle.THIN); // 左边框
 | 
				
			|||
		titleStyle.setBorderRight(BorderStyle.THIN); // 右边框
 | 
				
			|||
		titleStyle.setBorderBottom( BorderStyle.THIN); | 
				
			|||
		titleStyle.setBorderTop(BorderStyle.THIN); | 
				
			|||
 | 
				
			|||
		// 设置对齐方式
 | 
				
			|||
		titleStyle.setAlignment(HorizontalAlignment.CENTER); | 
				
			|||
		titleStyle.setVerticalAlignment(VerticalAlignment.CENTER); | 
				
			|||
 | 
				
			|||
		return titleStyle; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	@Override | 
				
			|||
	public CellStyle stringNoneStyle(Workbook workbook, boolean isWarp) { | 
				
			|||
		CellStyle style = workbook.createCellStyle(); | 
				
			|||
		style.setBorderLeft(BorderStyle.THIN); // 左边框
 | 
				
			|||
		style.setBorderRight(BorderStyle.THIN); // 右边框
 | 
				
			|||
		style.setBorderBottom(BorderStyle.THIN); | 
				
			|||
		style.setBorderTop(BorderStyle.THIN); | 
				
			|||
		// 设置对齐方式
 | 
				
			|||
		style.setAlignment(HorizontalAlignment.CENTER); | 
				
			|||
		style.setVerticalAlignment(VerticalAlignment.CENTER); | 
				
			|||
		style.setDataFormat(STRING_FORMAT); | 
				
			|||
		if (isWarp) { | 
				
			|||
			style.setWrapText(true); | 
				
			|||
		} | 
				
			|||
		return style; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	@Override | 
				
			|||
	public CellStyle getTitleStyle(short color) { | 
				
			|||
		CellStyle titleStyle = workbook.createCellStyle(); | 
				
			|||
		titleStyle.setBorderLeft(BorderStyle.THIN); // 左边框
 | 
				
			|||
		titleStyle.setBorderRight(BorderStyle.THIN); // 右边框
 | 
				
			|||
		titleStyle.setBorderBottom(BorderStyle.THIN); | 
				
			|||
		titleStyle.setBorderTop(BorderStyle.THIN); | 
				
			|||
		// 设置对齐方式
 | 
				
			|||
		titleStyle.setAlignment(HorizontalAlignment.CENTER); | 
				
			|||
		titleStyle.setVerticalAlignment(VerticalAlignment.CENTER); | 
				
			|||
		titleStyle.setWrapText(true); | 
				
			|||
		return titleStyle; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	@Override | 
				
			|||
	public CellStyle stringSeptailStyle(Workbook workbook, boolean isWarp) { | 
				
			|||
		return isWarp ? stringNoneWrapStyle : stringNoneStyle; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
} | 
				
			|||
@ -0,0 +1,89 @@ | 
				
			|||
/** | 
				
			|||
 * Copyright 2013-2015 JEECG (jeecgos@163.com) | 
				
			|||
 * | 
				
			|||
 *  Licensed under the Apache License, Version 2.0 (the "License"); | 
				
			|||
 *  you may not use this file except in compliance with the License. | 
				
			|||
 *  You may obtain a copy of the License at | 
				
			|||
 * | 
				
			|||
 *     http://www.apache.org/licenses/LICENSE-2.0
 | 
				
			|||
 * | 
				
			|||
 *  Unless required by applicable law or agreed to in writing, software | 
				
			|||
 * distributed under the License is distributed on an "AS IS" BASIS, | 
				
			|||
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | 
				
			|||
 * See the License for the specific language governing permissions and | 
				
			|||
 * limitations under the License. | 
				
			|||
 */ | 
				
			|||
package cc.admin.poi.excel.export.styler; | 
				
			|||
 | 
				
			|||
import org.apache.poi.ss.usermodel.*; | 
				
			|||
 | 
				
			|||
/** | 
				
			|||
 * 带有样式的导出服务 | 
				
			|||
 * | 
				
			|||
 * @author JEECG | 
				
			|||
 * @date 2015年1月9日 下午4:54:15 | 
				
			|||
 */ | 
				
			|||
public class ExcelExportStylerColorImpl extends AbstractExcelExportStyler implements IExcelExportStyler { | 
				
			|||
 | 
				
			|||
	public ExcelExportStylerColorImpl(Workbook workbook) { | 
				
			|||
		super.createStyles(workbook); | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	@Override | 
				
			|||
	public CellStyle getHeaderStyle(short headerColor) { | 
				
			|||
		CellStyle titleStyle = workbook.createCellStyle(); | 
				
			|||
		Font font = workbook.createFont(); | 
				
			|||
		font.setFontHeightInPoints((short) 24); | 
				
			|||
		titleStyle.setFont(font); | 
				
			|||
		titleStyle.setFillForegroundColor(headerColor); | 
				
			|||
		titleStyle.setAlignment(HorizontalAlignment.CENTER); | 
				
			|||
		titleStyle.setVerticalAlignment(VerticalAlignment.CENTER); | 
				
			|||
		return titleStyle; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	@Override | 
				
			|||
	public CellStyle stringNoneStyle(Workbook workbook, boolean isWarp) { | 
				
			|||
		CellStyle style = workbook.createCellStyle(); | 
				
			|||
		style.setBorderLeft(BorderStyle.THIN); // 左边框
 | 
				
			|||
		style.setBorderRight(BorderStyle.THIN); // 右边框
 | 
				
			|||
		style.setBorderBottom(BorderStyle.THIN); | 
				
			|||
		style.setBorderTop(BorderStyle.THIN); | 
				
			|||
		style.setAlignment(HorizontalAlignment.CENTER); | 
				
			|||
		style.setVerticalAlignment(VerticalAlignment.CENTER); | 
				
			|||
		style.setDataFormat(STRING_FORMAT); | 
				
			|||
		if (isWarp) { | 
				
			|||
			style.setWrapText(true); | 
				
			|||
		} | 
				
			|||
		return style; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	@Override | 
				
			|||
	public CellStyle getTitleStyle(short color) { | 
				
			|||
		CellStyle titleStyle = workbook.createCellStyle(); | 
				
			|||
		titleStyle.setFillForegroundColor(color); // 填充的背景颜色
 | 
				
			|||
		titleStyle.setAlignment(HorizontalAlignment.CENTER); | 
				
			|||
		titleStyle.setVerticalAlignment(VerticalAlignment.CENTER); | 
				
			|||
		titleStyle.setFillPattern(FillPatternType.SOLID_FOREGROUND); | 
				
			|||
		titleStyle.setWrapText(true); | 
				
			|||
		return titleStyle; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	@Override | 
				
			|||
	public CellStyle stringSeptailStyle(Workbook workbook, boolean isWarp) { | 
				
			|||
		CellStyle style = workbook.createCellStyle(); | 
				
			|||
		style.setBorderLeft(BorderStyle.THIN); // 左边框
 | 
				
			|||
		style.setBorderRight(BorderStyle.THIN); // 右边框
 | 
				
			|||
		style.setBorderBottom(BorderStyle.THIN); | 
				
			|||
		style.setBorderTop(BorderStyle.THIN); | 
				
			|||
		style.setFillForegroundColor((short) 41); // 填充的背景颜色
 | 
				
			|||
		style.setFillPattern(FillPatternType.SOLID_FOREGROUND); | 
				
			|||
		style.setAlignment(HorizontalAlignment.CENTER); | 
				
			|||
		style.setVerticalAlignment(VerticalAlignment.CENTER); | 
				
			|||
		style.setDataFormat(STRING_FORMAT); | 
				
			|||
		if (isWarp) { | 
				
			|||
			style.setWrapText(true); | 
				
			|||
		} | 
				
			|||
		return style; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
} | 
				
			|||
@ -0,0 +1,76 @@ | 
				
			|||
/** | 
				
			|||
 * Copyright 2013-2015 JEECG (jeecgos@163.com) | 
				
			|||
 * | 
				
			|||
 *  Licensed under the Apache License, Version 2.0 (the "License"); | 
				
			|||
 *  you may not use this file except in compliance with the License. | 
				
			|||
 *  You may obtain a copy of the License at | 
				
			|||
 * | 
				
			|||
 *     http://www.apache.org/licenses/LICENSE-2.0
 | 
				
			|||
 * | 
				
			|||
 *  Unless required by applicable law or agreed to in writing, software | 
				
			|||
 * distributed under the License is distributed on an "AS IS" BASIS, | 
				
			|||
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | 
				
			|||
 * See the License for the specific language governing permissions and | 
				
			|||
 * limitations under the License. | 
				
			|||
 */ | 
				
			|||
package cc.admin.poi.excel.export.styler; | 
				
			|||
 | 
				
			|||
import org.apache.poi.ss.usermodel.*; | 
				
			|||
 | 
				
			|||
/** | 
				
			|||
 * 样式的默认实现 | 
				
			|||
 * | 
				
			|||
 * @author JEECG | 
				
			|||
 * @date 2015年1月9日 下午5:36:08 | 
				
			|||
 */ | 
				
			|||
public class ExcelExportStylerDefaultImpl extends AbstractExcelExportStyler implements IExcelExportStyler { | 
				
			|||
 | 
				
			|||
	public ExcelExportStylerDefaultImpl(Workbook workbook) { | 
				
			|||
		super.createStyles(workbook); | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	@Override | 
				
			|||
	public CellStyle getTitleStyle(short color) { | 
				
			|||
		CellStyle titleStyle = workbook.createCellStyle(); | 
				
			|||
		titleStyle.setAlignment(HorizontalAlignment.CENTER); | 
				
			|||
		titleStyle.setVerticalAlignment(VerticalAlignment.CENTER); | 
				
			|||
		titleStyle.setWrapText(true); | 
				
			|||
		return titleStyle; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	@Override | 
				
			|||
	public CellStyle stringSeptailStyle(Workbook workbook, boolean isWarp) { | 
				
			|||
		CellStyle style = workbook.createCellStyle(); | 
				
			|||
		style.setAlignment(HorizontalAlignment.CENTER); | 
				
			|||
		style.setVerticalAlignment(VerticalAlignment.CENTER); | 
				
			|||
		style.setDataFormat(STRING_FORMAT); | 
				
			|||
		if (isWarp) { | 
				
			|||
			style.setWrapText(true); | 
				
			|||
		} | 
				
			|||
		return style; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	@Override | 
				
			|||
	public CellStyle getHeaderStyle(short color) { | 
				
			|||
		CellStyle titleStyle = workbook.createCellStyle(); | 
				
			|||
		Font font = workbook.createFont(); | 
				
			|||
		font.setFontHeightInPoints((short) 12); | 
				
			|||
		titleStyle.setFont(font); | 
				
			|||
		titleStyle.setAlignment(HorizontalAlignment.CENTER); | 
				
			|||
		titleStyle.setVerticalAlignment(VerticalAlignment.CENTER); | 
				
			|||
		return titleStyle; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	@Override | 
				
			|||
	public CellStyle stringNoneStyle(Workbook workbook, boolean isWarp) { | 
				
			|||
		CellStyle style = workbook.createCellStyle(); | 
				
			|||
		style.setAlignment(HorizontalAlignment.CENTER); | 
				
			|||
		style.setVerticalAlignment(VerticalAlignment.CENTER); | 
				
			|||
		style.setDataFormat(STRING_FORMAT); | 
				
			|||
		if (isWarp) { | 
				
			|||
			style.setWrapText(true); | 
				
			|||
		} | 
				
			|||
		return style; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
} | 
				
			|||
@ -0,0 +1,54 @@ | 
				
			|||
/** | 
				
			|||
 * Copyright 2013-2015 JEECG (jeecgos@163.com) | 
				
			|||
 * | 
				
			|||
 *  Licensed under the Apache License, Version 2.0 (the "License"); | 
				
			|||
 *  you may not use this file except in compliance with the License. | 
				
			|||
 *  You may obtain a copy of the License at | 
				
			|||
 * | 
				
			|||
 *     http://www.apache.org/licenses/LICENSE-2.0
 | 
				
			|||
 * | 
				
			|||
 *  Unless required by applicable law or agreed to in writing, software | 
				
			|||
 * distributed under the License is distributed on an "AS IS" BASIS, | 
				
			|||
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | 
				
			|||
 * See the License for the specific language governing permissions and | 
				
			|||
 * limitations under the License. | 
				
			|||
 */ | 
				
			|||
package cc.admin.poi.excel.export.styler; | 
				
			|||
 | 
				
			|||
import org.apache.poi.ss.usermodel.CellStyle; | 
				
			|||
import cc.admin.poi.excel.entity.params.ExcelExportEntity; | 
				
			|||
 | 
				
			|||
/** | 
				
			|||
 * Excel导出样式接口 | 
				
			|||
 * | 
				
			|||
 * @author JEECG | 
				
			|||
 * @date 2015年1月9日 下午5:32:30 | 
				
			|||
 */ | 
				
			|||
public interface IExcelExportStyler { | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 列表头样式 | 
				
			|||
	 * | 
				
			|||
	 * @param headerColor | 
				
			|||
	 * @return | 
				
			|||
	 */ | 
				
			|||
	public CellStyle getHeaderStyle(short headerColor); | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 标题样式 | 
				
			|||
	 * | 
				
			|||
	 * @param color | 
				
			|||
	 * @return | 
				
			|||
	 */ | 
				
			|||
	public CellStyle getTitleStyle(short color); | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 获取样式方法 | 
				
			|||
	 * | 
				
			|||
	 * @param noneStyler | 
				
			|||
	 * @param entity | 
				
			|||
	 * @return | 
				
			|||
	 */ | 
				
			|||
	public CellStyle getStyles(boolean noneStyler, ExcelExportEntity entity); | 
				
			|||
 | 
				
			|||
} | 
				
			|||
@ -0,0 +1,454 @@ | 
				
			|||
/** | 
				
			|||
 * Copyright 2013-2015 JEECG (jeecgos@163.com) | 
				
			|||
 * | 
				
			|||
 *  Licensed under the Apache License, Version 2.0 (the "License"); | 
				
			|||
 *  you may not use this file except in compliance with the License. | 
				
			|||
 *  You may obtain a copy of the License at | 
				
			|||
 * | 
				
			|||
 *     http://www.apache.org/licenses/LICENSE-2.0
 | 
				
			|||
 * | 
				
			|||
 *  Unless required by applicable law or agreed to in writing, software | 
				
			|||
 * distributed under the License is distributed on an "AS IS" BASIS, | 
				
			|||
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | 
				
			|||
 * See the License for the specific language governing permissions and | 
				
			|||
 * limitations under the License. | 
				
			|||
 */ | 
				
			|||
package cc.admin.poi.excel.export.template; | 
				
			|||
 | 
				
			|||
import cc.admin.poi.cache.ExcelCache; | 
				
			|||
import cc.admin.poi.excel.annotation.ExcelTarget; | 
				
			|||
import cc.admin.poi.excel.entity.TemplateExportParams; | 
				
			|||
import cc.admin.poi.excel.entity.enmus.ExcelType; | 
				
			|||
import cc.admin.poi.excel.entity.params.ExcelExportEntity; | 
				
			|||
import cc.admin.poi.excel.entity.params.ExcelTemplateParams; | 
				
			|||
import cc.admin.poi.excel.export.base.ExcelExportBase; | 
				
			|||
import cc.admin.poi.excel.export.styler.IExcelExportStyler; | 
				
			|||
import cc.admin.poi.exception.excel.ExcelExportException; | 
				
			|||
import cc.admin.poi.exception.excel.enums.ExcelExportEnum; | 
				
			|||
import cc.admin.poi.util.PoiElUtil; | 
				
			|||
import cc.admin.poi.util.PoiPublicUtil; | 
				
			|||
import cc.admin.poi.util.PoiSheetUtility; | 
				
			|||
import org.apache.commons.lang3.StringUtils; | 
				
			|||
import org.apache.poi.ss.usermodel.*; | 
				
			|||
import org.apache.poi.xssf.usermodel.XSSFWorkbook; | 
				
			|||
import org.slf4j.Logger; | 
				
			|||
import org.slf4j.LoggerFactory; | 
				
			|||
 | 
				
			|||
import java.lang.reflect.Field; | 
				
			|||
import java.util.*; | 
				
			|||
 | 
				
			|||
/** | 
				
			|||
 * Excel 导出根据模板导出 | 
				
			|||
 * | 
				
			|||
 * @author JEECG | 
				
			|||
 * @date 2013-10-17 | 
				
			|||
 * @version 1.0 | 
				
			|||
 */ | 
				
			|||
public final class ExcelExportOfTemplateUtil extends ExcelExportBase { | 
				
			|||
 | 
				
			|||
	private static final Logger LOGGER = LoggerFactory.getLogger(ExcelExportOfTemplateUtil.class); | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 缓存TEMP 的for each创建的cell ,跳过这个cell的模板语法查找,提高效率 | 
				
			|||
	 */ | 
				
			|||
	private Set<String> tempCreateCellSet = new HashSet<String>(); | 
				
			|||
	/** | 
				
			|||
	 * 模板参数,全局都用到 | 
				
			|||
	 */ | 
				
			|||
	private TemplateExportParams teplateParams; | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 往Sheet 填充正常数据,根据表头信息 使用导入的部分逻辑,坐对象映射 | 
				
			|||
	 * | 
				
			|||
	 * @param pojoClass | 
				
			|||
	 * @param dataSet | 
				
			|||
	 * @param workbook | 
				
			|||
	 */ | 
				
			|||
	private void addDataToSheet(Class<?> pojoClass, Collection<?> dataSet, Sheet sheet, Workbook workbook) throws Exception { | 
				
			|||
 | 
				
			|||
		if (workbook instanceof XSSFWorkbook) { | 
				
			|||
			super.type = ExcelType.XSSF; | 
				
			|||
		} | 
				
			|||
		// 获取表头数据
 | 
				
			|||
		Map<String, Integer> titlemap = getTitleMap(sheet); | 
				
			|||
		Drawing patriarch = sheet.createDrawingPatriarch(); | 
				
			|||
		// 得到所有字段
 | 
				
			|||
		Field[] fileds = PoiPublicUtil.getClassFields(pojoClass); | 
				
			|||
		ExcelTarget etarget = pojoClass.getAnnotation(ExcelTarget.class); | 
				
			|||
		String targetId = null; | 
				
			|||
		if (etarget != null) { | 
				
			|||
			targetId = etarget.value(); | 
				
			|||
		} | 
				
			|||
		// 获取实体对象的导出数据
 | 
				
			|||
		List<ExcelExportEntity> excelParams = new ArrayList<ExcelExportEntity>(); | 
				
			|||
		getAllExcelField(null, targetId, fileds, excelParams, pojoClass, null); | 
				
			|||
		// 根据表头进行筛选排序
 | 
				
			|||
		sortAndFilterExportField(excelParams, titlemap); | 
				
			|||
		short rowHeight = getRowHeight(excelParams); | 
				
			|||
		int index = teplateParams.getHeadingRows() + teplateParams.getHeadingStartRow(), titleHeight = index; | 
				
			|||
		// 下移数据,模拟插入
 | 
				
			|||
		sheet.shiftRows(teplateParams.getHeadingRows() + teplateParams.getHeadingStartRow(), sheet.getLastRowNum(), getShiftRows(dataSet, excelParams), true, true); | 
				
			|||
		if (excelParams.size() == 0) { | 
				
			|||
			return; | 
				
			|||
		} | 
				
			|||
		Iterator<?> its = dataSet.iterator(); | 
				
			|||
		while (its.hasNext()) { | 
				
			|||
			Object t = its.next(); | 
				
			|||
			index += createCells(patriarch, index, t, excelParams, sheet, workbook, rowHeight); | 
				
			|||
		} | 
				
			|||
		// 合并同类项
 | 
				
			|||
		mergeCells(sheet, excelParams, titleHeight); | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 下移数据 | 
				
			|||
	 * | 
				
			|||
	 * @param excelParams | 
				
			|||
	 * @return | 
				
			|||
	 */ | 
				
			|||
	private int getShiftRows(Collection<?> dataSet, List<ExcelExportEntity> excelParams) throws Exception { | 
				
			|||
		int size = 0; | 
				
			|||
		Iterator<?> its = dataSet.iterator(); | 
				
			|||
		while (its.hasNext()) { | 
				
			|||
			Object t = its.next(); | 
				
			|||
			size += getOneObjectSize(t, excelParams); | 
				
			|||
		} | 
				
			|||
		return size; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 获取单个对象的高度,主要是处理一堆多的情况 | 
				
			|||
	 * @throws Exception | 
				
			|||
	 */ | 
				
			|||
	public int getOneObjectSize(Object t, List<ExcelExportEntity> excelParams) throws Exception { | 
				
			|||
		ExcelExportEntity entity; | 
				
			|||
		int maxHeight = 1; | 
				
			|||
		for (int k = 0, paramSize = excelParams.size(); k < paramSize; k++) { | 
				
			|||
			entity = excelParams.get(k); | 
				
			|||
			if (entity.getList() != null) { | 
				
			|||
				Collection<?> list = (Collection<?>) entity.getMethod().invoke(t, new Object[] {}); | 
				
			|||
				if (list != null && list.size() > maxHeight) { | 
				
			|||
					maxHeight = list.size(); | 
				
			|||
				} | 
				
			|||
			} | 
				
			|||
		} | 
				
			|||
		return maxHeight; | 
				
			|||
 | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public Workbook createExcleByTemplate(TemplateExportParams params, Class<?> pojoClass, Collection<?> dataSet, Map<String, Object> map) { | 
				
			|||
		// step 1. 判断模板的地址
 | 
				
			|||
		if (params == null || map == null || StringUtils.isEmpty(params.getTemplateUrl())) { | 
				
			|||
			throw new ExcelExportException(ExcelExportEnum.PARAMETER_ERROR); | 
				
			|||
		} | 
				
			|||
		Workbook wb = null; | 
				
			|||
		// step 2. 判断模板的Excel类型,解析模板
 | 
				
			|||
		try { | 
				
			|||
			this.teplateParams = params; | 
				
			|||
			wb = getCloneWorkBook(); | 
				
			|||
			// 创建表格样式
 | 
				
			|||
			setExcelExportStyler((IExcelExportStyler) teplateParams.getStyle().getConstructor(Workbook.class).newInstance(wb)); | 
				
			|||
			// step 3. 解析模板
 | 
				
			|||
			for (int i = 0, le = params.isScanAllsheet() ? wb.getNumberOfSheets() : params.getSheetNum().length; i < le; i++) { | 
				
			|||
				if (params.getSheetName() != null && params.getSheetName().length > i && StringUtils.isNotEmpty(params.getSheetName()[i])) { | 
				
			|||
					wb.setSheetName(i, params.getSheetName()[i]); | 
				
			|||
				} | 
				
			|||
				tempCreateCellSet.clear(); | 
				
			|||
				parseTemplate(wb.getSheetAt(i), map); | 
				
			|||
			} | 
				
			|||
			if (dataSet != null) { | 
				
			|||
				// step 4. 正常的数据填充
 | 
				
			|||
				dataHanlder = params.getDataHanlder(); | 
				
			|||
				if (dataHanlder != null) { | 
				
			|||
					needHanlderList = Arrays.asList(dataHanlder.getNeedHandlerFields()); | 
				
			|||
				} | 
				
			|||
				addDataToSheet(pojoClass, dataSet, wb.getSheetAt(params.getDataSheetNum()), wb); | 
				
			|||
			} | 
				
			|||
		} catch (Exception e) { | 
				
			|||
			LOGGER.error(e.getMessage(), e); | 
				
			|||
			return null; | 
				
			|||
		} | 
				
			|||
		return wb; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 克隆excel防止操作原对象,workbook无法克隆,只能对excel进行克隆 | 
				
			|||
	 * | 
				
			|||
	 * @throws Exception | 
				
			|||
	 * @Author JEECG | 
				
			|||
	 * @date 2013-11-11 | 
				
			|||
	 */ | 
				
			|||
	private Workbook getCloneWorkBook() throws Exception { | 
				
			|||
		return ExcelCache.getWorkbook(teplateParams.getTemplateUrl(), teplateParams.getSheetNum(), teplateParams.isScanAllsheet()); | 
				
			|||
 | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 获取表头数据,设置表头的序号 | 
				
			|||
	 * | 
				
			|||
	 * @param sheet | 
				
			|||
	 * @return | 
				
			|||
	 */ | 
				
			|||
	private Map<String, Integer> getTitleMap(Sheet sheet) { | 
				
			|||
		Row row = null; | 
				
			|||
		Iterator<Cell> cellTitle; | 
				
			|||
		Map<String, Integer> titlemap = new HashMap<String, Integer>(); | 
				
			|||
		for (int j = 0; j < teplateParams.getHeadingRows(); j++) { | 
				
			|||
			row = sheet.getRow(j + teplateParams.getHeadingStartRow()); | 
				
			|||
			cellTitle = row.cellIterator(); | 
				
			|||
			int i = row.getFirstCellNum(); | 
				
			|||
			while (cellTitle.hasNext()) { | 
				
			|||
				Cell cell = cellTitle.next(); | 
				
			|||
				String value = cell.getStringCellValue(); | 
				
			|||
				if (!StringUtils.isEmpty(value)) { | 
				
			|||
					titlemap.put(value, i); | 
				
			|||
				} | 
				
			|||
				i = i + 1; | 
				
			|||
			} | 
				
			|||
		} | 
				
			|||
		return titlemap; | 
				
			|||
 | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	private void parseTemplate(Sheet sheet, Map<String, Object> map) throws Exception { | 
				
			|||
		deleteCell(sheet, map); | 
				
			|||
		Row row = null; | 
				
			|||
		int index = 0; | 
				
			|||
		while (index <= sheet.getLastRowNum()) { | 
				
			|||
			row = sheet.getRow(index++); | 
				
			|||
			if (row == null) { | 
				
			|||
				continue; | 
				
			|||
			} | 
				
			|||
			for (int i = row.getFirstCellNum(); i < row.getLastCellNum(); i++) { | 
				
			|||
				if (row.getCell(i) != null && !tempCreateCellSet.contains(row.getRowNum() + "_" + row.getCell(i).getColumnIndex())) { | 
				
			|||
					setValueForCellByMap(row.getCell(i), map); | 
				
			|||
				} | 
				
			|||
			} | 
				
			|||
		} | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 先判断删除,省得影响效率 | 
				
			|||
	 * | 
				
			|||
	 * @param sheet | 
				
			|||
	 * @param map | 
				
			|||
	 * @throws Exception | 
				
			|||
	 */ | 
				
			|||
	private void deleteCell(Sheet sheet, Map<String, Object> map) throws Exception { | 
				
			|||
		Row row = null; | 
				
			|||
		Cell cell = null; | 
				
			|||
		int index = 0; | 
				
			|||
		while (index <= sheet.getLastRowNum()) { | 
				
			|||
			row = sheet.getRow(index++); | 
				
			|||
			if (row == null) { | 
				
			|||
				continue; | 
				
			|||
			} | 
				
			|||
			for (int i = row.getFirstCellNum(); i < row.getLastCellNum(); i++) { | 
				
			|||
				cell = row.getCell(i); | 
				
			|||
				if (row.getCell(i) != null && (cell.getCellType() == CellType.STRING || cell.getCellType() == CellType.NUMERIC)) { | 
				
			|||
					cell.setCellType(CellType.STRING); | 
				
			|||
					String text = cell.getStringCellValue(); | 
				
			|||
					if (text.contains(PoiElUtil.IF_DELETE)) { | 
				
			|||
						if (Boolean.valueOf(PoiElUtil.eval(text.substring(text.indexOf(PoiElUtil.START_STR) + 2, text.indexOf(PoiElUtil.END_STR)).trim(), map).toString())) { | 
				
			|||
							PoiSheetUtility.deleteColumn(sheet, i); | 
				
			|||
						} | 
				
			|||
						cell.setCellValue(""); | 
				
			|||
					} | 
				
			|||
				} | 
				
			|||
			} | 
				
			|||
		} | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 给每个Cell通过解析方式set值 | 
				
			|||
	 * | 
				
			|||
	 * @param cell | 
				
			|||
	 * @param map | 
				
			|||
	 */ | 
				
			|||
	private void setValueForCellByMap(Cell cell, Map<String, Object> map) throws Exception { | 
				
			|||
		CellType cellType = cell.getCellType(); | 
				
			|||
		if (cellType != CellType.STRING && cellType != CellType.NUMERIC) { | 
				
			|||
			return; | 
				
			|||
		} | 
				
			|||
		String oldString; | 
				
			|||
		cell.setCellType(CellType.STRING); | 
				
			|||
		oldString = cell.getStringCellValue(); | 
				
			|||
		if (oldString != null && oldString.indexOf(PoiElUtil.START_STR) != -1 && !oldString.contains(PoiElUtil.FOREACH)) { | 
				
			|||
			// step 2. 判断是否含有解析函数
 | 
				
			|||
			String params = null; | 
				
			|||
			boolean isNumber = false; | 
				
			|||
			if (isNumber(oldString)) { | 
				
			|||
				isNumber = true; | 
				
			|||
				oldString = oldString.replace(PoiElUtil.NUMBER_SYMBOL, ""); | 
				
			|||
			} | 
				
			|||
			while (oldString.indexOf(PoiElUtil.START_STR) != -1) { | 
				
			|||
				params = oldString.substring(oldString.indexOf(PoiElUtil.START_STR) + 2, oldString.indexOf(PoiElUtil.END_STR)); | 
				
			|||
 | 
				
			|||
				oldString = oldString.replace(PoiElUtil.START_STR + params + PoiElUtil.END_STR, PoiElUtil.eval(params, map).toString()); | 
				
			|||
			} | 
				
			|||
			// 如何是数值 类型,就按照数值类型进行设置
 | 
				
			|||
			if (isNumber && StringUtils.isNotBlank(oldString)) { | 
				
			|||
				cell.setCellValue(Double.parseDouble(oldString)); | 
				
			|||
				cell.setCellType(CellType.NUMERIC); | 
				
			|||
			} else { | 
				
			|||
				cell.setCellValue(oldString); | 
				
			|||
			} | 
				
			|||
		} | 
				
			|||
		// 判断foreach 这种方法
 | 
				
			|||
		if (oldString != null && oldString.contains(PoiElUtil.FOREACH)) { | 
				
			|||
			addListDataToExcel(cell, map, oldString.trim()); | 
				
			|||
		} | 
				
			|||
 | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	private boolean isNumber(String text) { | 
				
			|||
		return text.startsWith(PoiElUtil.NUMBER_SYMBOL) || text.contains("{" + PoiElUtil.NUMBER_SYMBOL) || text.contains(" " + PoiElUtil.NUMBER_SYMBOL); | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 利用foreach循环输出数据 | 
				
			|||
	 * | 
				
			|||
	 * @param cell | 
				
			|||
	 * @param map | 
				
			|||
	 * @throws Exception | 
				
			|||
	 */ | 
				
			|||
	private void addListDataToExcel(Cell cell, Map<String, Object> map, String name) throws Exception { | 
				
			|||
		boolean isCreate = !name.contains(PoiElUtil.FOREACH_NOT_CREATE); | 
				
			|||
		boolean isShift = name.contains(PoiElUtil.FOREACH_AND_SHIFT); | 
				
			|||
		name = name.replace(PoiElUtil.FOREACH_NOT_CREATE, PoiElUtil.EMPTY).replace(PoiElUtil.FOREACH_AND_SHIFT, PoiElUtil.EMPTY).replace(PoiElUtil.FOREACH, PoiElUtil.EMPTY).replace(PoiElUtil.START_STR, PoiElUtil.EMPTY); | 
				
			|||
		String[] keys = name.replaceAll("\\s{1,}", " ").trim().split(" "); | 
				
			|||
		Collection<?> datas = (Collection<?>) PoiPublicUtil.getParamsValue(keys[0], map); | 
				
			|||
		List<ExcelTemplateParams> columns = getAllDataColumns(cell, name.replace(keys[0], PoiElUtil.EMPTY)); | 
				
			|||
		if (datas == null) { | 
				
			|||
			return; | 
				
			|||
		} | 
				
			|||
		Iterator<?> its = datas.iterator(); | 
				
			|||
		Row row; | 
				
			|||
		int rowIndex = cell.getRow().getRowNum() + 1; | 
				
			|||
		// 处理当前行
 | 
				
			|||
		if (its.hasNext()) { | 
				
			|||
			Object t = its.next(); | 
				
			|||
			cell.getRow().setHeight(columns.get(0).getHeight()); | 
				
			|||
			setForEeachCellValue(isCreate, cell.getRow(), cell.getColumnIndex(), t, columns, map); | 
				
			|||
		} | 
				
			|||
		if (isShift) { | 
				
			|||
			cell.getRow().getSheet().shiftRows(cell.getRowIndex() + 1, cell.getRow().getSheet().getLastRowNum(), datas.size() - 1, true, true); | 
				
			|||
		} | 
				
			|||
		while (its.hasNext()) { | 
				
			|||
			Object t = its.next(); | 
				
			|||
			if (isCreate) { | 
				
			|||
				row = cell.getRow().getSheet().createRow(rowIndex++); | 
				
			|||
			} else { | 
				
			|||
				row = cell.getRow().getSheet().getRow(rowIndex++); | 
				
			|||
				if (row == null) { | 
				
			|||
					row = cell.getRow().getSheet().createRow(rowIndex - 1); | 
				
			|||
				} | 
				
			|||
			} | 
				
			|||
			row.setHeight(columns.get(0).getHeight()); | 
				
			|||
			setForEeachCellValue(isCreate, row, cell.getColumnIndex(), t, columns, map); | 
				
			|||
		} | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	private void setForEeachCellValue(boolean isCreate, Row row, int columnIndex, Object t, List<ExcelTemplateParams> columns, Map<String, Object> map) throws Exception { | 
				
			|||
		for (int i = 0, max = columnIndex + columns.size(); i < max; i++) { | 
				
			|||
			if (row.getCell(i) == null) | 
				
			|||
				row.createCell(i); | 
				
			|||
		} | 
				
			|||
		for (int i = 0, max = columns.size(); i < max; i++) { | 
				
			|||
			boolean isNumber = false; | 
				
			|||
			String tempStr = new String(columns.get(i).getName()); | 
				
			|||
			if (isNumber(tempStr)) { | 
				
			|||
				isNumber = true; | 
				
			|||
				tempStr = tempStr.replace(PoiElUtil.NUMBER_SYMBOL, ""); | 
				
			|||
			} | 
				
			|||
			map.put(teplateParams.getTempParams(), t); | 
				
			|||
			String val = PoiElUtil.eval(tempStr, map).toString(); | 
				
			|||
			if (isNumber && StringUtils.isNotEmpty(val)) { | 
				
			|||
				row.getCell(i + columnIndex).setCellValue(Double.parseDouble(val)); | 
				
			|||
				row.getCell(i + columnIndex).setCellType(CellType.NUMERIC); | 
				
			|||
			} else { | 
				
			|||
				row.getCell(i + columnIndex).setCellValue(val); | 
				
			|||
			} | 
				
			|||
			row.getCell(i + columnIndex).setCellStyle(columns.get(i).getCellStyle()); | 
				
			|||
			tempCreateCellSet.add(row.getRowNum() + "_" + (i + columnIndex)); | 
				
			|||
		} | 
				
			|||
 | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 获取迭代的数据的值 | 
				
			|||
	 * | 
				
			|||
	 * @param cell | 
				
			|||
	 * @param name | 
				
			|||
	 * @return | 
				
			|||
	 */ | 
				
			|||
	private List<ExcelTemplateParams> getAllDataColumns(Cell cell, String name) { | 
				
			|||
		List<ExcelTemplateParams> columns = new ArrayList<ExcelTemplateParams>(); | 
				
			|||
		cell.setCellValue(""); | 
				
			|||
		if (name.contains(PoiElUtil.END_STR)) { | 
				
			|||
			columns.add(new ExcelTemplateParams(name.replace(PoiElUtil.END_STR, PoiElUtil.EMPTY).trim(), cell.getCellStyle(), cell.getRow().getHeight())); | 
				
			|||
			return columns; | 
				
			|||
		} | 
				
			|||
		columns.add(new ExcelTemplateParams(name.trim(), cell.getCellStyle(), cell.getRow().getHeight())); | 
				
			|||
		int index = cell.getColumnIndex(); | 
				
			|||
		Cell tempCell; | 
				
			|||
		while (true) { | 
				
			|||
			tempCell = cell.getRow().getCell(++index); | 
				
			|||
			if (tempCell == null) { | 
				
			|||
				break; | 
				
			|||
			} | 
				
			|||
			String cellStringString; | 
				
			|||
			try {// 允许为空,单表示已经完结了,因为可能被删除了
 | 
				
			|||
				cellStringString = tempCell.getStringCellValue(); | 
				
			|||
				if (StringUtils.isBlank(cellStringString)) { | 
				
			|||
					break; | 
				
			|||
				} | 
				
			|||
			} catch (Exception e) { | 
				
			|||
				throw new ExcelExportException("for each 当中存在空字符串,请检查模板"); | 
				
			|||
			} | 
				
			|||
			// 把读取过的cell 置为空
 | 
				
			|||
			tempCell.setCellValue(""); | 
				
			|||
			if (cellStringString.contains(PoiElUtil.END_STR)) { | 
				
			|||
				columns.add(new ExcelTemplateParams(cellStringString.trim().replace(PoiElUtil.END_STR, ""), tempCell.getCellStyle(), tempCell.getRow().getHeight())); | 
				
			|||
				break; | 
				
			|||
			} else { | 
				
			|||
				if (cellStringString.trim().contains(teplateParams.getTempParams())) { | 
				
			|||
					columns.add(new ExcelTemplateParams(cellStringString.trim(), tempCell.getCellStyle(), tempCell.getRow().getHeight())); | 
				
			|||
				} else { | 
				
			|||
					// 最后一行被删除了
 | 
				
			|||
					break; | 
				
			|||
				} | 
				
			|||
			} | 
				
			|||
 | 
				
			|||
		} | 
				
			|||
		return columns; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 对导出序列进行排序和塞选 | 
				
			|||
	 * | 
				
			|||
	 * @param excelParams | 
				
			|||
	 * @param titlemap | 
				
			|||
	 * @return | 
				
			|||
	 */ | 
				
			|||
	private void sortAndFilterExportField(List<ExcelExportEntity> excelParams, Map<String, Integer> titlemap) { | 
				
			|||
		for (int i = excelParams.size() - 1; i >= 0; i--) { | 
				
			|||
			if (excelParams.get(i).getList() != null && excelParams.get(i).getList().size() > 0) { | 
				
			|||
				sortAndFilterExportField(excelParams.get(i).getList(), titlemap); | 
				
			|||
				if (excelParams.get(i).getList().size() == 0) { | 
				
			|||
					excelParams.remove(i); | 
				
			|||
				} else { | 
				
			|||
					excelParams.get(i).setOrderNum(i); | 
				
			|||
				} | 
				
			|||
			} else { | 
				
			|||
				if (titlemap.containsKey(excelParams.get(i).getName())) { | 
				
			|||
					excelParams.get(i).setOrderNum(i); | 
				
			|||
				} else { | 
				
			|||
					excelParams.remove(i); | 
				
			|||
				} | 
				
			|||
			} | 
				
			|||
		} | 
				
			|||
		sortAllParams(excelParams); | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
} | 
				
			|||
@ -0,0 +1,191 @@ | 
				
			|||
package cc.admin.poi.excel.html; | 
				
			|||
 | 
				
			|||
import java.util.Formatter; | 
				
			|||
import java.util.Iterator; | 
				
			|||
 | 
				
			|||
import cc.admin.poi.excel.html.helper.CellValueHelper; | 
				
			|||
import cc.admin.poi.excel.html.helper.MergedRegionHelper; | 
				
			|||
import cc.admin.poi.excel.html.helper.StylerHelper; | 
				
			|||
import org.apache.poi.ss.usermodel.Cell; | 
				
			|||
import org.apache.poi.ss.usermodel.CellStyle; | 
				
			|||
import org.apache.poi.ss.usermodel.Row; | 
				
			|||
import org.apache.poi.ss.usermodel.Sheet; | 
				
			|||
import org.apache.poi.ss.usermodel.Workbook; | 
				
			|||
 | 
				
			|||
/** | 
				
			|||
 * Excel转换成Html 服务 | 
				
			|||
 * | 
				
			|||
 * @author JEECG | 
				
			|||
 * @date 2015年5月10日 上午11:41:15 | 
				
			|||
 */ | 
				
			|||
public class ExcelToHtmlServer { | 
				
			|||
 | 
				
			|||
	private Workbook wb; | 
				
			|||
	private int sheetNum; | 
				
			|||
	private int cssRandom; | 
				
			|||
 | 
				
			|||
	/* 是不是完成界面 */ | 
				
			|||
	private boolean completeHTML; | 
				
			|||
	private Formatter out; | 
				
			|||
	/* 已经完成范围处理 */ | 
				
			|||
	private boolean gotBounds; | 
				
			|||
	private int firstColumn; | 
				
			|||
	private int endColumn; | 
				
			|||
	private static final String COL_HEAD_CLASS = "colHeader"; | 
				
			|||
	// private static final String ROW_HEAD_CLASS = "rowHeader";
 | 
				
			|||
 | 
				
			|||
	private static final String DEFAULTS_CLASS = "excelDefaults"; | 
				
			|||
 | 
				
			|||
	public ExcelToHtmlServer(Workbook wb, boolean completeHTML, int sheetNum) { | 
				
			|||
		this.wb = wb; | 
				
			|||
		this.completeHTML = completeHTML; | 
				
			|||
		this.sheetNum = sheetNum; | 
				
			|||
		cssRandom = (int) Math.ceil(Math.random() * 1000); | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public String printPage() { | 
				
			|||
		try { | 
				
			|||
			ensureOut(); | 
				
			|||
			if (completeHTML) { | 
				
			|||
				out.format("<!DOCTYPE HTML>%n"); | 
				
			|||
				out.format("<html>%n"); | 
				
			|||
				out.format("<meta http-equiv=\"Content-Type\" content=\"text/html; charset=UTF-8\">%n"); | 
				
			|||
				out.format("<head>%n"); | 
				
			|||
			} | 
				
			|||
			new StylerHelper(wb, out, sheetNum, cssRandom); | 
				
			|||
			if (completeHTML) { | 
				
			|||
				out.format("</head>%n"); | 
				
			|||
				out.format("<body>%n"); | 
				
			|||
			} | 
				
			|||
			print(); | 
				
			|||
			if (completeHTML) { | 
				
			|||
				out.format("</body>%n"); | 
				
			|||
				out.format("</html>%n"); | 
				
			|||
			} | 
				
			|||
			return out.toString(); | 
				
			|||
		} finally { | 
				
			|||
			if (out != null) | 
				
			|||
				out.close(); | 
				
			|||
		} | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	private void print() { | 
				
			|||
		printSheets(); | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	private void ensureOut() { | 
				
			|||
		if (out == null) | 
				
			|||
			out = new Formatter(new StringBuilder()); | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	private void printSheets() { | 
				
			|||
		Sheet sheet = wb.getSheetAt(sheetNum); | 
				
			|||
		printSheet(sheet); | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	private void printSheet(Sheet sheet) { | 
				
			|||
		out.format("<table class='%s' width='%s'>%n", DEFAULTS_CLASS, getTableWidth(sheet)); | 
				
			|||
		printCols(sheet); | 
				
			|||
		printSheetContent(sheet); | 
				
			|||
		out.format("</table>%n"); | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	private void printCols(Sheet sheet) { | 
				
			|||
		// out.format("<col/>%n");
 | 
				
			|||
		ensureColumnBounds(sheet); | 
				
			|||
		for (int i = firstColumn; i < endColumn; i++) { | 
				
			|||
			out.format("<col style='width:%spx;' />%n", sheet.getColumnWidth(i) / 32); | 
				
			|||
		} | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	private int getTableWidth(Sheet sheet) { | 
				
			|||
		ensureColumnBounds(sheet); | 
				
			|||
		int width = 0; | 
				
			|||
		for (int i = firstColumn; i < endColumn; i++) { | 
				
			|||
			width = width + (sheet.getColumnWidth(i) / 32); | 
				
			|||
		} | 
				
			|||
		return width; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	private void ensureColumnBounds(Sheet sheet) { | 
				
			|||
		if (gotBounds) | 
				
			|||
			return; | 
				
			|||
 | 
				
			|||
		Iterator<Row> iter = sheet.rowIterator(); | 
				
			|||
		firstColumn = (iter.hasNext() ? Integer.MAX_VALUE : 0); | 
				
			|||
		endColumn = 0; | 
				
			|||
		while (iter.hasNext()) { | 
				
			|||
			Row row = iter.next(); | 
				
			|||
			short firstCell = row.getFirstCellNum(); | 
				
			|||
			if (firstCell >= 0) { | 
				
			|||
				firstColumn = Math.min(firstColumn, firstCell); | 
				
			|||
				endColumn = Math.max(endColumn, row.getLastCellNum()); | 
				
			|||
			} | 
				
			|||
		} | 
				
			|||
		gotBounds = true; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	@SuppressWarnings("unused") | 
				
			|||
	/**本来是用来生成 A,B 那个列名称的**/ | 
				
			|||
	private void printColumnHeads(Sheet sheet) { | 
				
			|||
		out.format("<thead>%n"); | 
				
			|||
		out.format("  <tr class=%s>%n", COL_HEAD_CLASS); | 
				
			|||
		out.format("    <th class=%s>◊</th>%n", COL_HEAD_CLASS); | 
				
			|||
		StringBuilder colName = new StringBuilder(); | 
				
			|||
		for (int i = firstColumn; i < endColumn; i++) { | 
				
			|||
			colName.setLength(0); | 
				
			|||
			int cnum = i; | 
				
			|||
			do { | 
				
			|||
				colName.insert(0, (char) ('A' + cnum % 26)); | 
				
			|||
				cnum /= 26; | 
				
			|||
			} while (cnum > 0); | 
				
			|||
			out.format("    <th class=%s>%s</th>%n", COL_HEAD_CLASS, colName); | 
				
			|||
		} | 
				
			|||
		out.format("  </tr>%n"); | 
				
			|||
		out.format("</thead>%n"); | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	private void printSheetContent(Sheet sheet) { | 
				
			|||
		// printColumnHeads(sheet);
 | 
				
			|||
		MergedRegionHelper mergedRegionHelper = new MergedRegionHelper(sheet); | 
				
			|||
		CellValueHelper cellValueHelper = new CellValueHelper(wb, cssRandom); | 
				
			|||
		out.format("<tbody>%n"); | 
				
			|||
		Iterator<Row> rows = sheet.rowIterator(); | 
				
			|||
		int rowIndex = 1; | 
				
			|||
		while (rows.hasNext()) { | 
				
			|||
			Row row = rows.next(); | 
				
			|||
			out.format("  <tr style='height:%spx;'>%n", row.getHeight() / 15); | 
				
			|||
			// out.format("    <td class='%s'>%d</td>%n", ROW_HEAD_CLASS,
 | 
				
			|||
			// row.getRowNum() + 1);
 | 
				
			|||
			for (int i = firstColumn; i < endColumn; i++) { | 
				
			|||
				if (mergedRegionHelper.isNeedCreate(rowIndex, i)) { | 
				
			|||
					String content = " "; | 
				
			|||
					CellStyle style = null; | 
				
			|||
					if (i >= row.getFirstCellNum() && i < row.getLastCellNum()) { | 
				
			|||
						Cell cell = row.getCell(i); | 
				
			|||
						if (cell != null) { | 
				
			|||
							style = cell.getCellStyle(); | 
				
			|||
							content = cellValueHelper.getHtmlValue(cell); | 
				
			|||
						} | 
				
			|||
					} | 
				
			|||
					if (mergedRegionHelper.isMergedRegion(rowIndex, i)) { | 
				
			|||
						Integer[] rowAndColSpan = mergedRegionHelper.getRowAndColSpan(rowIndex, i); | 
				
			|||
						out.format("    <td rowspan='%s' colspan='%s' class='%s' >%s</td>%n", rowAndColSpan[0], rowAndColSpan[1], styleName(style), content); | 
				
			|||
					} else { | 
				
			|||
						out.format("    <td class='%s'>%s</td>%n", styleName(style), content); | 
				
			|||
					} | 
				
			|||
				} | 
				
			|||
 | 
				
			|||
			} | 
				
			|||
			out.format("  </tr>%n"); | 
				
			|||
			rowIndex++; | 
				
			|||
		} | 
				
			|||
		out.format("</tbody>%n"); | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	private String styleName(CellStyle style) { | 
				
			|||
		if (style == null) | 
				
			|||
			return ""; | 
				
			|||
		return String.format("style_%02x_%s font_%s_%s", style.getIndex(), cssRandom, style.getFontIndex(), cssRandom); | 
				
			|||
	} | 
				
			|||
} | 
				
			|||
@ -0,0 +1,135 @@ | 
				
			|||
package cc.admin.poi.excel.html.helper; | 
				
			|||
 | 
				
			|||
import com.google.common.xml.XmlEscapers; | 
				
			|||
import org.apache.poi.hssf.usermodel.HSSFRichTextString; | 
				
			|||
import org.apache.poi.hssf.usermodel.HSSFWorkbook; | 
				
			|||
import org.apache.poi.ss.usermodel.Cell; | 
				
			|||
import org.apache.poi.ss.usermodel.CellType; | 
				
			|||
import org.apache.poi.ss.usermodel.Font; | 
				
			|||
import org.apache.poi.ss.usermodel.Workbook; | 
				
			|||
import org.apache.poi.xssf.usermodel.XSSFFont; | 
				
			|||
import org.apache.poi.xssf.usermodel.XSSFRichTextString; | 
				
			|||
import org.apache.poi.xssf.usermodel.XSSFWorkbook; | 
				
			|||
 | 
				
			|||
import java.util.HashMap; | 
				
			|||
import java.util.Map; | 
				
			|||
 | 
				
			|||
/** | 
				
			|||
 * Cell值帮助类 | 
				
			|||
 * | 
				
			|||
 * @author JEECG | 
				
			|||
 * @date 2015年5月9日 下午10:31:32 | 
				
			|||
 */ | 
				
			|||
public class CellValueHelper { | 
				
			|||
	/** | 
				
			|||
	 * Excel 格式 | 
				
			|||
	 */ | 
				
			|||
	private boolean is07; | 
				
			|||
 | 
				
			|||
	private int cssRandom; | 
				
			|||
 | 
				
			|||
	private Map<String, String> fontCache = new HashMap<String, String>(); | 
				
			|||
 | 
				
			|||
	public CellValueHelper(Workbook wb, int cssRandom) { | 
				
			|||
		this.cssRandom = cssRandom; | 
				
			|||
		if (wb instanceof HSSFWorkbook) | 
				
			|||
			is07 = false; | 
				
			|||
		else if (wb instanceof XSSFWorkbook) { | 
				
			|||
			is07 = true; | 
				
			|||
			cacheFontInfo(wb); | 
				
			|||
		} else | 
				
			|||
			throw new IllegalArgumentException("unknown workbook type: " + wb.getClass().getSimpleName()); | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * O7 版本坑爹bug | 
				
			|||
	 * | 
				
			|||
	 * @param wb | 
				
			|||
	 */ | 
				
			|||
	private void cacheFontInfo(Workbook wb) { | 
				
			|||
		for (short i = 0, le = wb.getNumberOfFonts(); i < le; i++) { | 
				
			|||
			Font font = wb.getFontAt(i); | 
				
			|||
			fontCache.put(font.getBold() + "_" + font.getItalic() + "_" + font.getFontName() + "_" + font.getFontHeightInPoints() + "_" + font.getColor(), font.getIndex() + ""); | 
				
			|||
		} | 
				
			|||
 | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public String getHtmlValue(Cell cell) { | 
				
			|||
 | 
				
			|||
		if (CellType.BOOLEAN == cell.getCellType() || CellType.NUMERIC == cell.getCellType()) { | 
				
			|||
			cell.setCellType(CellType.STRING); | 
				
			|||
			return cell.getStringCellValue(); | 
				
			|||
		} else if (CellType.STRING == cell.getCellType()) { | 
				
			|||
			if (cell.getRichStringCellValue().numFormattingRuns() == 0) { | 
				
			|||
				return XmlEscapers.xmlContentEscaper().escape(cell.getStringCellValue()); | 
				
			|||
			} else if (is07) { | 
				
			|||
				return getXSSFRichString((XSSFRichTextString) cell.getRichStringCellValue()); | 
				
			|||
			} else { | 
				
			|||
				return getHSSFRichString((HSSFRichTextString) cell.getRichStringCellValue()); | 
				
			|||
			} | 
				
			|||
		} | 
				
			|||
		return ""; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 03版本复杂数据 | 
				
			|||
	 * | 
				
			|||
	 * @param rich | 
				
			|||
	 * @return | 
				
			|||
	 */ | 
				
			|||
	private String getHSSFRichString(HSSFRichTextString rich) { | 
				
			|||
		int nums = rich.numFormattingRuns(); | 
				
			|||
		StringBuilder sb = new StringBuilder(); | 
				
			|||
		String text = rich.toString(); | 
				
			|||
		int currentIndex = 0; | 
				
			|||
		sb.append(text.substring(0, rich.getIndexOfFormattingRun(0))); | 
				
			|||
		for (int i = 0; i < nums; i++) { | 
				
			|||
			sb.append("<span "); | 
				
			|||
			sb.append("class='font_" + rich.getFontOfFormattingRun(i)); | 
				
			|||
			sb.append("_"); | 
				
			|||
			sb.append(cssRandom); | 
				
			|||
			sb.append("'>"); | 
				
			|||
			currentIndex = rich.getIndexOfFormattingRun(i); | 
				
			|||
			if (i < nums - 1) { | 
				
			|||
				sb.append(XmlEscapers.xmlContentEscaper().escape(text.substring(currentIndex, rich.getIndexOfFormattingRun(i + 1)))); | 
				
			|||
			} else { | 
				
			|||
				sb.append(XmlEscapers.xmlContentEscaper().escape(text.substring(currentIndex, text.length()))); | 
				
			|||
			} | 
				
			|||
			sb.append("</span>"); | 
				
			|||
		} | 
				
			|||
		return sb.toString(); | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 07版本复杂数据 | 
				
			|||
	 * | 
				
			|||
	 * @param rich | 
				
			|||
	 * @return | 
				
			|||
	 */ | 
				
			|||
	private String getXSSFRichString(XSSFRichTextString rich) { | 
				
			|||
		int nums = rich.numFormattingRuns(); | 
				
			|||
		StringBuilder sb = new StringBuilder(); | 
				
			|||
		String text = rich.toString(); | 
				
			|||
		int currentIndex = 0, lastIndex = 0; | 
				
			|||
		for (int i = 1; i <= nums; i++) { | 
				
			|||
			sb.append("<span "); | 
				
			|||
			try { | 
				
			|||
				sb.append("class='font_" + getFontIndex(rich.getFontOfFormattingRun(i - 1))); | 
				
			|||
				sb.append("_"); | 
				
			|||
				sb.append(cssRandom); | 
				
			|||
				sb.append("'"); | 
				
			|||
			} catch (Exception e) { | 
				
			|||
			} | 
				
			|||
			sb.append(">"); | 
				
			|||
			currentIndex = rich.getIndexOfFormattingRun(i) == -1 ? text.length() : rich.getIndexOfFormattingRun(i); | 
				
			|||
			sb.append(XmlEscapers.xmlContentEscaper().escape(text.substring(lastIndex, currentIndex))); | 
				
			|||
			sb.append("</span>"); | 
				
			|||
			lastIndex = currentIndex; | 
				
			|||
		} | 
				
			|||
		return sb.toString(); | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	private String getFontIndex(XSSFFont font) { | 
				
			|||
		return fontCache.get(font.getBold() + "_" + font.getItalic() + "_" + font.getFontName() + "_" + font.getFontHeightInPoints() + "_" + font.getColor()); | 
				
			|||
	} | 
				
			|||
} | 
				
			|||
@ -0,0 +1,95 @@ | 
				
			|||
package cc.admin.poi.excel.html.helper; | 
				
			|||
 | 
				
			|||
import org.apache.poi.ss.usermodel.Sheet; | 
				
			|||
 | 
				
			|||
import java.util.HashMap; | 
				
			|||
import java.util.HashSet; | 
				
			|||
import java.util.Map; | 
				
			|||
import java.util.Set; | 
				
			|||
 | 
				
			|||
/** | 
				
			|||
 * 合并单元格帮助类 | 
				
			|||
 * | 
				
			|||
 * @author JEECG | 
				
			|||
 * @date 2015年5月9日 下午2:13:35 | 
				
			|||
 */ | 
				
			|||
public class MergedRegionHelper { | 
				
			|||
 | 
				
			|||
	private Map<String, Integer[]> mergedCache = new HashMap<String, Integer[]>(); | 
				
			|||
 | 
				
			|||
	private Set<String> notNeedCread = new HashSet<String>(); | 
				
			|||
 | 
				
			|||
	public MergedRegionHelper(Sheet sheet) { | 
				
			|||
		getAllMergedRegion(sheet); | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	private void getAllMergedRegion(Sheet sheet) { | 
				
			|||
		int nums = sheet.getNumMergedRegions(); | 
				
			|||
		for (int i = 0; i < nums; i++) { | 
				
			|||
			handerMergedString(sheet.getMergedRegion(i).formatAsString()); | 
				
			|||
		} | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 根据合并输出内容,处理合并单元格事情 | 
				
			|||
	 * | 
				
			|||
	 * @param formatAsString | 
				
			|||
	 */ | 
				
			|||
	private void handerMergedString(String formatAsString) { | 
				
			|||
		String[] strArr = formatAsString.split(":"); | 
				
			|||
		if (strArr.length == 2) { | 
				
			|||
			int startCol = strArr[0].charAt(0) - 65; | 
				
			|||
			if (strArr[0].charAt(1) >= 65) { | 
				
			|||
				startCol = (startCol + 1) * 26 + (strArr[0].charAt(1) - 65); | 
				
			|||
			} | 
				
			|||
			int startRol = Integer.valueOf(strArr[0].substring(strArr[0].charAt(1) >= 65 ? 2 : 1)); | 
				
			|||
			int endCol = strArr[1].charAt(0) - 65; | 
				
			|||
			if (strArr[1].charAt(1) >= 65) { | 
				
			|||
				endCol = (endCol + 1) * 26 + (strArr[1].charAt(1) - 65); | 
				
			|||
			} | 
				
			|||
			int endRol = Integer.valueOf(strArr[1].substring(strArr[1].charAt(1) >= 65 ? 2 : 1)); | 
				
			|||
			mergedCache.put(startRol + "_" + startCol, new Integer[] { endRol - startRol + 1, endCol - startCol + 1 }); | 
				
			|||
			for (int i = startRol; i <= endRol; i++) { | 
				
			|||
				for (int j = startCol; j <= endCol; j++) { | 
				
			|||
					notNeedCread.add(i + "_" + j); | 
				
			|||
				} | 
				
			|||
			} | 
				
			|||
			notNeedCread.remove(startRol + "_" + startCol); | 
				
			|||
		} | 
				
			|||
 | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 是不是需要创建这个TD | 
				
			|||
	 * | 
				
			|||
	 * @param row | 
				
			|||
	 * @param col | 
				
			|||
	 * @return | 
				
			|||
	 */ | 
				
			|||
	public boolean isNeedCreate(int row, int col) { | 
				
			|||
		return !notNeedCread.contains(row + "_" + col); | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 是不是合并区域 | 
				
			|||
	 * | 
				
			|||
	 * @param row | 
				
			|||
	 * @param col | 
				
			|||
	 * @return | 
				
			|||
	 */ | 
				
			|||
	public boolean isMergedRegion(int row, int col) { | 
				
			|||
		return mergedCache.containsKey(row + "_" + col); | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 获取合并区域 | 
				
			|||
	 * | 
				
			|||
	 * @param row | 
				
			|||
	 * @param col | 
				
			|||
	 * @return | 
				
			|||
	 */ | 
				
			|||
	public Integer[] getRowAndColSpan(int row, int col) { | 
				
			|||
		return mergedCache.get(row + "_" + col); | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
} | 
				
			|||
@ -0,0 +1,252 @@ | 
				
			|||
package cc.admin.poi.excel.html.helper; | 
				
			|||
 | 
				
			|||
 | 
				
			|||
import cc.admin.poi.util.PoiPublicUtil; | 
				
			|||
import org.apache.poi.hssf.usermodel.HSSFCellStyle; | 
				
			|||
import org.apache.poi.hssf.usermodel.HSSFPalette; | 
				
			|||
import org.apache.poi.hssf.usermodel.HSSFWorkbook; | 
				
			|||
import org.apache.poi.hssf.util.HSSFColor; | 
				
			|||
import org.apache.poi.ss.usermodel.*; | 
				
			|||
import org.apache.poi.xssf.usermodel.XSSFCellStyle; | 
				
			|||
import org.apache.poi.xssf.usermodel.XSSFColor; | 
				
			|||
import org.apache.poi.xssf.usermodel.XSSFFont; | 
				
			|||
import org.apache.poi.xssf.usermodel.XSSFWorkbook; | 
				
			|||
 | 
				
			|||
import java.io.BufferedReader; | 
				
			|||
import java.io.IOException; | 
				
			|||
import java.io.InputStreamReader; | 
				
			|||
import java.util.*; | 
				
			|||
 | 
				
			|||
/** | 
				
			|||
 * 样式帮助类 | 
				
			|||
 * | 
				
			|||
 * @author JEECG | 
				
			|||
 * @date 2015年5月9日 下午4:04:24 | 
				
			|||
 */ | 
				
			|||
public class StylerHelper { | 
				
			|||
 | 
				
			|||
	private static String DEFAULTS_CLASS_CSS = ".excelDefaults {background-color: white;color: black;text-decoration: none;direction: ltr;text-transform: none;text-indent: 0;letter-spacing: 0;word-spacing: 0;white-space: normal;unicode-bidi: normal;vertical-align: 0;text-shadow: none;padding: 0;margin: 0;border-collapse: collapse;white-space: pre-wrap;word-wrap: break-word;word-break: break-all;}.excelDefaults td {padding: 1px 5px;border: 1px solid silver;border-color: #000000;text-align: center;vertical-align: middle;font-size: 12pt;}.excelDefaults .colHeader {background-color: silver;font-weight: bold;border: 1px solid black;text-align: center;padding: 1px 5px;}.excelDefaults .rowHeader {background-color: silver;font-weight: bold;border: 1px solid black;text-align: right;padding: 1px 5px;}"; | 
				
			|||
 | 
				
			|||
	private static final String DEFAULTS_CLASS = "excelDefaults"; | 
				
			|||
 | 
				
			|||
	private static final Map<HorizontalAlignment, String> ALIGN = PoiPublicUtil.mapFor(HorizontalAlignment.LEFT, "left", HorizontalAlignment.CENTER, "center", HorizontalAlignment.CENTER, "right", HorizontalAlignment.FILL, "left", HorizontalAlignment.JUSTIFY, "left", HorizontalAlignment.CENTER_SELECTION, "center"); | 
				
			|||
 | 
				
			|||
	private static final Map<VerticalAlignment, String> VERTICAL_ALIGN = PoiPublicUtil.mapFor(VerticalAlignment.BOTTOM, "bottom", VerticalAlignment.CENTER, "middle", VerticalAlignment.TOP, "top"); | 
				
			|||
 | 
				
			|||
	private Formatter out; | 
				
			|||
 | 
				
			|||
	private Sheet sheet; | 
				
			|||
 | 
				
			|||
	private HtmlHelper helper; | 
				
			|||
 | 
				
			|||
	private int sheetNum; | 
				
			|||
 | 
				
			|||
	private int cssRandom; | 
				
			|||
 | 
				
			|||
	public StylerHelper(Workbook wb, Formatter out, int sheetNum, int cssRandom) { | 
				
			|||
		this.out = out; | 
				
			|||
		this.sheetNum = sheetNum; | 
				
			|||
		this.cssRandom = cssRandom; | 
				
			|||
		if (wb instanceof HSSFWorkbook) | 
				
			|||
			helper = new HSSFHtmlHelper((HSSFWorkbook) wb); | 
				
			|||
		else if (wb instanceof XSSFWorkbook) | 
				
			|||
			helper = new XSSFHtmlHelper((XSSFWorkbook) wb); | 
				
			|||
		else | 
				
			|||
			throw new IllegalArgumentException("unknown workbook type: " + wb.getClass().getSimpleName()); | 
				
			|||
		printInlineStyle(wb); | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	private void printInlineStyle(Workbook wb) { | 
				
			|||
		out.format("<style type=\"text/css\">%n"); | 
				
			|||
		printStyles(wb); | 
				
			|||
		prontFonts(wb); | 
				
			|||
		out.format("</style>%n"); | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	private void prontFonts(Workbook wb) { | 
				
			|||
		for (short i = 0, le = wb.getNumberOfFonts(); i <= le; i++) { | 
				
			|||
			Font font = wb.getFontAt(i); | 
				
			|||
			out.format(".%s .%s {%n", DEFAULTS_CLASS, "font_" + i + "_" + cssRandom); | 
				
			|||
			fontStyle(font); | 
				
			|||
			out.format("}%n"); | 
				
			|||
		} | 
				
			|||
 | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void printStyles(Workbook wb) { | 
				
			|||
		if (DEFAULTS_CLASS_CSS == null) { | 
				
			|||
			DEFAULTS_CLASS_CSS = getDefaultsClassCss(); | 
				
			|||
		} | 
				
			|||
		out.format(DEFAULTS_CLASS_CSS); | 
				
			|||
		Set<CellStyle> seen = new HashSet<CellStyle>(); | 
				
			|||
		sheet = wb.getSheetAt(sheetNum); | 
				
			|||
		Iterator<Row> rows = sheet.rowIterator(); | 
				
			|||
		while (rows.hasNext()) { | 
				
			|||
			Row row = rows.next(); | 
				
			|||
			for (Cell cell : row) { | 
				
			|||
				CellStyle style = cell.getCellStyle(); | 
				
			|||
				if (!seen.contains(style)) { | 
				
			|||
					printStyle(style); | 
				
			|||
					seen.add(style); | 
				
			|||
				} | 
				
			|||
			} | 
				
			|||
		} | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	private String getDefaultsClassCss() { | 
				
			|||
		BufferedReader in = null; | 
				
			|||
		StringBuilder sb = new StringBuilder(); | 
				
			|||
		Formatter formatter = new Formatter(sb); | 
				
			|||
		try { | 
				
			|||
			in = new BufferedReader(new InputStreamReader(StylerHelper.class.getResourceAsStream("excelStyle.css"))); | 
				
			|||
			String line; | 
				
			|||
			while ((line = in.readLine()) != null) { | 
				
			|||
				formatter.format("%s%n", line); | 
				
			|||
			} | 
				
			|||
			return formatter.toString(); | 
				
			|||
		} catch (IOException e) { | 
				
			|||
			throw new IllegalStateException("Reading standard css", e); | 
				
			|||
		} finally { | 
				
			|||
			if (in != null) { | 
				
			|||
				try { | 
				
			|||
					in.close(); | 
				
			|||
				} catch (IOException e) { | 
				
			|||
					throw new IllegalStateException("Reading standard css", e); | 
				
			|||
				} | 
				
			|||
			} | 
				
			|||
			formatter.close(); | 
				
			|||
		} | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	private void printStyle(CellStyle style) { | 
				
			|||
		out.format(".%s .%s {%n", DEFAULTS_CLASS, styleName(style)); | 
				
			|||
		styleContents(style); | 
				
			|||
		out.format("}%n"); | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	private void styleContents(CellStyle style) { | 
				
			|||
		if (style.getAlignment() != HorizontalAlignment.CENTER) { | 
				
			|||
			styleOut("text-align", style.getAlignment(), ALIGN); | 
				
			|||
			styleOut("vertical-align", style.getVerticalAlignment(), VERTICAL_ALIGN); | 
				
			|||
		} | 
				
			|||
		helper.colorStyles(style, out); | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	private void fontStyle(Font font) { | 
				
			|||
		if (font.getBold()) | 
				
			|||
			out.format("  font-weight: bold;%n"); | 
				
			|||
		if (font.getItalic()) | 
				
			|||
			out.format("  font-style: italic;%n"); | 
				
			|||
		out.format("  font-family: %s;%n", font.getFontName()); | 
				
			|||
 | 
				
			|||
		int fontheight = font.getFontHeightInPoints(); | 
				
			|||
		if (fontheight == 9) { | 
				
			|||
			fontheight = 10; | 
				
			|||
		} | 
				
			|||
		out.format("  font-size: %dpt;%n", fontheight); | 
				
			|||
		helper.styleColor(out, "color", getColor(font)); | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	private Color getColor(Font font) { | 
				
			|||
		if (helper instanceof HSSFHtmlHelper) { | 
				
			|||
			return ((HSSFWorkbook) sheet.getWorkbook()).getCustomPalette().getColor(font.getColor()); | 
				
			|||
		} else { | 
				
			|||
			return ((XSSFFont) font).getXSSFColor(); | 
				
			|||
		} | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	private String styleName(CellStyle style) { | 
				
			|||
		if (style == null) | 
				
			|||
			return ""; | 
				
			|||
		return String.format("style_%02x_%s", style.getIndex(), cssRandom); | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	private <K> void styleOut(String attr, K key, Map<K, String> mapping) { | 
				
			|||
		String value = mapping.get(key); | 
				
			|||
		if (value != null) { | 
				
			|||
			out.format("  %s: %s;%n", attr, value); | 
				
			|||
		} | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	private interface HtmlHelper { | 
				
			|||
		/** | 
				
			|||
		 * Outputs the appropriate CSS style for the given cell style. | 
				
			|||
		 * | 
				
			|||
		 * @param style | 
				
			|||
		 *            The cell style. | 
				
			|||
		 * @param out | 
				
			|||
		 *            The place to write the output. | 
				
			|||
		 */ | 
				
			|||
		void colorStyles(CellStyle style, Formatter out); | 
				
			|||
 | 
				
			|||
		void styleColor(Formatter out, String attr, Color color); | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	private class HSSFHtmlHelper implements HtmlHelper { | 
				
			|||
		private final HSSFWorkbook wb; | 
				
			|||
		private final HSSFPalette colors; | 
				
			|||
 | 
				
			|||
		private final HSSFColor HSSF_AUTO = HSSFColor.HSSFColorPredefined.AUTOMATIC.getColor(); | 
				
			|||
 | 
				
			|||
		public HSSFHtmlHelper(HSSFWorkbook wb) { | 
				
			|||
			this.wb = wb; | 
				
			|||
			colors = wb.getCustomPalette(); | 
				
			|||
		} | 
				
			|||
 | 
				
			|||
		public void colorStyles(CellStyle style, Formatter out) { | 
				
			|||
			HSSFCellStyle cs = (HSSFCellStyle) style; | 
				
			|||
			out.format("  /* fill pattern = %d */%n", cs.getFillPattern()); | 
				
			|||
			styleColor(out, "background-color", cs.getFillForegroundColor()); | 
				
			|||
			styleColor(out, "color", colors.getColor(cs.getFont(wb).getColor())); | 
				
			|||
		} | 
				
			|||
 | 
				
			|||
		private void styleColor(Formatter out, String attr, short index) { | 
				
			|||
			HSSFColor color = colors.getColor(index); | 
				
			|||
			if (index == HSSF_AUTO.getIndex() || color == null) { | 
				
			|||
				out.format("  /* %s: index = %d */%n", attr, index); | 
				
			|||
			} else { | 
				
			|||
				short[] rgb = color.getTriplet(); | 
				
			|||
				out.format("  %s: #%02x%02x%02x; /* index = %d */%n", attr, rgb[0], rgb[1], rgb[2], index); | 
				
			|||
			} | 
				
			|||
		} | 
				
			|||
 | 
				
			|||
		public void styleColor(Formatter out, String attr, Color color) { | 
				
			|||
			if (color == null) { | 
				
			|||
				return; | 
				
			|||
			} | 
				
			|||
			HSSFColor hSSFColor = (HSSFColor) color; | 
				
			|||
			short[] rgb = hSSFColor.getTriplet(); | 
				
			|||
			out.format("  %s: #%02x%02x%02x; %n", attr, rgb[0], rgb[1], rgb[2]); | 
				
			|||
		} | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * Implementation of {@link HtmlHelper} for XSSF files. | 
				
			|||
	 * | 
				
			|||
	 * @author Ken Arnold, Industrious Media LLC | 
				
			|||
	 */ | 
				
			|||
	private class XSSFHtmlHelper implements HtmlHelper { | 
				
			|||
 | 
				
			|||
		public XSSFHtmlHelper(XSSFWorkbook wb) { | 
				
			|||
		} | 
				
			|||
 | 
				
			|||
		public void colorStyles(CellStyle style, Formatter out) { | 
				
			|||
			XSSFCellStyle cs = (XSSFCellStyle) style; | 
				
			|||
			styleColor(out, "background-color", cs.getFillForegroundXSSFColor()); | 
				
			|||
			styleColor(out, "color", cs.getFont().getXSSFColor()); | 
				
			|||
		} | 
				
			|||
 | 
				
			|||
		public void styleColor(Formatter out, String attr, Color color) { | 
				
			|||
			XSSFColor xSSFColor = (XSSFColor) color; | 
				
			|||
			if (color == null || xSSFColor.isAuto()) | 
				
			|||
				return; | 
				
			|||
 | 
				
			|||
			byte[] rgb = xSSFColor.getRGB(); | 
				
			|||
			if (rgb == null) { | 
				
			|||
				return; | 
				
			|||
			} | 
				
			|||
			out.format("  %s: #%02x%02x%02x;%n", attr, rgb[0], rgb[1], rgb[2]); | 
				
			|||
		} | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
} | 
				
			|||
@ -0,0 +1,45 @@ | 
				
			|||
.excelDefaults { | 
				
			|||
	background-color: white; | 
				
			|||
	color: black; | 
				
			|||
	text-decoration: none; | 
				
			|||
	direction: ltr; | 
				
			|||
	text-transform: none; | 
				
			|||
	text-indent: 0; | 
				
			|||
	letter-spacing: 0; | 
				
			|||
	word-spacing: 0; | 
				
			|||
	white-space: normal; | 
				
			|||
	unicode-bidi: normal; | 
				
			|||
	vertical-align: 0; | 
				
			|||
	text-shadow: none; | 
				
			|||
	padding: 0; | 
				
			|||
	margin: 0; | 
				
			|||
	border-collapse: collapse; | 
				
			|||
	white-space: pre-wrap; | 
				
			|||
	word-wrap: break-word; | 
				
			|||
	word-break: break-all; | 
				
			|||
} | 
				
			|||
 | 
				
			|||
.excelDefaults td { | 
				
			|||
	padding: 1px 5px; | 
				
			|||
	border: 1px solid silver; | 
				
			|||
	border-color: #000000; | 
				
			|||
	text-align: center; | 
				
			|||
	vertical-align: middle; | 
				
			|||
	font-size: 12pt; | 
				
			|||
} | 
				
			|||
 | 
				
			|||
.excelDefaults .colHeader { | 
				
			|||
	background-color: silver; | 
				
			|||
	font-weight: bold; | 
				
			|||
	border: 1px solid black; | 
				
			|||
	text-align: center; | 
				
			|||
	padding: 1px 5px; | 
				
			|||
} | 
				
			|||
 | 
				
			|||
.excelDefaults .rowHeader { | 
				
			|||
	background-color: silver; | 
				
			|||
	font-weight: bold; | 
				
			|||
	border: 1px solid black; | 
				
			|||
	text-align: right; | 
				
			|||
	padding: 1px 5px; | 
				
			|||
} | 
				
			|||
@ -0,0 +1,346 @@ | 
				
			|||
/** | 
				
			|||
 * Copyright 2013-2015 JEECG (jeecgos@163.com) | 
				
			|||
 * | 
				
			|||
 *  Licensed under the Apache License, Version 2.0 (the "License"); | 
				
			|||
 *  you may not use this file except in compliance with the License. | 
				
			|||
 *  You may obtain a copy of the License at | 
				
			|||
 * | 
				
			|||
 *     http://www.apache.org/licenses/LICENSE-2.0
 | 
				
			|||
 * | 
				
			|||
 *  Unless required by applicable law or agreed to in writing, software | 
				
			|||
 * distributed under the License is distributed on an "AS IS" BASIS, | 
				
			|||
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | 
				
			|||
 * See the License for the specific language governing permissions and | 
				
			|||
 * limitations under the License. | 
				
			|||
 */ | 
				
			|||
package cc.admin.poi.excel.imports; | 
				
			|||
 | 
				
			|||
import cc.admin.poi.excel.entity.params.ExcelImportEntity; | 
				
			|||
import cc.admin.poi.excel.entity.sax.SaxReadCellEntity; | 
				
			|||
import cc.admin.poi.exception.excel.ExcelImportException; | 
				
			|||
import cc.admin.poi.exception.excel.enums.ExcelImportEnum; | 
				
			|||
import cc.admin.poi.handler.inter.IExcelDataHandler; | 
				
			|||
import cc.admin.poi.util.ExcelUtil; | 
				
			|||
import cc.admin.poi.util.PoiPublicUtil; | 
				
			|||
import org.apache.commons.lang3.StringUtils; | 
				
			|||
import org.apache.poi.ss.usermodel.Cell; | 
				
			|||
import org.apache.poi.ss.usermodel.CellType; | 
				
			|||
import org.slf4j.Logger; | 
				
			|||
import org.slf4j.LoggerFactory; | 
				
			|||
 | 
				
			|||
import java.lang.reflect.Method; | 
				
			|||
import java.lang.reflect.Type; | 
				
			|||
import java.math.BigDecimal; | 
				
			|||
import java.sql.Time; | 
				
			|||
import java.text.ParseException; | 
				
			|||
import java.text.SimpleDateFormat; | 
				
			|||
import java.util.Arrays; | 
				
			|||
import java.util.Date; | 
				
			|||
import java.util.List; | 
				
			|||
import java.util.Map; | 
				
			|||
 | 
				
			|||
/** | 
				
			|||
 * Cell 取值服务 判断类型处理数据 1.判断Excel中的类型 2.根据replace替换值 3.handler处理数据 4.判断返回类型转化数据返回 | 
				
			|||
 * | 
				
			|||
 * @author JEECG | 
				
			|||
 * @date 2014年6月26日 下午10:42:28 | 
				
			|||
 */ | 
				
			|||
public class CellValueServer { | 
				
			|||
 | 
				
			|||
	private static final Logger LOGGER = LoggerFactory.getLogger(CellValueServer.class); | 
				
			|||
 | 
				
			|||
	private List<String> hanlderList = null; | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 获取单元格内的值 | 
				
			|||
	 * | 
				
			|||
	 * @param xclass | 
				
			|||
	 * @param cell | 
				
			|||
	 * @param entity | 
				
			|||
	 * @return | 
				
			|||
	 */ | 
				
			|||
	private Object getCellValue(String xclass, Cell cell, ExcelImportEntity entity) { | 
				
			|||
		if (cell == null) { | 
				
			|||
			return ""; | 
				
			|||
		} | 
				
			|||
		Object result = null; | 
				
			|||
		// 日期格式比较特殊,和cell格式不一致
 | 
				
			|||
		if ("class java.util.Date".equals(xclass) || ("class java.sql.Time").equals(xclass)) { | 
				
			|||
			if (CellType.NUMERIC == cell.getCellType()) { | 
				
			|||
				// 日期格式
 | 
				
			|||
				result = cell.getDateCellValue(); | 
				
			|||
			} else { | 
				
			|||
				cell.setCellType(CellType.STRING); | 
				
			|||
				result = getDateData(entity, cell.getStringCellValue()); | 
				
			|||
			} | 
				
			|||
			if (("class java.sql.Time").equals(xclass)) { | 
				
			|||
				result = new Time(((Date) result).getTime()); | 
				
			|||
			} | 
				
			|||
		} else if (CellType.NUMERIC == cell.getCellType()) { | 
				
			|||
			result = cell.getNumericCellValue(); | 
				
			|||
		} else if (CellType.BOOLEAN == cell.getCellType()) { | 
				
			|||
			result = cell.getBooleanCellValue(); | 
				
			|||
		} else { | 
				
			|||
			result = cell.getStringCellValue(); | 
				
			|||
		} | 
				
			|||
		return result; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 获取日期类型数据 | 
				
			|||
	 * | 
				
			|||
	 * @Author JEECG | 
				
			|||
	 * @date 2013年11月26日 | 
				
			|||
	 * @param entity | 
				
			|||
	 * @param value | 
				
			|||
	 * @return | 
				
			|||
	 */ | 
				
			|||
	private Date getDateData(ExcelImportEntity entity, String value) { | 
				
			|||
		if (StringUtils.isNotEmpty(entity.getFormat()) && StringUtils.isNotEmpty(value)) { | 
				
			|||
			SimpleDateFormat format = new SimpleDateFormat(entity.getFormat()); | 
				
			|||
			try { | 
				
			|||
				return format.parse(value); | 
				
			|||
			} catch (ParseException e) { | 
				
			|||
				LOGGER.error("时间格式化失败,格式化:{},值:{}", entity.getFormat(), value); | 
				
			|||
				throw new ExcelImportException(ExcelImportEnum.GET_VALUE_ERROR); | 
				
			|||
			} | 
				
			|||
		} | 
				
			|||
		return null; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 获取cell的值 | 
				
			|||
	 * | 
				
			|||
	 * @param object | 
				
			|||
	 * @param excelParams | 
				
			|||
	 * @param cell | 
				
			|||
	 * @param titleString | 
				
			|||
	 */ | 
				
			|||
	public Object getValue(IExcelDataHandler dataHanlder, Object object, Cell cell, Map<String, ExcelImportEntity> excelParams, String titleString) throws Exception { | 
				
			|||
		ExcelImportEntity entity = excelParams.get(titleString); | 
				
			|||
		String xclass = "class java.lang.Object"; | 
				
			|||
		if (!(object instanceof Map)) { | 
				
			|||
			Method setMethod = entity.getMethods() != null && entity.getMethods().size() > 0 ? entity.getMethods().get(entity.getMethods().size() - 1) : entity.getMethod(); | 
				
			|||
			Type[] ts = setMethod.getGenericParameterTypes(); | 
				
			|||
			xclass = ts[0].toString(); | 
				
			|||
		} | 
				
			|||
		Object result = getCellValue(xclass, cell, entity); | 
				
			|||
		if (entity != null) { | 
				
			|||
			result = hanlderSuffix(entity.getSuffix(), result); | 
				
			|||
			//update-begin-author:taoYan date:20180807 for:多值替换
 | 
				
			|||
			result = replaceValue(entity.getReplace(), result,entity.isMultiReplace()); | 
				
			|||
			//update-end-author:taoYan date:20180807 for:多值替换
 | 
				
			|||
		} | 
				
			|||
		result = hanlderValue(dataHanlder, object, result, titleString); | 
				
			|||
		return getValueByType(xclass, result, entity); | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 获取cell值 | 
				
			|||
	 * | 
				
			|||
	 * @param dataHanlder | 
				
			|||
	 * @param object | 
				
			|||
	 * @param excelParams | 
				
			|||
	 * @param titleString | 
				
			|||
	 * @return | 
				
			|||
	 */ | 
				
			|||
	public Object getValue(IExcelDataHandler dataHanlder, Object object, SaxReadCellEntity cellEntity, Map<String, ExcelImportEntity> excelParams, String titleString) { | 
				
			|||
		ExcelImportEntity entity = excelParams.get(titleString); | 
				
			|||
		Method setMethod = entity.getMethods() != null && entity.getMethods().size() > 0 ? entity.getMethods().get(entity.getMethods().size() - 1) : entity.getMethod(); | 
				
			|||
		Type[] ts = setMethod.getGenericParameterTypes(); | 
				
			|||
		String xclass = ts[0].toString(); | 
				
			|||
		Object result = cellEntity.getValue(); | 
				
			|||
		result = hanlderSuffix(entity.getSuffix(), result); | 
				
			|||
		//update-begin-auhtor:taoyan date:20180807 for:多值替换
 | 
				
			|||
		result = replaceValue(entity.getReplace(), result,entity.isMultiReplace()); | 
				
			|||
		//update-end-auhtor:taoyan date:20180807 for:多值替换
 | 
				
			|||
		result = hanlderValue(dataHanlder, object, result, titleString); | 
				
			|||
		return getValueByType(xclass, result, entity); | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 把后缀删除掉 | 
				
			|||
	 * | 
				
			|||
	 * @param result | 
				
			|||
	 * @param suffix | 
				
			|||
	 * @return | 
				
			|||
	 */ | 
				
			|||
	private Object hanlderSuffix(String suffix, Object result) { | 
				
			|||
		if (StringUtils.isNotEmpty(suffix) && result != null && result.toString().endsWith(suffix)) { | 
				
			|||
			String temp = result.toString(); | 
				
			|||
			return temp.substring(0, temp.length() - suffix.length()); | 
				
			|||
		} | 
				
			|||
		return result; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 根据返回类型获取返回值 | 
				
			|||
	 * | 
				
			|||
	 * @param xclass | 
				
			|||
	 * @param result | 
				
			|||
	 * @param entity | 
				
			|||
	 * @return | 
				
			|||
	 */ | 
				
			|||
	private Object getValueByType(String xclass, Object result, ExcelImportEntity entity) { | 
				
			|||
		try { | 
				
			|||
			//update-begin-author:scott date:20180711 for:TASK #2950 【bug】excel 导入报错,空指针问题
 | 
				
			|||
			if(result==null || "".equals(String.valueOf(result))){ | 
				
			|||
				return null; | 
				
			|||
			} | 
				
			|||
			//update-end-author:scott date:20180711 for:TASK #2950 【bug】excel 导入报错,空指针问题
 | 
				
			|||
			if ("class java.util.Date".equals(xclass)) { | 
				
			|||
				return result; | 
				
			|||
			} | 
				
			|||
			if ("class java.lang.Boolean".equals(xclass) || "boolean".equals(xclass)) { | 
				
			|||
				//update-begin-author:taoYan date:20200319 for:Excel注解的numFormat方法似乎未实现 #970
 | 
				
			|||
				Boolean temp = Boolean.valueOf(String.valueOf(result)); | 
				
			|||
				//if(StringUtils.isNotEmpty(entity.getNumFormat())){
 | 
				
			|||
				//	return Boolean.valueOf(new DecimalFormat(entity.getNumFormat()).format(temp));
 | 
				
			|||
				//}else{
 | 
				
			|||
					return temp; | 
				
			|||
				//}
 | 
				
			|||
				//update-end-author:taoYan date:20200319 for:Excel注解的numFormat方法似乎未实现 #970
 | 
				
			|||
			} | 
				
			|||
			if ("class java.lang.Double".equals(xclass) || "double".equals(xclass)) { | 
				
			|||
				//update-begin-author:taoYan date:20200319 for:Excel注解的numFormat方法似乎未实现 #970
 | 
				
			|||
				Double temp = Double.valueOf(String.valueOf(result)); | 
				
			|||
				//if(StringUtils.isNotEmpty(entity.getNumFormat())){
 | 
				
			|||
				//	return Double.valueOf(new DecimalFormat(entity.getNumFormat()).format(temp));
 | 
				
			|||
				//}else{
 | 
				
			|||
					return temp; | 
				
			|||
				//}
 | 
				
			|||
				//update-end-author:taoYan date:20200319 for:Excel注解的numFormat方法似乎未实现 #970
 | 
				
			|||
			} | 
				
			|||
			if ("class java.lang.Long".equals(xclass) || "long".equals(xclass)) { | 
				
			|||
				//update-begin-author:taoYan date:20200319 for:Excel注解的numFormat方法似乎未实现 #970
 | 
				
			|||
				Long temp = Long.valueOf(ExcelUtil.remove0Suffix(String.valueOf(result))); | 
				
			|||
				//if(StringUtils.isNotEmpty(entity.getNumFormat())){
 | 
				
			|||
				//	return Long.valueOf(new DecimalFormat(entity.getNumFormat()).format(temp));
 | 
				
			|||
				//}else{
 | 
				
			|||
					return temp; | 
				
			|||
				//}
 | 
				
			|||
				//update-end-author:taoYan date:20200319 for:Excel注解的numFormat方法似乎未实现 #970
 | 
				
			|||
			} | 
				
			|||
			if ("class java.lang.Float".equals(xclass) || "float".equals(xclass)) { | 
				
			|||
				//update-begin-author:taoYan date:20200319 for:Excel注解的numFormat方法似乎未实现 #970
 | 
				
			|||
				Float temp = Float.valueOf(String.valueOf(result)); | 
				
			|||
				//if(StringUtils.isNotEmpty(entity.getNumFormat())){
 | 
				
			|||
				//	return Float.valueOf(new DecimalFormat(entity.getNumFormat()).format(temp));
 | 
				
			|||
				//}else{
 | 
				
			|||
					return temp; | 
				
			|||
				//}
 | 
				
			|||
				//update-end-author:taoYan date:20200319 for:Excel注解的numFormat方法似乎未实现 #970
 | 
				
			|||
			} | 
				
			|||
			if ("class java.lang.Integer".equals(xclass) || "int".equals(xclass)) { | 
				
			|||
				//update-begin-author:taoYan date:20200319 for:Excel注解的numFormat方法似乎未实现 #970
 | 
				
			|||
				Integer temp = Integer.valueOf(ExcelUtil.remove0Suffix(String.valueOf(result))); | 
				
			|||
				//if(StringUtils.isNotEmpty(entity.getNumFormat())){
 | 
				
			|||
				//	return Integer.valueOf(new DecimalFormat(entity.getNumFormat()).format(temp));
 | 
				
			|||
				//}else{
 | 
				
			|||
					return temp; | 
				
			|||
				//}
 | 
				
			|||
				//update-end-author:taoYan date:20200319 for:Excel注解的numFormat方法似乎未实现 #970
 | 
				
			|||
			} | 
				
			|||
			if ("class java.math.BigDecimal".equals(xclass)) { | 
				
			|||
				//update-begin-author:taoYan date:20200319 for:Excel注解的numFormat方法似乎未实现 #970
 | 
				
			|||
				BigDecimal temp = new BigDecimal(String.valueOf(result)); | 
				
			|||
				//if(StringUtils.isNotEmpty(entity.getNumFormat())){
 | 
				
			|||
				//	return new BigDecimal(new DecimalFormat(entity.getNumFormat()).format(temp));
 | 
				
			|||
				//}else{
 | 
				
			|||
					return temp; | 
				
			|||
				//}
 | 
				
			|||
				//update-end-author:taoYan date:20200319 for:Excel注解的numFormat方法似乎未实现 #970
 | 
				
			|||
			} | 
				
			|||
			if ("class java.lang.String".equals(xclass)) { | 
				
			|||
				// 针对String 类型,但是Excel获取的数据却不是String,比如Double类型,防止科学计数法
 | 
				
			|||
				if (result instanceof String) { | 
				
			|||
					//---update-begin-----autor:scott------date:20191016-------for:excel导入数字类型,去掉后缀.0------
 | 
				
			|||
					return ExcelUtil.remove0Suffix(result); | 
				
			|||
					//---update-end-----autor:scott------date:20191016-------for:excel导入数字类型,去掉后缀.0------
 | 
				
			|||
				} | 
				
			|||
				// double类型防止科学计数法
 | 
				
			|||
				if (result instanceof Double) { | 
				
			|||
					return PoiPublicUtil.doubleToString((Double) result); | 
				
			|||
				} | 
				
			|||
				//---update-begin-----autor:scott------date:20191016-------for:excel导入数字类型,去掉后缀.0------
 | 
				
			|||
				return ExcelUtil.remove0Suffix(String.valueOf(result)); | 
				
			|||
				//---update-end-----autor:scott------date:20191016-------for:excel导入数字类型,去掉后缀.0------
 | 
				
			|||
			} | 
				
			|||
			return result; | 
				
			|||
		} catch (Exception e) { | 
				
			|||
			LOGGER.error(e.getMessage(), e); | 
				
			|||
			throw new ExcelImportException(ExcelImportEnum.GET_VALUE_ERROR); | 
				
			|||
		} | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 调用处理接口处理值 | 
				
			|||
	 * | 
				
			|||
	 * @param dataHanlder | 
				
			|||
	 * @param object | 
				
			|||
	 * @param result | 
				
			|||
	 * @param titleString | 
				
			|||
	 * @return | 
				
			|||
	 */ | 
				
			|||
	private Object hanlderValue(IExcelDataHandler dataHanlder, Object object, Object result, String titleString) { | 
				
			|||
		if (dataHanlder == null || dataHanlder.getNeedHandlerFields() == null || dataHanlder.getNeedHandlerFields().length == 0) { | 
				
			|||
			return result; | 
				
			|||
		} | 
				
			|||
		if (hanlderList == null) { | 
				
			|||
			hanlderList = Arrays.asList(dataHanlder.getNeedHandlerFields()); | 
				
			|||
		} | 
				
			|||
		if (hanlderList.contains(titleString)) { | 
				
			|||
			return dataHanlder.importHandler(object, titleString, result); | 
				
			|||
		} | 
				
			|||
		return result; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	//update-begin-author:taoyan date:20180807 for:导入多值替换--
 | 
				
			|||
	/** | 
				
			|||
	 * 导入支持多值替换 | 
				
			|||
	 * @param replace 数据库中字典查询出来的数组 | 
				
			|||
	 * @param result excel单元格获取的值 | 
				
			|||
	 * @param multiReplace 是否支持多值替换 | 
				
			|||
	 * @author taoYan | 
				
			|||
	 * @since 2018年8月7日 | 
				
			|||
	 */ | 
				
			|||
	private Object replaceValue(String[] replace, Object result,boolean multiReplace) { | 
				
			|||
		if(result == null){ | 
				
			|||
			return ""; | 
				
			|||
		} | 
				
			|||
		if(replace == null || replace.length<=0){ | 
				
			|||
			return result; | 
				
			|||
		} | 
				
			|||
		String temp = String.valueOf(result); | 
				
			|||
		String backValue = ""; | 
				
			|||
		if(temp.indexOf(",")>0 && multiReplace){ | 
				
			|||
			//原值中带有逗号,认为他是多值的
 | 
				
			|||
			String multiReplaces[] = temp.split(","); | 
				
			|||
			for (String str : multiReplaces) { | 
				
			|||
				backValue = backValue.concat(replaceSingleValue(replace, str)+","); | 
				
			|||
			} | 
				
			|||
			if(backValue.equals("")){ | 
				
			|||
				backValue = temp; | 
				
			|||
			}else{ | 
				
			|||
				backValue = backValue.substring(0, backValue.length()-1); | 
				
			|||
			} | 
				
			|||
		}else{ | 
				
			|||
			backValue = replaceSingleValue(replace, temp); | 
				
			|||
		} | 
				
			|||
		return backValue; | 
				
			|||
	} | 
				
			|||
	/** | 
				
			|||
	 * 单值替换 ,若没找到则原值返回 | 
				
			|||
	 */ | 
				
			|||
	private String replaceSingleValue(String[] replace, String temp){ | 
				
			|||
		String[] tempArr; | 
				
			|||
		for (int i = 0; i < replace.length; i++) { | 
				
			|||
			tempArr = replace[i].split("_"); | 
				
			|||
			if (temp.equals(tempArr[0])) { | 
				
			|||
				return tempArr[1]; | 
				
			|||
			} | 
				
			|||
		} | 
				
			|||
		return temp; | 
				
			|||
	} | 
				
			|||
	//update-end-author:taoyan date:20180807 for:导入多值替换--
 | 
				
			|||
} | 
				
			|||
@ -0,0 +1,491 @@ | 
				
			|||
/** | 
				
			|||
 * Copyright 2013-2015 JEECG (jeecgos@163.com) | 
				
			|||
 * <p> | 
				
			|||
 * Licensed under the Apache License, Version 2.0 (the "License"); | 
				
			|||
 * you may not use this file except in compliance with the License. | 
				
			|||
 * You may obtain a copy of the License at | 
				
			|||
 * <p> | 
				
			|||
 * http://www.apache.org/licenses/LICENSE-2.0
 | 
				
			|||
 * <p> | 
				
			|||
 * Unless required by applicable law or agreed to in writing, software | 
				
			|||
 * distributed under the License is distributed on an "AS IS" BASIS, | 
				
			|||
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | 
				
			|||
 * See the License for the specific language governing permissions and | 
				
			|||
 * limitations under the License. | 
				
			|||
 */ | 
				
			|||
package cc.admin.poi.excel.imports; | 
				
			|||
 | 
				
			|||
import cc.admin.core.util.ApplicationContextUtil; | 
				
			|||
import cc.admin.poi.excel.annotation.ExcelTarget; | 
				
			|||
import cc.admin.poi.excel.entity.ImportParams; | 
				
			|||
import cc.admin.poi.excel.entity.params.ExcelCollectionParams; | 
				
			|||
import cc.admin.poi.excel.entity.params.ExcelImportEntity; | 
				
			|||
import cc.admin.poi.excel.entity.result.ExcelImportResult; | 
				
			|||
import cc.admin.poi.excel.entity.result.ExcelVerifyHanlderResult; | 
				
			|||
import cc.admin.poi.excel.imports.base.ImportBaseService; | 
				
			|||
import cc.admin.poi.excel.imports.base.ImportFileServiceI; | 
				
			|||
import cc.admin.poi.excel.imports.verifys.VerifyHandlerServer; | 
				
			|||
import cc.admin.poi.exception.excel.ExcelImportException; | 
				
			|||
import cc.admin.poi.exception.excel.enums.ExcelImportEnum; | 
				
			|||
import cc.admin.poi.util.ExcelUtil; | 
				
			|||
import cc.admin.poi.util.PoiPublicUtil; | 
				
			|||
import org.apache.commons.lang3.StringUtils; | 
				
			|||
import org.apache.poi.hssf.usermodel.HSSFSheet; | 
				
			|||
import org.apache.poi.hssf.usermodel.HSSFWorkbook; | 
				
			|||
import org.apache.poi.ss.formula.functions.T; | 
				
			|||
import org.apache.poi.ss.usermodel.*; | 
				
			|||
import org.apache.poi.xssf.usermodel.XSSFSheet; | 
				
			|||
import org.apache.poi.xssf.usermodel.XSSFWorkbook; | 
				
			|||
import org.slf4j.Logger; | 
				
			|||
import org.slf4j.LoggerFactory; | 
				
			|||
 | 
				
			|||
import java.io.File; | 
				
			|||
import java.io.FileOutputStream; | 
				
			|||
import java.io.InputStream; | 
				
			|||
import java.io.PushbackInputStream; | 
				
			|||
import java.lang.reflect.Field; | 
				
			|||
import java.util.*; | 
				
			|||
 | 
				
			|||
/** | 
				
			|||
 * Excel 导入服务 | 
				
			|||
 * | 
				
			|||
 * @author JEECG | 
				
			|||
 * @date 2014年6月26日 下午9:20:51 | 
				
			|||
 */ | 
				
			|||
@SuppressWarnings({"rawtypes", "unchecked", "hiding"}) | 
				
			|||
public class ExcelImportServer extends ImportBaseService { | 
				
			|||
 | 
				
			|||
    private final static Logger LOGGER = LoggerFactory.getLogger(ExcelImportServer.class); | 
				
			|||
 | 
				
			|||
    private CellValueServer cellValueServer; | 
				
			|||
 | 
				
			|||
    private VerifyHandlerServer verifyHandlerServer; | 
				
			|||
 | 
				
			|||
    private boolean verfiyFail = false; | 
				
			|||
    /** | 
				
			|||
     * 异常数据styler | 
				
			|||
     */ | 
				
			|||
    private CellStyle errorCellStyle; | 
				
			|||
 | 
				
			|||
    public ExcelImportServer() { | 
				
			|||
        this.cellValueServer = new CellValueServer(); | 
				
			|||
        this.verifyHandlerServer = new VerifyHandlerServer(); | 
				
			|||
    } | 
				
			|||
 | 
				
			|||
    /*** | 
				
			|||
     * 向List里面继续添加元素 | 
				
			|||
     * | 
				
			|||
     * @param object | 
				
			|||
     * @param param | 
				
			|||
     * @param row | 
				
			|||
     * @param titlemap | 
				
			|||
     * @param targetId | 
				
			|||
     * @param pictures | 
				
			|||
     * @param params | 
				
			|||
     */ | 
				
			|||
    private void addListContinue(Object object, ExcelCollectionParams param, Row row, Map<Integer, String> titlemap, String targetId, Map<String, PictureData> pictures, ImportParams params) throws Exception { | 
				
			|||
        Collection collection = (Collection) PoiPublicUtil.getMethod(param.getName(), object.getClass()).invoke(object, new Object[]{}); | 
				
			|||
        Object entity = PoiPublicUtil.createObject(param.getType(), targetId); | 
				
			|||
        String picId; | 
				
			|||
        boolean isUsed = false;// 是否需要加上这个对象
 | 
				
			|||
        for (int i = row.getFirstCellNum(); i < row.getLastCellNum(); i++) { | 
				
			|||
            Cell cell = row.getCell(i); | 
				
			|||
            String titleString = (String) titlemap.get(i); | 
				
			|||
            if (param.getExcelParams().containsKey(titleString)) { | 
				
			|||
                if (param.getExcelParams().get(titleString).getType() == 2) { | 
				
			|||
                    picId = row.getRowNum() + "_" + i; | 
				
			|||
                    saveImage(object, picId, param.getExcelParams(), titleString, pictures, params); | 
				
			|||
                } else { | 
				
			|||
                    saveFieldValue(params, entity, cell, param.getExcelParams(), titleString, row); | 
				
			|||
                } | 
				
			|||
                isUsed = true; | 
				
			|||
            } | 
				
			|||
        } | 
				
			|||
        if (isUsed) { | 
				
			|||
            collection.add(entity); | 
				
			|||
        } | 
				
			|||
    } | 
				
			|||
 | 
				
			|||
    /** | 
				
			|||
     * 获取key的值,针对不同类型获取不同的值 | 
				
			|||
     * | 
				
			|||
     * @Author JEECG | 
				
			|||
     * @date 2013-11-21 | 
				
			|||
     * @param cell | 
				
			|||
     * @return | 
				
			|||
     */ | 
				
			|||
    private String getKeyValue(Cell cell) { | 
				
			|||
        if (cell == null) { | 
				
			|||
            return null; | 
				
			|||
        } | 
				
			|||
        Object obj = null; | 
				
			|||
        switch (cell.getCellType()) { | 
				
			|||
            case STRING: | 
				
			|||
                obj = cell.getStringCellValue(); | 
				
			|||
                break; | 
				
			|||
            case BOOLEAN: | 
				
			|||
                obj = cell.getBooleanCellValue(); | 
				
			|||
                break; | 
				
			|||
            case NUMERIC: | 
				
			|||
                obj = cell.getNumericCellValue(); | 
				
			|||
                break; | 
				
			|||
            case FORMULA: | 
				
			|||
                obj = cell.getCellFormula(); | 
				
			|||
                break; | 
				
			|||
        } | 
				
			|||
        return obj == null ? null : obj.toString().trim(); | 
				
			|||
    } | 
				
			|||
 | 
				
			|||
    /** | 
				
			|||
     * 获取保存的真实路径 | 
				
			|||
     * | 
				
			|||
     * @param excelImportEntity | 
				
			|||
     * @param object | 
				
			|||
     * @return | 
				
			|||
     * @throws Exception | 
				
			|||
     */ | 
				
			|||
    private String getSaveUrl(ExcelImportEntity excelImportEntity, Object object) throws Exception { | 
				
			|||
        String url = ""; | 
				
			|||
        if (excelImportEntity.getSaveUrl().equals("upload")) { | 
				
			|||
            if (excelImportEntity.getMethods() != null && excelImportEntity.getMethods().size() > 0) { | 
				
			|||
                object = getFieldBySomeMethod(excelImportEntity.getMethods(), object); | 
				
			|||
            } | 
				
			|||
            url = object.getClass().getName().split("\\.")[object.getClass().getName().split("\\.").length - 1]; | 
				
			|||
            return excelImportEntity.getSaveUrl() + "/" + url.substring(0, url.lastIndexOf("Entity")); | 
				
			|||
        } | 
				
			|||
        return excelImportEntity.getSaveUrl(); | 
				
			|||
    } | 
				
			|||
 | 
				
			|||
    //update-begin--Author:xuelin  Date:20171205 for:TASK #2098 【excel问题】 Online 一对多导入失败--------------------
 | 
				
			|||
    private <T> List<T> importExcel(Collection<T> result, Sheet sheet, Class<?> pojoClass, ImportParams params, Map<String, PictureData> pictures) throws Exception { | 
				
			|||
        List collection = new ArrayList(); | 
				
			|||
        Map<String, ExcelImportEntity> excelParams = new HashMap<String, ExcelImportEntity>(); | 
				
			|||
        List<ExcelCollectionParams> excelCollection = new ArrayList<ExcelCollectionParams>(); | 
				
			|||
        String targetId = null; | 
				
			|||
        if (!Map.class.equals(pojoClass)) { | 
				
			|||
            Field fileds[] = PoiPublicUtil.getClassFields(pojoClass); | 
				
			|||
            ExcelTarget etarget = pojoClass.getAnnotation(ExcelTarget.class); | 
				
			|||
            if (etarget != null) { | 
				
			|||
                targetId = etarget.value(); | 
				
			|||
            } | 
				
			|||
            getAllExcelField(targetId, fileds, excelParams, excelCollection, pojoClass, null); | 
				
			|||
        } | 
				
			|||
        ignoreHeaderHandler(excelParams, params); | 
				
			|||
        Iterator<Row> rows = sheet.rowIterator(); | 
				
			|||
        Map<Integer, String> titlemap = getTitleMap(sheet, rows, params, excelCollection); | 
				
			|||
        Set<Integer> columnIndexSet = titlemap.keySet(); | 
				
			|||
        Integer maxColumnIndex = Collections.max(columnIndexSet); | 
				
			|||
        Integer minColumnIndex = Collections.min(columnIndexSet); | 
				
			|||
        Row row = null; | 
				
			|||
        //跳过表头和标题行
 | 
				
			|||
        for (int j = 0; j < params.getTitleRows() + params.getHeadRows(); j++) { | 
				
			|||
            row = rows.next(); | 
				
			|||
        } | 
				
			|||
        Object object = null; | 
				
			|||
        String picId; | 
				
			|||
        while (rows.hasNext() && (row == null || sheet.getLastRowNum() - row.getRowNum() > params.getLastOfInvalidRow())) { | 
				
			|||
            row = rows.next(); | 
				
			|||
            //update-begin--Author:xuelin  Date:20171017 for:TASK #2373 【bug】表改造问题,导致 3.7.1批量导入用户bug-导入不成功--------------------
 | 
				
			|||
            // 判断是集合元素还是不是集合元素,如果是就继续加入这个集合,不是就创建新的对象
 | 
				
			|||
            //update-begin--Author:xuelin  Date:20171206 for:TASK #2451 【excel导出bug】online 一对多导入成功, 但是现在代码生成后的一对多online导入有问题了
 | 
				
			|||
            Cell keyIndexCell = row.getCell(params.getKeyIndex()); | 
				
			|||
            if (excelCollection.size() > 0 && StringUtils.isEmpty(getKeyValue(keyIndexCell)) && object != null && !Map.class.equals(pojoClass)) { | 
				
			|||
                //update-end--Author:xuelin  Date:20171206 for:TASK #2451 【excel导出bug】online 一对多导入成功, 但是现在代码生成后的一对多online导入有问题了
 | 
				
			|||
                for (ExcelCollectionParams param : excelCollection) { | 
				
			|||
                    addListContinue(object, param, row, titlemap, targetId, pictures, params); | 
				
			|||
                } | 
				
			|||
 | 
				
			|||
            } else { | 
				
			|||
                object = PoiPublicUtil.createObject(pojoClass, targetId); | 
				
			|||
                try { | 
				
			|||
                    //update-begin-author:taoyan date:20200303 for:导入图片
 | 
				
			|||
                    int firstCellNum = row.getFirstCellNum(); | 
				
			|||
                    if (firstCellNum > minColumnIndex) { | 
				
			|||
                        firstCellNum = minColumnIndex; | 
				
			|||
                    } | 
				
			|||
                    int lastCellNum = row.getLastCellNum(); | 
				
			|||
                    if (lastCellNum < maxColumnIndex + 1) { | 
				
			|||
                        lastCellNum = maxColumnIndex + 1; | 
				
			|||
                    } | 
				
			|||
                    for (int i = firstCellNum, le = lastCellNum; i < le; i++) { | 
				
			|||
                        Cell cell = row.getCell(i); | 
				
			|||
                        String titleString = (String) titlemap.get(i); | 
				
			|||
                        if (excelParams.containsKey(titleString) || Map.class.equals(pojoClass)) { | 
				
			|||
                            if (excelParams.get(titleString) != null && excelParams.get(titleString).getType() == 2) { | 
				
			|||
                                picId = row.getRowNum() + "_" + i; | 
				
			|||
                                saveImage(object, picId, excelParams, titleString, pictures, params); | 
				
			|||
                            } else { | 
				
			|||
                                if (params.getImageList() != null && params.getImageList().contains(titleString)) { | 
				
			|||
                                    if (pictures != null) { | 
				
			|||
                                        picId = row.getRowNum() + "_" + i; | 
				
			|||
                                        PictureData image = pictures.get(picId); | 
				
			|||
                                        if (image != null) { | 
				
			|||
                                            byte[] data = image.getData(); | 
				
			|||
                                            params.getDataHanlder().setMapValue((Map) object, titleString, data); | 
				
			|||
                                        } | 
				
			|||
                                    } | 
				
			|||
                                } else { | 
				
			|||
                                    saveFieldValue(params, object, cell, excelParams, titleString, row); | 
				
			|||
                                } | 
				
			|||
                                //update-end-author:taoyan date:20200303 for:导入图片
 | 
				
			|||
                            } | 
				
			|||
                        } | 
				
			|||
                    } | 
				
			|||
 | 
				
			|||
                    for (ExcelCollectionParams param : excelCollection) { | 
				
			|||
                        addListContinue(object, param, row, titlemap, targetId, pictures, params); | 
				
			|||
                    } | 
				
			|||
                    collection.add(object); | 
				
			|||
                } catch (ExcelImportException e) { | 
				
			|||
                    if (!e.getType().equals(ExcelImportEnum.VERIFY_ERROR)) { | 
				
			|||
                        throw new ExcelImportException(e.getType(), e); | 
				
			|||
                    } | 
				
			|||
                } | 
				
			|||
            } | 
				
			|||
            //update-end--Author:xuelin  Date:20171017 for:TASK #2373 【bug】表改造问题,导致 3.7.1批量导入用户bug-导入不成功--------------------
 | 
				
			|||
        } | 
				
			|||
        return collection; | 
				
			|||
    } | 
				
			|||
 | 
				
			|||
    /** | 
				
			|||
     * 获取忽略的表头信息 | 
				
			|||
     * @param excelParams | 
				
			|||
     * @param params | 
				
			|||
     */ | 
				
			|||
    private void ignoreHeaderHandler(Map<String, ExcelImportEntity> excelParams, ImportParams params) { | 
				
			|||
        List<String> ignoreList = new ArrayList<>(); | 
				
			|||
        for (String key : excelParams.keySet()) { | 
				
			|||
            String temp = excelParams.get(key).getGroupName(); | 
				
			|||
            if (temp != null && temp.length() > 0) { | 
				
			|||
                ignoreList.add(temp); | 
				
			|||
            } | 
				
			|||
        } | 
				
			|||
        params.setIgnoreHeaderList(ignoreList); | 
				
			|||
    } | 
				
			|||
 | 
				
			|||
    /** | 
				
			|||
     * 获取表格字段列名对应信息 | 
				
			|||
     * | 
				
			|||
     * @param rows | 
				
			|||
     * @param params | 
				
			|||
     * @param excelCollection | 
				
			|||
     * @return | 
				
			|||
     */ | 
				
			|||
    private Map<Integer, String> getTitleMap(Sheet sheet, Iterator<Row> rows, ImportParams params, List<ExcelCollectionParams> excelCollection) { | 
				
			|||
        Map<Integer, String> titlemap = new HashMap<Integer, String>(); | 
				
			|||
        Iterator<Cell> cellTitle = null; | 
				
			|||
        String collectionName = null; | 
				
			|||
        ExcelCollectionParams collectionParams = null; | 
				
			|||
        Row headRow = null; | 
				
			|||
        int headBegin = params.getTitleRows(); | 
				
			|||
        //找到首行表头,每个sheet都必须至少有一行表头
 | 
				
			|||
        while (headRow == null) { | 
				
			|||
            headRow = sheet.getRow(headBegin++); | 
				
			|||
        } | 
				
			|||
        //设置表头行数
 | 
				
			|||
        if (ExcelUtil.isMergedRegion(sheet, headRow.getRowNum(), 0)) { | 
				
			|||
            params.setHeadRows(2); | 
				
			|||
        } else { | 
				
			|||
            params.setHeadRows(1); | 
				
			|||
        } | 
				
			|||
        cellTitle = headRow.cellIterator(); | 
				
			|||
        while (cellTitle.hasNext()) { | 
				
			|||
            Cell cell = cellTitle.next(); | 
				
			|||
            String value = getKeyValue(cell); | 
				
			|||
            if (StringUtils.isNotEmpty(value)) { | 
				
			|||
                titlemap.put(cell.getColumnIndex(), value);//加入表头列表
 | 
				
			|||
            } | 
				
			|||
        } | 
				
			|||
 | 
				
			|||
        //多行表头
 | 
				
			|||
        for (int j = headBegin; j < headBegin + params.getHeadRows() - 1; j++) { | 
				
			|||
            headRow = sheet.getRow(j); | 
				
			|||
            cellTitle = headRow.cellIterator(); | 
				
			|||
            while (cellTitle.hasNext()) { | 
				
			|||
                Cell cell = cellTitle.next(); | 
				
			|||
                String value = getKeyValue(cell); | 
				
			|||
                if (StringUtils.isNotEmpty(value)) { | 
				
			|||
                    int columnIndex = cell.getColumnIndex(); | 
				
			|||
                    //当前cell的上一行是否为合并单元格
 | 
				
			|||
                    if (ExcelUtil.isMergedRegion(sheet, cell.getRowIndex() - 1, columnIndex)) { | 
				
			|||
                        collectionName = ExcelUtil.getMergedRegionValue(sheet, cell.getRowIndex() - 1, columnIndex); | 
				
			|||
                        if (params.isIgnoreHeader(collectionName)) { | 
				
			|||
                            titlemap.put(cell.getColumnIndex(), value); | 
				
			|||
                        } else { | 
				
			|||
                            titlemap.put(cell.getColumnIndex(), collectionName + "_" + value); | 
				
			|||
                        } | 
				
			|||
                    } else { | 
				
			|||
                        titlemap.put(cell.getColumnIndex(), value); | 
				
			|||
                    } | 
				
			|||
					/*int i = cell.getColumnIndex(); | 
				
			|||
					// 用以支持重名导入
 | 
				
			|||
					if (titlemap.containsKey(i)) { | 
				
			|||
						collectionName = titlemap.get(i); | 
				
			|||
						collectionParams = getCollectionParams(excelCollection, collectionName); | 
				
			|||
						titlemap.put(i, collectionName + "_" + value); | 
				
			|||
					} else if (StringUtils.isNotEmpty(collectionName) && collectionParams.getExcelParams().containsKey(collectionName + "_" + value)) { | 
				
			|||
						titlemap.put(i, collectionName + "_" + value); | 
				
			|||
					} else { | 
				
			|||
						collectionName = null; | 
				
			|||
						collectionParams = null; | 
				
			|||
					} | 
				
			|||
					if (StringUtils.isEmpty(collectionName)) { | 
				
			|||
						titlemap.put(i, value); | 
				
			|||
					}*/ | 
				
			|||
                } | 
				
			|||
            } | 
				
			|||
        } | 
				
			|||
        return titlemap; | 
				
			|||
    } | 
				
			|||
    //update-end--Author:xuelin  Date:20171205 for:TASK #2098 【excel问题】 Online 一对多导入失败--------------------
 | 
				
			|||
 | 
				
			|||
    /** | 
				
			|||
     * 获取这个名称对应的集合信息 | 
				
			|||
     * | 
				
			|||
     * @param excelCollection | 
				
			|||
     * @param collectionName | 
				
			|||
     * @return | 
				
			|||
     */ | 
				
			|||
    private ExcelCollectionParams getCollectionParams(List<ExcelCollectionParams> excelCollection, String collectionName) { | 
				
			|||
        for (ExcelCollectionParams excelCollectionParams : excelCollection) { | 
				
			|||
            if (collectionName.equals(excelCollectionParams.getExcelName())) { | 
				
			|||
                return excelCollectionParams; | 
				
			|||
            } | 
				
			|||
        } | 
				
			|||
        return null; | 
				
			|||
    } | 
				
			|||
 | 
				
			|||
    /** | 
				
			|||
     * Excel 导入 field 字段类型 Integer,Long,Double,Date,String,Boolean | 
				
			|||
     * | 
				
			|||
     * @param inputstream | 
				
			|||
     * @param pojoClass | 
				
			|||
     * @param params | 
				
			|||
     * @return | 
				
			|||
     * @throws Exception | 
				
			|||
     */ | 
				
			|||
    public ExcelImportResult importExcelByIs(InputStream inputstream, Class<?> pojoClass, ImportParams params) throws Exception { | 
				
			|||
        if (LOGGER.isDebugEnabled()) { | 
				
			|||
            LOGGER.debug("Excel import start ,class is {}", pojoClass); | 
				
			|||
        } | 
				
			|||
        List<T> result = new ArrayList<T>(); | 
				
			|||
        Workbook book = null; | 
				
			|||
        boolean isXSSFWorkbook = true; | 
				
			|||
        if (!(inputstream.markSupported())) { | 
				
			|||
            inputstream = new PushbackInputStream(inputstream, 8); | 
				
			|||
        } | 
				
			|||
        book = WorkbookFactory.create(inputstream); | 
				
			|||
        createErrorCellStyle(book); | 
				
			|||
        Map<String, PictureData> pictures; | 
				
			|||
        for (int i = 0; i < params.getSheetNum(); i++) { | 
				
			|||
            if (LOGGER.isDebugEnabled()) { | 
				
			|||
                LOGGER.debug(" start to read excel by is ,startTime is {}", new Date().getTime()); | 
				
			|||
            } | 
				
			|||
            if (isXSSFWorkbook) { | 
				
			|||
                pictures = PoiPublicUtil.getSheetPictrues07((XSSFSheet) book.getSheetAt(i), (XSSFWorkbook) book); | 
				
			|||
            } else { | 
				
			|||
                pictures = PoiPublicUtil.getSheetPictrues03((HSSFSheet) book.getSheetAt(i), (HSSFWorkbook) book); | 
				
			|||
            } | 
				
			|||
            if (LOGGER.isDebugEnabled()) { | 
				
			|||
                LOGGER.debug(" end to read excel by is ,endTime is {}", new Date().getTime()); | 
				
			|||
            } | 
				
			|||
            result.addAll(importExcel(result, book.getSheetAt(i), pojoClass, params, pictures)); | 
				
			|||
            if (LOGGER.isDebugEnabled()) { | 
				
			|||
                LOGGER.debug(" end to read excel list by pos ,endTime is {}", new Date().getTime()); | 
				
			|||
            } | 
				
			|||
        } | 
				
			|||
        if (params.isNeedSave()) { | 
				
			|||
            saveThisExcel(params, pojoClass, isXSSFWorkbook, book); | 
				
			|||
        } | 
				
			|||
        return new ExcelImportResult(result, verfiyFail, book); | 
				
			|||
    } | 
				
			|||
 | 
				
			|||
    /** | 
				
			|||
     * 保存字段值(获取值,校验值,追加错误信息) | 
				
			|||
     * | 
				
			|||
     * @param params | 
				
			|||
     * @param object | 
				
			|||
     * @param cell | 
				
			|||
     * @param excelParams | 
				
			|||
     * @param titleString | 
				
			|||
     * @param row | 
				
			|||
     * @throws Exception | 
				
			|||
     */ | 
				
			|||
    private void saveFieldValue(ImportParams params, Object object, Cell cell, Map<String, ExcelImportEntity> excelParams, String titleString, Row row) throws Exception { | 
				
			|||
        Object value = cellValueServer.getValue(params.getDataHanlder(), object, cell, excelParams, titleString); | 
				
			|||
        if (object instanceof Map) { | 
				
			|||
            if (params.getDataHanlder() != null) { | 
				
			|||
                params.getDataHanlder().setMapValue((Map) object, titleString, value); | 
				
			|||
            } else { | 
				
			|||
                ((Map) object).put(titleString, value); | 
				
			|||
            } | 
				
			|||
        } else { | 
				
			|||
            ExcelVerifyHanlderResult verifyResult = verifyHandlerServer.verifyData(object, value, titleString, excelParams.get(titleString).getVerify(), params.getVerifyHanlder()); | 
				
			|||
            if (verifyResult.isSuccess()) { | 
				
			|||
                setValues(excelParams.get(titleString), object, value); | 
				
			|||
            } else { | 
				
			|||
                Cell errorCell = row.createCell(row.getLastCellNum()); | 
				
			|||
                errorCell.setCellValue(verifyResult.getMsg()); | 
				
			|||
                errorCell.setCellStyle(errorCellStyle); | 
				
			|||
                verfiyFail = true; | 
				
			|||
                throw new ExcelImportException(ExcelImportEnum.VERIFY_ERROR); | 
				
			|||
            } | 
				
			|||
        } | 
				
			|||
    } | 
				
			|||
 | 
				
			|||
    /** | 
				
			|||
     * | 
				
			|||
     * @param object | 
				
			|||
     * @param picId | 
				
			|||
     * @param excelParams | 
				
			|||
     * @param titleString | 
				
			|||
     * @param pictures | 
				
			|||
     * @param params | 
				
			|||
     * @throws Exception | 
				
			|||
     */ | 
				
			|||
    private void saveImage(Object object, String picId, Map<String, ExcelImportEntity> excelParams, String titleString, Map<String, PictureData> pictures, ImportParams params) throws Exception { | 
				
			|||
        if (pictures == null || pictures.get(picId) == null) { | 
				
			|||
            return; | 
				
			|||
        } | 
				
			|||
        PictureData image = pictures.get(picId); | 
				
			|||
        byte[] data = image.getData(); | 
				
			|||
        String fileName = "pic" + Math.round(Math.random() * 100000000000L); | 
				
			|||
        fileName += "." + PoiPublicUtil.getFileExtendName(data); | 
				
			|||
        //update-beign-author:taoyan date:20200302 for:【多任务】online 专项集中问题 LOWCOD-159
 | 
				
			|||
        int saveType = excelParams.get(titleString).getSaveType(); | 
				
			|||
        if (saveType == 1) { | 
				
			|||
            String path = PoiPublicUtil.getWebRootPath(getSaveUrl(excelParams.get(titleString), object)); | 
				
			|||
            File savefile = new File(path); | 
				
			|||
            if (!savefile.exists()) { | 
				
			|||
                savefile.mkdirs(); | 
				
			|||
            } | 
				
			|||
            savefile = new File(path + "/" + fileName); | 
				
			|||
            FileOutputStream fos = new FileOutputStream(savefile); | 
				
			|||
            fos.write(data); | 
				
			|||
            fos.close(); | 
				
			|||
            setValues(excelParams.get(titleString), object, getSaveUrl(excelParams.get(titleString), object) + "/" + fileName); | 
				
			|||
        } else if (saveType == 2) { | 
				
			|||
            setValues(excelParams.get(titleString), object, data); | 
				
			|||
        } else { | 
				
			|||
            ImportFileServiceI importFileService = null; | 
				
			|||
            try { | 
				
			|||
                importFileService = ApplicationContextUtil.getContext().getBean(ImportFileServiceI.class); | 
				
			|||
            } catch (Exception e) { | 
				
			|||
                System.err.println(e.getMessage()); | 
				
			|||
            } | 
				
			|||
            if (importFileService != null) { | 
				
			|||
                String dbPath = importFileService.doUpload(data); | 
				
			|||
                setValues(excelParams.get(titleString), object, dbPath); | 
				
			|||
            } | 
				
			|||
        } | 
				
			|||
        //update-end-author:taoyan date:20200302 for:【多任务】online 专项集中问题 LOWCOD-159
 | 
				
			|||
    } | 
				
			|||
 | 
				
			|||
    private void createErrorCellStyle(Workbook workbook) { | 
				
			|||
        errorCellStyle = workbook.createCellStyle(); | 
				
			|||
        Font font = workbook.createFont(); | 
				
			|||
        font.setColor(Font.COLOR_RED); | 
				
			|||
        errorCellStyle.setFont(font); | 
				
			|||
    } | 
				
			|||
 | 
				
			|||
} | 
				
			|||
@ -0,0 +1,302 @@ | 
				
			|||
/** | 
				
			|||
 * Copyright 2013-2015 JEECG (jeecgos@163.com) | 
				
			|||
 * | 
				
			|||
 *  Licensed under the Apache License, Version 2.0 (the "License"); | 
				
			|||
 *  you may not use this file except in compliance with the License. | 
				
			|||
 *  You may obtain a copy of the License at | 
				
			|||
 * | 
				
			|||
 *     http://www.apache.org/licenses/LICENSE-2.0
 | 
				
			|||
 * | 
				
			|||
 *  Unless required by applicable law or agreed to in writing, software | 
				
			|||
 * distributed under the License is distributed on an "AS IS" BASIS, | 
				
			|||
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | 
				
			|||
 * See the License for the specific language governing permissions and | 
				
			|||
 * limitations under the License. | 
				
			|||
 */ | 
				
			|||
package cc.admin.poi.excel.imports.base; | 
				
			|||
 | 
				
			|||
import java.io.File; | 
				
			|||
import java.io.FileOutputStream; | 
				
			|||
import java.lang.reflect.Field; | 
				
			|||
import java.lang.reflect.Method; | 
				
			|||
import java.lang.reflect.ParameterizedType; | 
				
			|||
import java.text.SimpleDateFormat; | 
				
			|||
import java.util.ArrayList; | 
				
			|||
import java.util.Date; | 
				
			|||
import java.util.HashMap; | 
				
			|||
import java.util.HashSet; | 
				
			|||
import java.util.List; | 
				
			|||
import java.util.Map; | 
				
			|||
import java.util.Set; | 
				
			|||
 | 
				
			|||
import cc.admin.poi.excel.entity.ImportParams; | 
				
			|||
import cc.admin.poi.excel.entity.params.ExcelCollectionParams; | 
				
			|||
import cc.admin.poi.excel.entity.params.ExcelImportEntity; | 
				
			|||
import cc.admin.poi.excel.entity.params.ExcelVerifyEntity; | 
				
			|||
import cc.admin.poi.util.PoiPublicUtil; | 
				
			|||
import org.apache.commons.lang3.StringUtils; | 
				
			|||
import org.apache.poi.ss.usermodel.Workbook; | 
				
			|||
import cc.admin.core.util.ApplicationContextUtil; | 
				
			|||
import cc.admin.dict.service.AutoPoiDictServiceI; | 
				
			|||
import cc.admin.poi.excel.annotation.Excel; | 
				
			|||
import cc.admin.poi.excel.annotation.ExcelCollection; | 
				
			|||
import cc.admin.poi.excel.annotation.ExcelVerify; | 
				
			|||
 | 
				
			|||
/** | 
				
			|||
 * 导入基础和,普通方法和Sax共用 | 
				
			|||
 * | 
				
			|||
 * @author JEECG | 
				
			|||
 * @date 2015年1月9日 下午10:25:53 | 
				
			|||
 */ | 
				
			|||
public class ImportBaseService { | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 把这个注解解析放到类型对象中 | 
				
			|||
	 * | 
				
			|||
	 * @param targetId | 
				
			|||
	 * @param field | 
				
			|||
	 * @param excelEntity | 
				
			|||
	 * @param pojoClass | 
				
			|||
	 * @param getMethods | 
				
			|||
	 * @param temp | 
				
			|||
	 * @throws Exception | 
				
			|||
	 */ | 
				
			|||
	public void addEntityToMap(String targetId, Field field, ExcelImportEntity excelEntity, Class<?> pojoClass, List<Method> getMethods, Map<String, ExcelImportEntity> temp) throws Exception { | 
				
			|||
		Excel excel = field.getAnnotation(Excel.class); | 
				
			|||
		excelEntity = new ExcelImportEntity(); | 
				
			|||
		excelEntity.setType(excel.type()); | 
				
			|||
		excelEntity.setSaveUrl(excel.savePath()); | 
				
			|||
		excelEntity.setSaveType(excel.imageType()); | 
				
			|||
		excelEntity.setReplace(excel.replace()); | 
				
			|||
		excelEntity.setDatabaseFormat(excel.databaseFormat()); | 
				
			|||
		excelEntity.setVerify(getImportVerify(field)); | 
				
			|||
		excelEntity.setSuffix(excel.suffix()); | 
				
			|||
		excelEntity.setNumFormat(excel.numFormat()); | 
				
			|||
		excelEntity.setGroupName(excel.groupName()); | 
				
			|||
		//update-begin-author:taoYan date:20180202 for:TASK #2067 【bug excel 问题】excel导入字典文本翻译问题
 | 
				
			|||
		excelEntity.setMultiReplace(excel.multiReplace()); | 
				
			|||
		if(StringUtils.isNotEmpty(excel.dicCode())){ | 
				
			|||
			AutoPoiDictServiceI ccDictService = null; | 
				
			|||
			try { | 
				
			|||
				ccDictService = ApplicationContextUtil.getContext().getBean(AutoPoiDictServiceI.class); | 
				
			|||
			} catch (Exception e) { | 
				
			|||
			} | 
				
			|||
			if(ccDictService!=null){ | 
				
			|||
				 String[] dictReplace = ccDictService.queryDict(excel.dictTable(), excel.dicCode(), excel.dicText()); | 
				
			|||
				 if(excelEntity.getReplace()!=null && dictReplace!=null && dictReplace.length!=0){ | 
				
			|||
					 excelEntity.setReplace(dictReplace); | 
				
			|||
				 } | 
				
			|||
			} | 
				
			|||
		} | 
				
			|||
		//update-end-author:taoYan date:20180202 for:TASK #2067 【bug excel 问题】excel导入字典文本翻译问题
 | 
				
			|||
		getExcelField(targetId, field, excelEntity, excel, pojoClass); | 
				
			|||
		if (getMethods != null) { | 
				
			|||
			List<Method> newMethods = new ArrayList<Method>(); | 
				
			|||
			newMethods.addAll(getMethods); | 
				
			|||
			newMethods.add(excelEntity.getMethod()); | 
				
			|||
			excelEntity.setMethods(newMethods); | 
				
			|||
		} | 
				
			|||
		temp.put(excelEntity.getName(), excelEntity); | 
				
			|||
 | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 获取导入校验参数 | 
				
			|||
	 * | 
				
			|||
	 * @param field | 
				
			|||
	 * @return | 
				
			|||
	 */ | 
				
			|||
	public ExcelVerifyEntity getImportVerify(Field field) { | 
				
			|||
		ExcelVerify verify = field.getAnnotation(ExcelVerify.class); | 
				
			|||
		if (verify != null) { | 
				
			|||
			ExcelVerifyEntity entity = new ExcelVerifyEntity(); | 
				
			|||
			entity.setEmail(verify.isEmail()); | 
				
			|||
			entity.setInterHandler(verify.interHandler()); | 
				
			|||
			entity.setMaxLength(verify.maxLength()); | 
				
			|||
			entity.setMinLength(verify.minLength()); | 
				
			|||
			entity.setMobile(verify.isMobile()); | 
				
			|||
			entity.setNotNull(verify.notNull()); | 
				
			|||
			entity.setRegex(verify.regex()); | 
				
			|||
			entity.setRegexTip(verify.regexTip()); | 
				
			|||
			entity.setTel(verify.isTel()); | 
				
			|||
			return entity; | 
				
			|||
		} | 
				
			|||
		return null; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 获取需要导出的全部字段 | 
				
			|||
	 * | 
				
			|||
	 * | 
				
			|||
	 * @param exclusions | 
				
			|||
	 * @param targetId | 
				
			|||
	 *            目标ID | 
				
			|||
	 * @param fields | 
				
			|||
	 * @param excelCollection | 
				
			|||
	 * @throws Exception | 
				
			|||
	 */ | 
				
			|||
	public void getAllExcelField(String targetId, Field[] fields, Map<String, ExcelImportEntity> excelParams, List<ExcelCollectionParams> excelCollection, Class<?> pojoClass, List<Method> getMethods) throws Exception { | 
				
			|||
		ExcelImportEntity excelEntity = null; | 
				
			|||
		for (int i = 0; i < fields.length; i++) { | 
				
			|||
			Field field = fields[i]; | 
				
			|||
			if (PoiPublicUtil.isNotUserExcelUserThis(null, field, targetId)) { | 
				
			|||
				continue; | 
				
			|||
			} | 
				
			|||
			if (PoiPublicUtil.isCollection(field.getType())) { | 
				
			|||
				// 集合对象设置属性
 | 
				
			|||
				ExcelCollectionParams collection = new ExcelCollectionParams(); | 
				
			|||
				collection.setName(field.getName()); | 
				
			|||
				Map<String, ExcelImportEntity> temp = new HashMap<String, ExcelImportEntity>(); | 
				
			|||
				ParameterizedType pt = (ParameterizedType) field.getGenericType(); | 
				
			|||
				Class<?> clz = (Class<?>) pt.getActualTypeArguments()[0]; | 
				
			|||
				collection.setType(clz); | 
				
			|||
				getExcelFieldList(targetId, PoiPublicUtil.getClassFields(clz), clz, temp, null); | 
				
			|||
				collection.setExcelParams(temp); | 
				
			|||
				collection.setExcelName(field.getAnnotation(ExcelCollection.class).name()); | 
				
			|||
				additionalCollectionName(collection); | 
				
			|||
				excelCollection.add(collection); | 
				
			|||
			} else if (PoiPublicUtil.isJavaClass(field)) { | 
				
			|||
				addEntityToMap(targetId, field, excelEntity, pojoClass, getMethods, excelParams); | 
				
			|||
			} else { | 
				
			|||
				List<Method> newMethods = new ArrayList<Method>(); | 
				
			|||
				if (getMethods != null) { | 
				
			|||
					newMethods.addAll(getMethods); | 
				
			|||
				} | 
				
			|||
				newMethods.add(PoiPublicUtil.getMethod(field.getName(), pojoClass)); | 
				
			|||
				getAllExcelField(targetId, PoiPublicUtil.getClassFields(field.getType()), excelParams, excelCollection, field.getType(), newMethods); | 
				
			|||
			} | 
				
			|||
		} | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 追加集合名称到前面 | 
				
			|||
	 * | 
				
			|||
	 * @param collection | 
				
			|||
	 */ | 
				
			|||
	private void additionalCollectionName(ExcelCollectionParams collection) { | 
				
			|||
		Set<String> keys = new HashSet<String>(); | 
				
			|||
		keys.addAll(collection.getExcelParams().keySet()); | 
				
			|||
		for (String key : keys) { | 
				
			|||
			collection.getExcelParams().put(collection.getExcelName() + "_" + key, collection.getExcelParams().get(key)); | 
				
			|||
			collection.getExcelParams().remove(key); | 
				
			|||
		} | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void getExcelField(String targetId, Field field, ExcelImportEntity excelEntity, Excel excel, Class<?> pojoClass) throws Exception { | 
				
			|||
		excelEntity.setName(getExcelName(excel.name(), targetId)); | 
				
			|||
		String fieldname = field.getName(); | 
				
			|||
		//update-begin-author:taoyan for:TASK #2798 【例子】导入扩展方法,支持自定义导入字段转换规则
 | 
				
			|||
		excelEntity.setMethod(PoiPublicUtil.getMethod(fieldname, pojoClass, field.getType(),excel.importConvert())); | 
				
			|||
		//update-end-author:taoyan for:TASK #2798 【例子】导入扩展方法,支持自定义导入字段转换规则
 | 
				
			|||
		if (StringUtils.isNotEmpty(excel.importFormat())) { | 
				
			|||
			excelEntity.setFormat(excel.importFormat()); | 
				
			|||
		} else { | 
				
			|||
			excelEntity.setFormat(excel.format()); | 
				
			|||
		} | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void getExcelFieldList(String targetId, Field[] fields, Class<?> pojoClass, Map<String, ExcelImportEntity> temp, List<Method> getMethods) throws Exception { | 
				
			|||
		ExcelImportEntity excelEntity = null; | 
				
			|||
		for (int i = 0; i < fields.length; i++) { | 
				
			|||
			Field field = fields[i]; | 
				
			|||
			if (PoiPublicUtil.isNotUserExcelUserThis(null, field, targetId)) { | 
				
			|||
				continue; | 
				
			|||
			} | 
				
			|||
			if (PoiPublicUtil.isJavaClass(field)) { | 
				
			|||
				addEntityToMap(targetId, field, excelEntity, pojoClass, getMethods, temp); | 
				
			|||
			} else { | 
				
			|||
				List<Method> newMethods = new ArrayList<Method>(); | 
				
			|||
				if (getMethods != null) { | 
				
			|||
					newMethods.addAll(getMethods); | 
				
			|||
				} | 
				
			|||
				newMethods.add(PoiPublicUtil.getMethod(field.getName(), pojoClass, field.getType())); | 
				
			|||
				getExcelFieldList(targetId, PoiPublicUtil.getClassFields(field.getType()), field.getType(), temp, newMethods); | 
				
			|||
			} | 
				
			|||
		} | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 判断在这个单元格显示的名称 | 
				
			|||
	 * | 
				
			|||
	 * @param exportName | 
				
			|||
	 * @param targetId | 
				
			|||
	 * @return | 
				
			|||
	 */ | 
				
			|||
	public String getExcelName(String exportName, String targetId) { | 
				
			|||
		if (exportName.indexOf("_") < 0) { | 
				
			|||
			return exportName; | 
				
			|||
		} | 
				
			|||
		String[] arr = exportName.split(","); | 
				
			|||
		for (String str : arr) { | 
				
			|||
			if (str.indexOf(targetId) != -1) { | 
				
			|||
				return str.split("_")[0]; | 
				
			|||
			} | 
				
			|||
		} | 
				
			|||
		return null; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public Object getFieldBySomeMethod(List<Method> list, Object t) throws Exception { | 
				
			|||
		Method m; | 
				
			|||
		for (int i = 0; i < list.size() - 1; i++) { | 
				
			|||
			m = list.get(i); | 
				
			|||
			t = m.invoke(t, new Object[] {}); | 
				
			|||
		} | 
				
			|||
		return t; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	public void saveThisExcel(ImportParams params, Class<?> pojoClass, boolean isXSSFWorkbook, Workbook book) throws Exception { | 
				
			|||
		String path = PoiPublicUtil.getWebRootPath(getSaveExcelUrl(params, pojoClass)); | 
				
			|||
		File savefile = new File(path); | 
				
			|||
		if (!savefile.exists()) { | 
				
			|||
			savefile.mkdirs(); | 
				
			|||
		} | 
				
			|||
		SimpleDateFormat format = new SimpleDateFormat("yyyMMddHHmmss"); | 
				
			|||
		FileOutputStream fos = new FileOutputStream(path + "/" + format.format(new Date()) + "_" + Math.round(Math.random() * 100000) + (isXSSFWorkbook == true ? ".xlsx" : ".xls")); | 
				
			|||
		book.write(fos); | 
				
			|||
		fos.close(); | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 获取保存的Excel 的真实路径 | 
				
			|||
	 * | 
				
			|||
	 * @param params | 
				
			|||
	 * @param pojoClass | 
				
			|||
	 * @return | 
				
			|||
	 * @throws Exception | 
				
			|||
	 */ | 
				
			|||
	public String getSaveExcelUrl(ImportParams params, Class<?> pojoClass) throws Exception { | 
				
			|||
		String url = ""; | 
				
			|||
		if (params.getSaveUrl().equals("upload/excelUpload")) { | 
				
			|||
			url = pojoClass.getName().split("\\.")[pojoClass.getName().split("\\.").length - 1]; | 
				
			|||
			return params.getSaveUrl() + "/" + url; | 
				
			|||
		} | 
				
			|||
		return params.getSaveUrl(); | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 多个get 最后再set | 
				
			|||
	 * | 
				
			|||
	 * @param setMethods | 
				
			|||
	 * @param object | 
				
			|||
	 */ | 
				
			|||
	public void setFieldBySomeMethod(List<Method> setMethods, Object object, Object value) throws Exception { | 
				
			|||
		Object t = getFieldBySomeMethod(setMethods, object); | 
				
			|||
		setMethods.get(setMethods.size() - 1).invoke(t, value); | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * | 
				
			|||
	 * @param entity | 
				
			|||
	 * @param object | 
				
			|||
	 * @param value | 
				
			|||
	 * @throws Exception | 
				
			|||
	 */ | 
				
			|||
	public void setValues(ExcelImportEntity entity, Object object, Object value) throws Exception { | 
				
			|||
		if (entity.getMethods() != null) { | 
				
			|||
			setFieldBySomeMethod(entity.getMethods(), object, value); | 
				
			|||
		} else { | 
				
			|||
			entity.getMethod().invoke(object, value); | 
				
			|||
		} | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
} | 
				
			|||
@ -0,0 +1,12 @@ | 
				
			|||
package cc.admin.poi.excel.imports.base; | 
				
			|||
 | 
				
			|||
public interface ImportFileServiceI { | 
				
			|||
 | 
				
			|||
    /** | 
				
			|||
     * 上传文件 返回文件地址字符串 | 
				
			|||
     * @param data | 
				
			|||
     * @return | 
				
			|||
     */ | 
				
			|||
    String doUpload(byte[] data); | 
				
			|||
 | 
				
			|||
} | 
				
			|||
@ -0,0 +1,6 @@ | 
				
			|||
/** | 
				
			|||
 * 导入类 | 
				
			|||
 * @author JEECG | 
				
			|||
 * @date 2014年6月23日 下午11:05:59 | 
				
			|||
 */ | 
				
			|||
package cc.admin.poi.excel.imports; | 
				
			|||
@ -0,0 +1,91 @@ | 
				
			|||
/** | 
				
			|||
 * Copyright 2013-2015 JEECG (jeecgos@163.com) | 
				
			|||
 * | 
				
			|||
 *  Licensed under the Apache License, Version 2.0 (the "License"); | 
				
			|||
 *  you may not use this file except in compliance with the License. | 
				
			|||
 *  You may obtain a copy of the License at | 
				
			|||
 * | 
				
			|||
 *     http://www.apache.org/licenses/LICENSE-2.0
 | 
				
			|||
 * | 
				
			|||
 *  Unless required by applicable law or agreed to in writing, software | 
				
			|||
 * distributed under the License is distributed on an "AS IS" BASIS, | 
				
			|||
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | 
				
			|||
 * See the License for the specific language governing permissions and | 
				
			|||
 * limitations under the License. | 
				
			|||
 */ | 
				
			|||
package cc.admin.poi.excel.imports.sax; | 
				
			|||
 | 
				
			|||
import java.io.InputStream; | 
				
			|||
import java.util.Iterator; | 
				
			|||
import java.util.List; | 
				
			|||
 | 
				
			|||
import cc.admin.poi.excel.entity.ImportParams; | 
				
			|||
import cc.admin.poi.handler.inter.IExcelReadRowHanlder; | 
				
			|||
import org.apache.poi.openxml4j.opc.OPCPackage; | 
				
			|||
import org.apache.poi.xssf.eventusermodel.XSSFReader; | 
				
			|||
import org.apache.poi.xssf.model.SharedStringsTable; | 
				
			|||
import cc.admin.poi.excel.imports.sax.parse.ISaxRowRead; | 
				
			|||
import cc.admin.poi.excel.imports.sax.parse.SaxRowRead; | 
				
			|||
import cc.admin.poi.exception.excel.ExcelImportException; | 
				
			|||
import org.slf4j.Logger; | 
				
			|||
import org.slf4j.LoggerFactory; | 
				
			|||
import org.xml.sax.ContentHandler; | 
				
			|||
import org.xml.sax.InputSource; | 
				
			|||
import org.xml.sax.SAXException; | 
				
			|||
import org.xml.sax.XMLReader; | 
				
			|||
import org.xml.sax.helpers.XMLReaderFactory; | 
				
			|||
 | 
				
			|||
/** | 
				
			|||
 * 基于SAX Excel大数据读取,读取Excel 07版本,不支持图片读取 | 
				
			|||
 * | 
				
			|||
 * @author JEECG | 
				
			|||
 * @date 2014年12月29日 下午9:41:38 | 
				
			|||
 * @version 1.0 | 
				
			|||
 */ | 
				
			|||
@SuppressWarnings("rawtypes") | 
				
			|||
public class SaxReadExcel { | 
				
			|||
 | 
				
			|||
	private static final Logger LOGGER = LoggerFactory.getLogger(SaxReadExcel.class); | 
				
			|||
 | 
				
			|||
	public <T> List<T> readExcel(InputStream inputstream, Class<?> pojoClass, ImportParams params, ISaxRowRead rowRead, IExcelReadRowHanlder hanlder) { | 
				
			|||
		try { | 
				
			|||
			OPCPackage opcPackage = OPCPackage.open(inputstream); | 
				
			|||
			return readExcel(opcPackage, pojoClass, params, rowRead, hanlder); | 
				
			|||
		} catch (Exception e) { | 
				
			|||
			LOGGER.error(e.getMessage(), e); | 
				
			|||
			throw new ExcelImportException(e.getMessage()); | 
				
			|||
		} | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	private <T> List<T> readExcel(OPCPackage opcPackage, Class<?> pojoClass, ImportParams params, ISaxRowRead rowRead, IExcelReadRowHanlder hanlder) { | 
				
			|||
		try { | 
				
			|||
			XSSFReader xssfReader = new XSSFReader(opcPackage); | 
				
			|||
			SharedStringsTable sst = xssfReader.getSharedStringsTable(); | 
				
			|||
			if (rowRead == null) { | 
				
			|||
				rowRead = new SaxRowRead(pojoClass, params, hanlder); | 
				
			|||
			} | 
				
			|||
			XMLReader parser = fetchSheetParser(sst, rowRead); | 
				
			|||
			Iterator<InputStream> sheets = xssfReader.getSheetsData(); | 
				
			|||
			int sheetIndex = 0; | 
				
			|||
			while (sheets.hasNext() && sheetIndex < params.getSheetNum()) { | 
				
			|||
				sheetIndex++; | 
				
			|||
				InputStream sheet = sheets.next(); | 
				
			|||
				InputSource sheetSource = new InputSource(sheet); | 
				
			|||
				parser.parse(sheetSource); | 
				
			|||
				sheet.close(); | 
				
			|||
			} | 
				
			|||
			return rowRead.getList(); | 
				
			|||
		} catch (Exception e) { | 
				
			|||
			LOGGER.error(e.getMessage(), e); | 
				
			|||
			throw new ExcelImportException("SAX导入数据失败"); | 
				
			|||
		} | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	private XMLReader fetchSheetParser(SharedStringsTable sst, ISaxRowRead rowRead) throws SAXException { | 
				
			|||
		XMLReader parser = XMLReaderFactory.createXMLReader("org.apache.xerces.parsers.SAXParser"); | 
				
			|||
		ContentHandler handler = new SheetHandler(sst, rowRead); | 
				
			|||
		parser.setContentHandler(handler); | 
				
			|||
		return parser; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
} | 
				
			|||
@ -0,0 +1,135 @@ | 
				
			|||
/** | 
				
			|||
 * Copyright 2013-2015 JEECG (jeecgos@163.com) | 
				
			|||
 * | 
				
			|||
 *  Licensed under the Apache License, Version 2.0 (the "License"); | 
				
			|||
 *  you may not use this file except in compliance with the License. | 
				
			|||
 *  You may obtain a copy of the License at | 
				
			|||
 * | 
				
			|||
 *     http://www.apache.org/licenses/LICENSE-2.0
 | 
				
			|||
 * | 
				
			|||
 *  Unless required by applicable law or agreed to in writing, software | 
				
			|||
 * distributed under the License is distributed on an "AS IS" BASIS, | 
				
			|||
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | 
				
			|||
 * See the License for the specific language governing permissions and | 
				
			|||
 * limitations under the License. | 
				
			|||
 */ | 
				
			|||
package cc.admin.poi.excel.imports.sax; | 
				
			|||
 | 
				
			|||
import cc.admin.poi.excel.entity.enmus.CellValueType; | 
				
			|||
import cc.admin.poi.excel.entity.sax.SaxReadCellEntity; | 
				
			|||
import com.google.common.collect.Lists; | 
				
			|||
import org.apache.poi.hssf.usermodel.HSSFDateUtil; | 
				
			|||
import org.apache.poi.xssf.model.SharedStringsTable; | 
				
			|||
import org.apache.poi.xssf.usermodel.XSSFRichTextString; | 
				
			|||
import cc.admin.poi.excel.imports.sax.parse.ISaxRowRead; | 
				
			|||
import org.xml.sax.Attributes; | 
				
			|||
import org.xml.sax.SAXException; | 
				
			|||
import org.xml.sax.helpers.DefaultHandler; | 
				
			|||
 | 
				
			|||
import java.math.BigDecimal; | 
				
			|||
import java.util.Date; | 
				
			|||
import java.util.List; | 
				
			|||
 | 
				
			|||
/** | 
				
			|||
 * 回调接口 | 
				
			|||
 * | 
				
			|||
 * @author JEECG | 
				
			|||
 * @date 2014年12月29日 下午9:50:09 | 
				
			|||
 */ | 
				
			|||
public class SheetHandler extends DefaultHandler { | 
				
			|||
 | 
				
			|||
	private SharedStringsTable sst; | 
				
			|||
	private String lastContents; | 
				
			|||
 | 
				
			|||
	// 当前行
 | 
				
			|||
	private int curRow = 0; | 
				
			|||
	// 当前列
 | 
				
			|||
	private int curCol = 0; | 
				
			|||
 | 
				
			|||
	private CellValueType type; | 
				
			|||
 | 
				
			|||
	private ISaxRowRead read; | 
				
			|||
 | 
				
			|||
	// 存储行记录的容器
 | 
				
			|||
	private List<SaxReadCellEntity> rowlist = Lists.newArrayList(); | 
				
			|||
 | 
				
			|||
	public SheetHandler(SharedStringsTable sst, ISaxRowRead rowRead) { | 
				
			|||
		this.sst = sst; | 
				
			|||
		this.read = rowRead; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	@Override | 
				
			|||
	public void startElement(String uri, String localName, String name, Attributes attributes) throws SAXException { | 
				
			|||
		// 置空
 | 
				
			|||
		lastContents = ""; | 
				
			|||
		// c => 单元格
 | 
				
			|||
		if ("c".equals(name)) { | 
				
			|||
			// 如果下一个元素是 SST 的索引,则将nextIsString标记为true
 | 
				
			|||
			String cellType = attributes.getValue("t"); | 
				
			|||
			if ("s".equals(cellType)) { | 
				
			|||
				type = CellValueType.String; | 
				
			|||
				return; | 
				
			|||
			} | 
				
			|||
			// 日期格式
 | 
				
			|||
			cellType = attributes.getValue("s"); | 
				
			|||
			if ("1".equals(cellType)) { | 
				
			|||
				type = CellValueType.Date; | 
				
			|||
			} else if ("2".equals(cellType)) { | 
				
			|||
				type = CellValueType.Number; | 
				
			|||
			} | 
				
			|||
		} else if ("t".equals(name)) {// 当元素为t时
 | 
				
			|||
			type = CellValueType.TElement; | 
				
			|||
		} | 
				
			|||
 | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	@Override | 
				
			|||
	public void endElement(String uri, String localName, String name) throws SAXException { | 
				
			|||
 | 
				
			|||
		// 根据SST的索引值的到单元格的真正要存储的字符串
 | 
				
			|||
		// 这时characters()方法可能会被调用多次
 | 
				
			|||
		if (CellValueType.String.equals(type)) { | 
				
			|||
			try { | 
				
			|||
				int idx = Integer.parseInt(lastContents); | 
				
			|||
				lastContents = new XSSFRichTextString(sst.getEntryAt(idx)).toString(); | 
				
			|||
			} catch (Exception e) { | 
				
			|||
 | 
				
			|||
			} | 
				
			|||
		} | 
				
			|||
		// t元素也包含字符串
 | 
				
			|||
		if (CellValueType.TElement.equals(type)) { | 
				
			|||
			String value = lastContents.trim(); | 
				
			|||
			rowlist.add(curCol, new SaxReadCellEntity(CellValueType.String, value)); | 
				
			|||
			curCol++; | 
				
			|||
			type = CellValueType.None; | 
				
			|||
			// v => 单元格的值,如果单元格是字符串则v标签的值为该字符串在SST中的索引
 | 
				
			|||
			// 将单元格内容加入rowlist中,在这之前先去掉字符串前后的空白符
 | 
				
			|||
		} else if ("v".equals(name)) { | 
				
			|||
			String value = lastContents.trim(); | 
				
			|||
			value = value.equals("") ? " " : value; | 
				
			|||
			if (CellValueType.Date.equals(type)) { | 
				
			|||
				Date date = HSSFDateUtil.getJavaDate(Double.valueOf(value)); | 
				
			|||
				rowlist.add(curCol, new SaxReadCellEntity(CellValueType.Date, date)); | 
				
			|||
			} else if (CellValueType.Number.equals(type)) { | 
				
			|||
				BigDecimal bd = new BigDecimal(value); | 
				
			|||
				rowlist.add(curCol, new SaxReadCellEntity(CellValueType.Number, bd)); | 
				
			|||
			} else if (CellValueType.String.equals(type)) { | 
				
			|||
				rowlist.add(curCol, new SaxReadCellEntity(CellValueType.String, value)); | 
				
			|||
			} | 
				
			|||
			curCol++; | 
				
			|||
		} else if (name.equals("row")) {// 如果标签名称为 row ,这说明已到行尾,调用 optRows() 方法
 | 
				
			|||
			read.parse(curRow, rowlist); | 
				
			|||
			rowlist.clear(); | 
				
			|||
			curRow++; | 
				
			|||
			curCol = 0; | 
				
			|||
		} | 
				
			|||
 | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	@Override | 
				
			|||
	public void characters(char[] ch, int start, int length) throws SAXException { | 
				
			|||
		// 得到单元格内容的值
 | 
				
			|||
		lastContents += new String(ch, start, length); | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
} | 
				
			|||
@ -0,0 +1,39 @@ | 
				
			|||
/** | 
				
			|||
 * Copyright 2013-2015 JEECG (jeecgos@163.com) | 
				
			|||
 * | 
				
			|||
 *  Licensed under the Apache License, Version 2.0 (the "License"); | 
				
			|||
 *  you may not use this file except in compliance with the License. | 
				
			|||
 *  You may obtain a copy of the License at | 
				
			|||
 * | 
				
			|||
 *     http://www.apache.org/licenses/LICENSE-2.0
 | 
				
			|||
 * | 
				
			|||
 *  Unless required by applicable law or agreed to in writing, software | 
				
			|||
 * distributed under the License is distributed on an "AS IS" BASIS, | 
				
			|||
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | 
				
			|||
 * See the License for the specific language governing permissions and | 
				
			|||
 * limitations under the License. | 
				
			|||
 */ | 
				
			|||
package cc.admin.poi.excel.imports.sax.parse; | 
				
			|||
 | 
				
			|||
import cc.admin.poi.excel.entity.sax.SaxReadCellEntity; | 
				
			|||
 | 
				
			|||
import java.util.List; | 
				
			|||
 | 
				
			|||
public interface ISaxRowRead { | 
				
			|||
	/** | 
				
			|||
	 * 获取返回数据 | 
				
			|||
	 * | 
				
			|||
	 * @param <T> | 
				
			|||
	 * @return | 
				
			|||
	 */ | 
				
			|||
	public <T> List<T> getList(); | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 解析数据 | 
				
			|||
	 * | 
				
			|||
	 * @param index | 
				
			|||
	 * @param datas | 
				
			|||
	 */ | 
				
			|||
	public void parse(int index, List<SaxReadCellEntity> datas); | 
				
			|||
 | 
				
			|||
} | 
				
			|||
@ -0,0 +1,213 @@ | 
				
			|||
/** | 
				
			|||
 * Copyright 2013-2015 JEECG (jeecgos@163.com) | 
				
			|||
 * | 
				
			|||
 *  Licensed under the Apache License, Version 2.0 (the "License"); | 
				
			|||
 *  you may not use this file except in compliance with the License. | 
				
			|||
 *  You may obtain a copy of the License at | 
				
			|||
 * | 
				
			|||
 *     http://www.apache.org/licenses/LICENSE-2.0
 | 
				
			|||
 * | 
				
			|||
 *  Unless required by applicable law or agreed to in writing, software | 
				
			|||
 * distributed under the License is distributed on an "AS IS" BASIS, | 
				
			|||
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | 
				
			|||
 * See the License for the specific language governing permissions and | 
				
			|||
 * limitations under the License. | 
				
			|||
 */ | 
				
			|||
package cc.admin.poi.excel.imports.sax.parse; | 
				
			|||
 | 
				
			|||
import java.lang.reflect.Field; | 
				
			|||
import java.util.ArrayList; | 
				
			|||
import java.util.Collection; | 
				
			|||
import java.util.HashMap; | 
				
			|||
import java.util.List; | 
				
			|||
import java.util.Map; | 
				
			|||
 | 
				
			|||
import cc.admin.poi.excel.annotation.ExcelTarget; | 
				
			|||
import cc.admin.poi.excel.entity.ImportParams; | 
				
			|||
import cc.admin.poi.excel.entity.params.ExcelCollectionParams; | 
				
			|||
import cc.admin.poi.excel.entity.params.ExcelImportEntity; | 
				
			|||
import cc.admin.poi.excel.entity.sax.SaxReadCellEntity; | 
				
			|||
import cc.admin.poi.excel.imports.CellValueServer; | 
				
			|||
import cc.admin.poi.excel.imports.base.ImportBaseService; | 
				
			|||
import cc.admin.poi.handler.inter.IExcelReadRowHanlder; | 
				
			|||
import cc.admin.poi.util.PoiPublicUtil; | 
				
			|||
import org.apache.commons.lang3.StringUtils; | 
				
			|||
import cc.admin.poi.exception.excel.ExcelImportException; | 
				
			|||
import org.slf4j.Logger; | 
				
			|||
import org.slf4j.LoggerFactory; | 
				
			|||
 | 
				
			|||
import com.google.common.collect.Lists; | 
				
			|||
 | 
				
			|||
/** | 
				
			|||
 * 当行读取数据 | 
				
			|||
 * | 
				
			|||
 * @author JEECG | 
				
			|||
 * @param <T> | 
				
			|||
 * @date 2015年1月1日 下午7:59:39 | 
				
			|||
 */ | 
				
			|||
@SuppressWarnings({ "rawtypes", "unchecked" }) | 
				
			|||
public class SaxRowRead extends ImportBaseService implements ISaxRowRead { | 
				
			|||
 | 
				
			|||
	private static final Logger LOGGER = LoggerFactory.getLogger(SaxRowRead.class); | 
				
			|||
	/** 需要返回的数据 **/ | 
				
			|||
	private List list; | 
				
			|||
	/** 导出的对象 **/ | 
				
			|||
	private Class<?> pojoClass; | 
				
			|||
	/** 导入参数 **/ | 
				
			|||
	private ImportParams params; | 
				
			|||
	/** 列表头对应关系 **/ | 
				
			|||
	private Map<Integer, String> titlemap = new HashMap<Integer, String>(); | 
				
			|||
	/** 当前的对象 **/ | 
				
			|||
	private Object object = null; | 
				
			|||
 | 
				
			|||
	private Map<String, ExcelImportEntity> excelParams = new HashMap<String, ExcelImportEntity>(); | 
				
			|||
 | 
				
			|||
	private List<ExcelCollectionParams> excelCollection = new ArrayList<ExcelCollectionParams>(); | 
				
			|||
 | 
				
			|||
	private String targetId; | 
				
			|||
 | 
				
			|||
	private CellValueServer cellValueServer; | 
				
			|||
 | 
				
			|||
	private IExcelReadRowHanlder hanlder; | 
				
			|||
 | 
				
			|||
	public SaxRowRead(Class<?> pojoClass, ImportParams params, IExcelReadRowHanlder hanlder) { | 
				
			|||
		list = Lists.newArrayList(); | 
				
			|||
		this.params = params; | 
				
			|||
		this.pojoClass = pojoClass; | 
				
			|||
		cellValueServer = new CellValueServer(); | 
				
			|||
		this.hanlder = hanlder; | 
				
			|||
		initParams(pojoClass, params); | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	private void initParams(Class<?> pojoClass, ImportParams params) { | 
				
			|||
		try { | 
				
			|||
 | 
				
			|||
			Field fileds[] = PoiPublicUtil.getClassFields(pojoClass); | 
				
			|||
			ExcelTarget etarget = pojoClass.getAnnotation(ExcelTarget.class); | 
				
			|||
			if (etarget != null) { | 
				
			|||
				targetId = etarget.value(); | 
				
			|||
			} | 
				
			|||
			getAllExcelField(targetId, fileds, excelParams, excelCollection, pojoClass, null); | 
				
			|||
		} catch (Exception e) { | 
				
			|||
			LOGGER.error(e.getMessage(), e); | 
				
			|||
			throw new ExcelImportException(e.getMessage()); | 
				
			|||
		} | 
				
			|||
 | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	@Override | 
				
			|||
	public <T> List<T> getList() { | 
				
			|||
		return list; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	@Override | 
				
			|||
	public void parse(int index, List<SaxReadCellEntity> datas) { | 
				
			|||
		try { | 
				
			|||
			if (datas == null || datas.size() == 0) { | 
				
			|||
				return; | 
				
			|||
			} | 
				
			|||
			// 标题行跳过
 | 
				
			|||
			if (index < params.getTitleRows()) { | 
				
			|||
				return; | 
				
			|||
			} | 
				
			|||
			// 表头行
 | 
				
			|||
			if (index < params.getTitleRows() + params.getHeadRows()) { | 
				
			|||
				addHeadData(datas); | 
				
			|||
			} else { | 
				
			|||
				addListData(datas); | 
				
			|||
			} | 
				
			|||
		} catch (Exception e) { | 
				
			|||
			LOGGER.error(e.getMessage(), e); | 
				
			|||
			throw new ExcelImportException(e.getMessage()); | 
				
			|||
		} | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 集合元素处理 | 
				
			|||
	 * | 
				
			|||
	 * @param datas | 
				
			|||
	 */ | 
				
			|||
	private void addListData(List<SaxReadCellEntity> datas) throws Exception { | 
				
			|||
		// 判断是集合元素还是不是集合元素,如果是就继续加入这个集合,不是就创建新的对象
 | 
				
			|||
		if ((datas.get(params.getKeyIndex()) == null || StringUtils.isEmpty(String.valueOf(datas.get(params.getKeyIndex()).getValue()))) && object != null) { | 
				
			|||
			for (ExcelCollectionParams param : excelCollection) { | 
				
			|||
				addListContinue(object, param, datas, titlemap, targetId, params); | 
				
			|||
			} | 
				
			|||
		} else { | 
				
			|||
			if (object != null && hanlder != null) { | 
				
			|||
				hanlder.hanlder(object); | 
				
			|||
			} | 
				
			|||
			object = PoiPublicUtil.createObject(pojoClass, targetId); | 
				
			|||
			SaxReadCellEntity entity; | 
				
			|||
			for (int i = 0, le = datas.size(); i < le; i++) { | 
				
			|||
				entity = datas.get(i); | 
				
			|||
				String titleString = (String) titlemap.get(i); | 
				
			|||
				if (excelParams.containsKey(titleString)) { | 
				
			|||
					saveFieldValue(params, object, entity, excelParams, titleString); | 
				
			|||
				} | 
				
			|||
			} | 
				
			|||
			for (ExcelCollectionParams param : excelCollection) { | 
				
			|||
				addListContinue(object, param, datas, titlemap, targetId, params); | 
				
			|||
			} | 
				
			|||
			if (hanlder == null) { | 
				
			|||
				list.add(object); | 
				
			|||
			} | 
				
			|||
		} | 
				
			|||
 | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	/*** | 
				
			|||
	 * 向List里面继续添加元素 | 
				
			|||
	 * | 
				
			|||
	 * @param exclusions | 
				
			|||
	 * @param object | 
				
			|||
	 * @param param | 
				
			|||
	 * @param datas | 
				
			|||
	 * @param titlemap | 
				
			|||
	 * @param targetId | 
				
			|||
	 * @param params | 
				
			|||
	 */ | 
				
			|||
	private void addListContinue(Object object, ExcelCollectionParams param, List<SaxReadCellEntity> datas, Map<Integer, String> titlemap, String targetId, ImportParams params) throws Exception { | 
				
			|||
		Collection collection = (Collection) PoiPublicUtil.getMethod(param.getName(), object.getClass()).invoke(object, new Object[] {}); | 
				
			|||
		Object entity = PoiPublicUtil.createObject(param.getType(), targetId); | 
				
			|||
		boolean isUsed = false;// 是否需要加上这个对象
 | 
				
			|||
		for (int i = 0; i < datas.size(); i++) { | 
				
			|||
			String titleString = (String) titlemap.get(i); | 
				
			|||
			if (param.getExcelParams().containsKey(titleString)) { | 
				
			|||
				saveFieldValue(params, entity, datas.get(i), param.getExcelParams(), titleString); | 
				
			|||
				isUsed = true; | 
				
			|||
			} | 
				
			|||
		} | 
				
			|||
		if (isUsed) { | 
				
			|||
			collection.add(entity); | 
				
			|||
		} | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 设置值 | 
				
			|||
	 * | 
				
			|||
	 * @param params | 
				
			|||
	 * @param object | 
				
			|||
	 * @param entity | 
				
			|||
	 * @param excelParams | 
				
			|||
	 * @param titleString | 
				
			|||
	 * @throws Exception | 
				
			|||
	 */ | 
				
			|||
	private void saveFieldValue(ImportParams params, Object object, SaxReadCellEntity entity, Map<String, ExcelImportEntity> excelParams, String titleString) throws Exception { | 
				
			|||
		Object value = cellValueServer.getValue(params.getDataHanlder(), object, entity, excelParams, titleString); | 
				
			|||
		setValues(excelParams.get(titleString), object, value); | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * put 表头数据 | 
				
			|||
	 * | 
				
			|||
	 * @param datas | 
				
			|||
	 */ | 
				
			|||
	private void addHeadData(List<SaxReadCellEntity> datas) { | 
				
			|||
		for (int i = 0; i < datas.size(); i++) { | 
				
			|||
			if (StringUtils.isNotEmpty(String.valueOf(datas.get(i).getValue()))) { | 
				
			|||
				titlemap.put(i, String.valueOf(datas.get(i).getValue())); | 
				
			|||
			} | 
				
			|||
		} | 
				
			|||
	} | 
				
			|||
} | 
				
			|||
@ -0,0 +1,145 @@ | 
				
			|||
/** | 
				
			|||
 * Copyright 2013-2015 JEECG (jeecgos@163.com) | 
				
			|||
 * | 
				
			|||
 *  Licensed under the Apache License, Version 2.0 (the "License"); | 
				
			|||
 *  you may not use this file except in compliance with the License. | 
				
			|||
 *  You may obtain a copy of the License at | 
				
			|||
 * | 
				
			|||
 *     http://www.apache.org/licenses/LICENSE-2.0
 | 
				
			|||
 * | 
				
			|||
 *  Unless required by applicable law or agreed to in writing, software | 
				
			|||
 * distributed under the License is distributed on an "AS IS" BASIS, | 
				
			|||
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | 
				
			|||
 * See the License for the specific language governing permissions and | 
				
			|||
 * limitations under the License. | 
				
			|||
 */ | 
				
			|||
package cc.admin.poi.excel.imports.verifys; | 
				
			|||
 | 
				
			|||
import java.util.regex.Pattern; | 
				
			|||
 | 
				
			|||
import cc.admin.poi.excel.entity.result.ExcelVerifyHanlderResult; | 
				
			|||
 | 
				
			|||
/** | 
				
			|||
 * 基础校验工具类 | 
				
			|||
 * | 
				
			|||
 * @author JEECG | 
				
			|||
 * @date 2014年6月23日 下午11:10:12 | 
				
			|||
 */ | 
				
			|||
public class BaseVerifyHandler { | 
				
			|||
 | 
				
			|||
	private static String NOT_NULL = "不允许为空"; | 
				
			|||
	private static String IS_MOBILE = "不是手机号"; | 
				
			|||
	private static String IS_TEL = "不是电话号码"; | 
				
			|||
	private static String IS_EMAIL = "不是邮箱地址"; | 
				
			|||
	private static String MIN_LENGHT = "小于规定长度"; | 
				
			|||
	private static String MAX_LENGHT = "超过规定长度"; | 
				
			|||
 | 
				
			|||
	private static Pattern mobilePattern = Pattern.compile("^[1][3,4,5,8,7][0-9]{9}$"); | 
				
			|||
 | 
				
			|||
	private static Pattern telPattern = Pattern.compile("^([0][1-9]{2,3}-)?[0-9]{5,10}$"); | 
				
			|||
 | 
				
			|||
	private static Pattern emailPattern = Pattern.compile("^([a-zA-Z0-9]+[_|\\_|\\.]?)*[a-zA-Z0-9]+@([a-zA-Z0-9]+[_|\\_|\\.]?)*[a-zA-Z0-9]+\\.[a-zA-Z]{2,3}$"); | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * email校验 | 
				
			|||
	 * | 
				
			|||
	 * @param name | 
				
			|||
	 * @param val | 
				
			|||
	 * @return | 
				
			|||
	 */ | 
				
			|||
	public static ExcelVerifyHanlderResult isEmail(String name, Object val) { | 
				
			|||
		if (!emailPattern.matcher(String.valueOf(val)).matches()) { | 
				
			|||
			return new ExcelVerifyHanlderResult(false, name + IS_EMAIL); | 
				
			|||
		} | 
				
			|||
		return new ExcelVerifyHanlderResult(true); | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 手机校验 | 
				
			|||
	 * | 
				
			|||
	 * @param name | 
				
			|||
	 * @param val | 
				
			|||
	 * @return | 
				
			|||
	 */ | 
				
			|||
	public static ExcelVerifyHanlderResult isMobile(String name, Object val) { | 
				
			|||
		if (!mobilePattern.matcher(String.valueOf(val)).matches()) { | 
				
			|||
			return new ExcelVerifyHanlderResult(false, name + IS_MOBILE); | 
				
			|||
		} | 
				
			|||
		return new ExcelVerifyHanlderResult(true); | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 电话校验 | 
				
			|||
	 * | 
				
			|||
	 * @param name | 
				
			|||
	 * @param val | 
				
			|||
	 * @return | 
				
			|||
	 */ | 
				
			|||
	public static ExcelVerifyHanlderResult isTel(String name, Object val) { | 
				
			|||
		if (!telPattern.matcher(String.valueOf(val)).matches()) { | 
				
			|||
			return new ExcelVerifyHanlderResult(false, name + IS_TEL); | 
				
			|||
		} | 
				
			|||
		return new ExcelVerifyHanlderResult(true); | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 最大长度校验 | 
				
			|||
	 * | 
				
			|||
	 * @param name | 
				
			|||
	 * @param val | 
				
			|||
	 * @return | 
				
			|||
	 */ | 
				
			|||
	public static ExcelVerifyHanlderResult maxLength(String name, Object val, int maxLength) { | 
				
			|||
		if (notNull(name, val).isSuccess() && String.valueOf(val).length() > maxLength) { | 
				
			|||
			return new ExcelVerifyHanlderResult(false, name + MAX_LENGHT); | 
				
			|||
		} | 
				
			|||
		return new ExcelVerifyHanlderResult(true); | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 最小长度校验 | 
				
			|||
	 * | 
				
			|||
	 * @param name | 
				
			|||
	 * @param val | 
				
			|||
	 * @param minLength | 
				
			|||
	 * @return | 
				
			|||
	 */ | 
				
			|||
	public static ExcelVerifyHanlderResult minLength(String name, Object val, int minLength) { | 
				
			|||
		if (notNull(name, val).isSuccess() && String.valueOf(val).length() < minLength) { | 
				
			|||
			return new ExcelVerifyHanlderResult(false, name + MIN_LENGHT); | 
				
			|||
		} | 
				
			|||
		return new ExcelVerifyHanlderResult(true); | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 非空校验 | 
				
			|||
	 * | 
				
			|||
	 * @param name | 
				
			|||
	 * @param val | 
				
			|||
	 * @return | 
				
			|||
	 */ | 
				
			|||
	public static ExcelVerifyHanlderResult notNull(String name, Object val) { | 
				
			|||
		if (val == null || val.toString().equals("")) { | 
				
			|||
			return new ExcelVerifyHanlderResult(false, name + NOT_NULL); | 
				
			|||
		} | 
				
			|||
		return new ExcelVerifyHanlderResult(true); | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 正则表达式校验 | 
				
			|||
	 * | 
				
			|||
	 * @param name | 
				
			|||
	 * @param val | 
				
			|||
	 * @param regex | 
				
			|||
	 * @param regexTip | 
				
			|||
	 * @return | 
				
			|||
	 */ | 
				
			|||
	public static ExcelVerifyHanlderResult regex(String name, Object val, String regex, String regexTip) { | 
				
			|||
		Pattern pattern = Pattern.compile(regex); | 
				
			|||
		if (!pattern.matcher(String.valueOf(val)).matches()) { | 
				
			|||
			return new ExcelVerifyHanlderResult(false, name + regexTip); | 
				
			|||
		} | 
				
			|||
		return new ExcelVerifyHanlderResult(true); | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
} | 
				
			|||
@ -0,0 +1,81 @@ | 
				
			|||
/** | 
				
			|||
 * Copyright 2013-2015 JEECG (jeecgos@163.com) | 
				
			|||
 * | 
				
			|||
 *  Licensed under the Apache License, Version 2.0 (the "License"); | 
				
			|||
 *  you may not use this file except in compliance with the License. | 
				
			|||
 *  You may obtain a copy of the License at | 
				
			|||
 * | 
				
			|||
 *     http://www.apache.org/licenses/LICENSE-2.0
 | 
				
			|||
 * | 
				
			|||
 *  Unless required by applicable law or agreed to in writing, software | 
				
			|||
 * distributed under the License is distributed on an "AS IS" BASIS, | 
				
			|||
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | 
				
			|||
 * See the License for the specific language governing permissions and | 
				
			|||
 * limitations under the License. | 
				
			|||
 */ | 
				
			|||
package cc.admin.poi.excel.imports.verifys; | 
				
			|||
 | 
				
			|||
import cc.admin.poi.excel.entity.params.ExcelVerifyEntity; | 
				
			|||
import cc.admin.poi.excel.entity.result.ExcelVerifyHanlderResult; | 
				
			|||
import cc.admin.poi.handler.inter.IExcelVerifyHandler; | 
				
			|||
import org.apache.commons.lang3.StringUtils; | 
				
			|||
 | 
				
			|||
/** | 
				
			|||
 * 校验服务 | 
				
			|||
 * | 
				
			|||
 * @author JEECG | 
				
			|||
 * @date 2014年6月29日 下午4:37:56 | 
				
			|||
 */ | 
				
			|||
public class VerifyHandlerServer { | 
				
			|||
 | 
				
			|||
	private final static ExcelVerifyHanlderResult DEFAULT_RESULT = new ExcelVerifyHanlderResult(true); | 
				
			|||
 | 
				
			|||
	private void addVerifyResult(ExcelVerifyHanlderResult hanlderResult, ExcelVerifyHanlderResult result) { | 
				
			|||
		if (!hanlderResult.isSuccess()) { | 
				
			|||
			result.setSuccess(false); | 
				
			|||
			result.setMsg((StringUtils.isEmpty(result.getMsg()) ? "" : result.getMsg() + " , ") + hanlderResult.getMsg()); | 
				
			|||
		} | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	/** | 
				
			|||
	 * 校驗數據 | 
				
			|||
	 * | 
				
			|||
	 * @param object | 
				
			|||
	 * @param value | 
				
			|||
	 * @param titleString | 
				
			|||
	 * @param verify | 
				
			|||
	 * @param excelVerifyHandler | 
				
			|||
	 */ | 
				
			|||
	public ExcelVerifyHanlderResult verifyData(Object object, Object value, String name, ExcelVerifyEntity verify, IExcelVerifyHandler excelVerifyHandler) { | 
				
			|||
		if (verify == null) { | 
				
			|||
			return DEFAULT_RESULT; | 
				
			|||
		} | 
				
			|||
		ExcelVerifyHanlderResult result = new ExcelVerifyHanlderResult(true, ""); | 
				
			|||
		if (verify.isNotNull()) { | 
				
			|||
			addVerifyResult(BaseVerifyHandler.notNull(name, value), result); | 
				
			|||
		} | 
				
			|||
		if (verify.isEmail()) { | 
				
			|||
			addVerifyResult(BaseVerifyHandler.isEmail(name, value), result); | 
				
			|||
		} | 
				
			|||
		if (verify.isMobile()) { | 
				
			|||
			addVerifyResult(BaseVerifyHandler.isMobile(name, value), result); | 
				
			|||
		} | 
				
			|||
		if (verify.isTel()) { | 
				
			|||
			addVerifyResult(BaseVerifyHandler.isTel(name, value), result); | 
				
			|||
		} | 
				
			|||
		if (verify.getMaxLength() != -1) { | 
				
			|||
			addVerifyResult(BaseVerifyHandler.maxLength(name, value, verify.getMaxLength()), result); | 
				
			|||
		} | 
				
			|||
		if (verify.getMinLength() != -1) { | 
				
			|||
			addVerifyResult(BaseVerifyHandler.minLength(name, value, verify.getMinLength()), result); | 
				
			|||
		} | 
				
			|||
		if (StringUtils.isNotEmpty(verify.getRegex())) { | 
				
			|||
			addVerifyResult(BaseVerifyHandler.regex(name, value, verify.getRegex(), verify.getRegexTip()), result); | 
				
			|||
		} | 
				
			|||
		if (verify.isInterHandler()) { | 
				
			|||
			addVerifyResult(excelVerifyHandler.verifyHandler(object, name, value), result); | 
				
			|||
		} | 
				
			|||
		return result; | 
				
			|||
 | 
				
			|||
	} | 
				
			|||
} | 
				
			|||
@ -0,0 +1,43 @@ | 
				
			|||
/** | 
				
			|||
 * Copyright 2013-2015 JEECG (jeecgos@163.com) | 
				
			|||
 * | 
				
			|||
 *  Licensed under the Apache License, Version 2.0 (the "License"); | 
				
			|||
 *  you may not use this file except in compliance with the License. | 
				
			|||
 *  You may obtain a copy of the License at | 
				
			|||
 * | 
				
			|||
 *     http://www.apache.org/licenses/LICENSE-2.0
 | 
				
			|||
 * | 
				
			|||
 *  Unless required by applicable law or agreed to in writing, software | 
				
			|||
 * distributed under the License is distributed on an "AS IS" BASIS, | 
				
			|||
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | 
				
			|||
 * See the License for the specific language governing permissions and | 
				
			|||
 * limitations under the License. | 
				
			|||
 */ | 
				
			|||
package cc.admin.poi.excel.view; | 
				
			|||
 | 
				
			|||
import javax.servlet.http.HttpServletRequest; | 
				
			|||
 | 
				
			|||
import org.springframework.web.servlet.view.AbstractView; | 
				
			|||
 | 
				
			|||
/** | 
				
			|||
 * 基础抽象Excel View | 
				
			|||
 * | 
				
			|||
 * @author JEECG | 
				
			|||
 * @date 2015年2月28日 下午1:41:05 | 
				
			|||
 */ | 
				
			|||
public abstract class MiniAbstractExcelView extends AbstractView { | 
				
			|||
 | 
				
			|||
	private static final String CONTENT_TYPE = "application/vnd.ms-excel"; | 
				
			|||
 | 
				
			|||
	protected static final String HSSF = ".xls"; | 
				
			|||
	protected static final String XSSF = ".xlsx"; | 
				
			|||
 | 
				
			|||
	public MiniAbstractExcelView() { | 
				
			|||
		setContentType(CONTENT_TYPE); | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	protected boolean isIE(HttpServletRequest request) { | 
				
			|||
		return (request.getHeader("USER-AGENT").toLowerCase().indexOf("msie") > 0 || request.getHeader("USER-AGENT").toLowerCase().indexOf("rv:11.0") > 0) ? true : false; | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
} | 
				
			|||
@ -0,0 +1,88 @@ | 
				
			|||
/** | 
				
			|||
 * Copyright 2013-2015 JEECG (jeecgos@163.com) | 
				
			|||
 * | 
				
			|||
 *  Licensed under the Apache License, Version 2.0 (the "License"); | 
				
			|||
 *  you may not use this file except in compliance with the License. | 
				
			|||
 *  You may obtain a copy of the License at | 
				
			|||
 * | 
				
			|||
 *     http://www.apache.org/licenses/LICENSE-2.0
 | 
				
			|||
 * | 
				
			|||
 *  Unless required by applicable law or agreed to in writing, software | 
				
			|||
 * distributed under the License is distributed on an "AS IS" BASIS, | 
				
			|||
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | 
				
			|||
 * See the License for the specific language governing permissions and | 
				
			|||
 * limitations under the License. | 
				
			|||
 */ | 
				
			|||
package cc.admin.poi.excel.view; | 
				
			|||
 | 
				
			|||
import cc.admin.poi.excel.ExcelExportUtil; | 
				
			|||
import cc.admin.poi.excel.def.NormalExcelConstants; | 
				
			|||
import cc.admin.poi.excel.entity.ExportParams; | 
				
			|||
import cc.admin.poi.excel.export.ExcelExportServer; | 
				
			|||
import org.apache.poi.hssf.usermodel.HSSFWorkbook; | 
				
			|||
import org.apache.poi.ss.usermodel.Workbook; | 
				
			|||
import org.springframework.stereotype.Controller; | 
				
			|||
 | 
				
			|||
import javax.servlet.ServletOutputStream; | 
				
			|||
import javax.servlet.http.HttpServletRequest; | 
				
			|||
import javax.servlet.http.HttpServletResponse; | 
				
			|||
import java.util.Collection; | 
				
			|||
import java.util.List; | 
				
			|||
import java.util.Map; | 
				
			|||
 | 
				
			|||
/** | 
				
			|||
 * Entity 实体数据对象导出 | 
				
			|||
 * @Author JEECG | 
				
			|||
 * | 
				
			|||
 */ | 
				
			|||
@SuppressWarnings("unchecked") | 
				
			|||
@Controller(NormalExcelConstants.CC_ADMIN_ENTITY_EXCEL_VIEW) | 
				
			|||
public class PoiEntityExcelView extends MiniAbstractExcelView { | 
				
			|||
 | 
				
			|||
	public PoiEntityExcelView() { | 
				
			|||
		super(); | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	@Override | 
				
			|||
	protected void renderMergedOutputModel(Map<String, Object> model, HttpServletRequest request, HttpServletResponse response) throws Exception { | 
				
			|||
		String codedFileName = "临时文件"; | 
				
			|||
		Workbook workbook = null; | 
				
			|||
		//---update-end-----autor:scott------date:20191016-------for:导出字段支持自定义--------
 | 
				
			|||
		String[] exportFields = null; | 
				
			|||
 | 
				
			|||
		Object exportFieldStr =  model.get(NormalExcelConstants.EXPORT_FIELDS); | 
				
			|||
		if(exportFieldStr!=null && exportFieldStr!=""){ | 
				
			|||
			exportFields = exportFieldStr.toString().split(","); | 
				
			|||
		} | 
				
			|||
        //---update-end-----autor:scott------date:20191016-------for:导出字段支持自定义--------
 | 
				
			|||
		if (model.containsKey(NormalExcelConstants.MAP_LIST)) { | 
				
			|||
			List<Map<String, Object>> list = (List<Map<String, Object>>) model.get(NormalExcelConstants.MAP_LIST); | 
				
			|||
			if (list.size() == 0) { | 
				
			|||
				throw new RuntimeException("MAP_LIST IS NULL"); | 
				
			|||
			} | 
				
			|||
			workbook = ExcelExportUtil.exportExcel((ExportParams) list.get(0).get(NormalExcelConstants.PARAMS), (Class<?>) list.get(0).get(NormalExcelConstants.CLASS), (Collection<?>) list.get(0).get(NormalExcelConstants.DATA_LIST),exportFields); | 
				
			|||
			for (int i = 1; i < list.size(); i++) { | 
				
			|||
				new ExcelExportServer().createSheet(workbook, (ExportParams) list.get(i).get(NormalExcelConstants.PARAMS), (Class<?>) list.get(i).get(NormalExcelConstants.CLASS), (Collection<?>) list.get(i).get(NormalExcelConstants.DATA_LIST),exportFields); | 
				
			|||
			} | 
				
			|||
		} else { | 
				
			|||
			workbook = ExcelExportUtil.exportExcel((ExportParams) model.get(NormalExcelConstants.PARAMS), (Class<?>) model.get(NormalExcelConstants.CLASS), (Collection<?>) model.get(NormalExcelConstants.DATA_LIST),exportFields); | 
				
			|||
		} | 
				
			|||
		if (model.containsKey(NormalExcelConstants.FILE_NAME)) { | 
				
			|||
			codedFileName = (String) model.get(NormalExcelConstants.FILE_NAME); | 
				
			|||
		} | 
				
			|||
		if (workbook instanceof HSSFWorkbook) { | 
				
			|||
			codedFileName += HSSF; | 
				
			|||
		} else { | 
				
			|||
			codedFileName += XSSF; | 
				
			|||
		} | 
				
			|||
		if (isIE(request)) { | 
				
			|||
			codedFileName = java.net.URLEncoder.encode(codedFileName, "UTF8"); | 
				
			|||
		} else { | 
				
			|||
			codedFileName = new String(codedFileName.getBytes("UTF-8"), "ISO-8859-1"); | 
				
			|||
		} | 
				
			|||
		response.setHeader("content-disposition", "attachment;filename=" + codedFileName); | 
				
			|||
		ServletOutputStream out = response.getOutputStream(); | 
				
			|||
		workbook.write(out); | 
				
			|||
		out.flush(); | 
				
			|||
	} | 
				
			|||
} | 
				
			|||
@ -0,0 +1,70 @@ | 
				
			|||
/** | 
				
			|||
 * Copyright 2013-2015 JEECG (jeecgos@163.com) | 
				
			|||
 * | 
				
			|||
 *  Licensed under the Apache License, Version 2.0 (the "License"); | 
				
			|||
 *  you may not use this file except in compliance with the License. | 
				
			|||
 *  You may obtain a copy of the License at | 
				
			|||
 * | 
				
			|||
 *     http://www.apache.org/licenses/LICENSE-2.0
 | 
				
			|||
 * | 
				
			|||
 *  Unless required by applicable law or agreed to in writing, software | 
				
			|||
 * distributed under the License is distributed on an "AS IS" BASIS, | 
				
			|||
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | 
				
			|||
 * See the License for the specific language governing permissions and | 
				
			|||
 * limitations under the License. | 
				
			|||
 */ | 
				
			|||
package cc.admin.poi.excel.view; | 
				
			|||
 | 
				
			|||
import cc.admin.poi.excel.ExcelExportUtil; | 
				
			|||
import cc.admin.poi.excel.def.MapExcelConstants; | 
				
			|||
import cc.admin.poi.excel.entity.ExportParams; | 
				
			|||
import cc.admin.poi.excel.entity.params.ExcelExportEntity; | 
				
			|||
import org.apache.poi.hssf.usermodel.HSSFWorkbook; | 
				
			|||
import org.apache.poi.ss.usermodel.Workbook; | 
				
			|||
import org.springframework.stereotype.Controller; | 
				
			|||
 | 
				
			|||
import javax.servlet.ServletOutputStream; | 
				
			|||
import javax.servlet.http.HttpServletRequest; | 
				
			|||
import javax.servlet.http.HttpServletResponse; | 
				
			|||
import java.util.Collection; | 
				
			|||
import java.util.List; | 
				
			|||
import java.util.Map; | 
				
			|||
 | 
				
			|||
/** | 
				
			|||
 * Map 数据对象接口导出 | 
				
			|||
 * | 
				
			|||
 * @author JEECG | 
				
			|||
 * @date 2014年11月25日 下午3:26:32 | 
				
			|||
 */ | 
				
			|||
@SuppressWarnings("unchecked") | 
				
			|||
@Controller(MapExcelConstants.DSTC_MAP_EXCEL_VIEW) | 
				
			|||
public class PoiMapExcelView extends MiniAbstractExcelView { | 
				
			|||
 | 
				
			|||
	public PoiMapExcelView() { | 
				
			|||
		super(); | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	@Override | 
				
			|||
	protected void renderMergedOutputModel(Map<String, Object> model, HttpServletRequest request, HttpServletResponse response) throws Exception { | 
				
			|||
		String codedFileName = "临时文件"; | 
				
			|||
		Workbook workbook = ExcelExportUtil.exportExcel((ExportParams) model.get(MapExcelConstants.PARAMS), (List<ExcelExportEntity>) model.get(MapExcelConstants.ENTITY_LIST), (Collection<? extends Map<?, ?>>) model.get(MapExcelConstants.MAP_LIST)); | 
				
			|||
		if (model.containsKey(MapExcelConstants.FILE_NAME)) { | 
				
			|||
			codedFileName = (String) model.get(MapExcelConstants.FILE_NAME); | 
				
			|||
		} | 
				
			|||
		if (workbook instanceof HSSFWorkbook) { | 
				
			|||
			codedFileName += HSSF; | 
				
			|||
		} else { | 
				
			|||
			codedFileName += XSSF; | 
				
			|||
		} | 
				
			|||
		if (isIE(request)) { | 
				
			|||
			codedFileName = java.net.URLEncoder.encode(codedFileName, "UTF8"); | 
				
			|||
		} else { | 
				
			|||
			codedFileName = new String(codedFileName.getBytes("UTF-8"), "ISO-8859-1"); | 
				
			|||
		} | 
				
			|||
		response.setHeader("content-disposition", "attachment;filename=" + codedFileName); | 
				
			|||
		ServletOutputStream out = response.getOutputStream(); | 
				
			|||
		workbook.write(out); | 
				
			|||
		out.flush(); | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
} | 
				
			|||
@ -0,0 +1,68 @@ | 
				
			|||
/** | 
				
			|||
 * Copyright 2013-2015 JEECG (jeecgos@163.com) | 
				
			|||
 * | 
				
			|||
 *  Licensed under the Apache License, Version 2.0 (the "License"); | 
				
			|||
 *  you may not use this file except in compliance with the License. | 
				
			|||
 *  You may obtain a copy of the License at | 
				
			|||
 * | 
				
			|||
 *     http://www.apache.org/licenses/LICENSE-2.0
 | 
				
			|||
 * | 
				
			|||
 *  Unless required by applicable law or agreed to in writing, software | 
				
			|||
 * distributed under the License is distributed on an "AS IS" BASIS, | 
				
			|||
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | 
				
			|||
 * See the License for the specific language governing permissions and | 
				
			|||
 * limitations under the License. | 
				
			|||
 */ | 
				
			|||
package cc.admin.poi.excel.view; | 
				
			|||
 | 
				
			|||
import cc.admin.poi.excel.ExcelExportUtil; | 
				
			|||
import cc.admin.poi.excel.def.NormalExcelConstants; | 
				
			|||
import cc.admin.poi.excel.def.TemplateExcelConstants; | 
				
			|||
import cc.admin.poi.excel.entity.TemplateExportParams; | 
				
			|||
import org.apache.poi.hssf.usermodel.HSSFWorkbook; | 
				
			|||
import org.apache.poi.ss.usermodel.Workbook; | 
				
			|||
import org.springframework.stereotype.Controller; | 
				
			|||
 | 
				
			|||
import javax.servlet.ServletOutputStream; | 
				
			|||
import javax.servlet.http.HttpServletRequest; | 
				
			|||
import javax.servlet.http.HttpServletResponse; | 
				
			|||
import java.util.List; | 
				
			|||
import java.util.Map; | 
				
			|||
 | 
				
			|||
/** | 
				
			|||
 * Excel 模板导出 | 
				
			|||
 * | 
				
			|||
 * @author JEECG | 
				
			|||
 * @date 2014年6月30日 下午9:15:49 | 
				
			|||
 */ | 
				
			|||
@SuppressWarnings("unchecked") | 
				
			|||
@Controller(TemplateExcelConstants.DSTC_TEMPLATE_EXCEL_VIEW) | 
				
			|||
public class PoiTemplateExcelView extends MiniAbstractExcelView { | 
				
			|||
 | 
				
			|||
	public PoiTemplateExcelView() { | 
				
			|||
		super(); | 
				
			|||
	} | 
				
			|||
 | 
				
			|||
	@Override | 
				
			|||
	protected void renderMergedOutputModel(Map<String, Object> model, HttpServletRequest request, HttpServletResponse response) throws Exception { | 
				
			|||
		String codedFileName = "临时文件"; | 
				
			|||
		Workbook workbook = ExcelExportUtil.exportExcel((TemplateExportParams) model.get(TemplateExcelConstants.PARAMS), (Class<?>) model.get(TemplateExcelConstants.CLASS), (List<?>) model.get(TemplateExcelConstants.LIST_DATA), (Map<String, Object>) model.get(TemplateExcelConstants.MAP_DATA)); | 
				
			|||
		if (model.containsKey(NormalExcelConstants.FILE_NAME)) { | 
				
			|||
			codedFileName = (String) model.get(NormalExcelConstants.FILE_NAME); | 
				
			|||
		} | 
				
			|||
		if (workbook instanceof HSSFWorkbook) { | 
				
			|||
			codedFileName += HSSF; | 
				
			|||
		} else { | 
				
			|||
			codedFileName += XSSF; | 
				
			|||
		} | 
				
			|||
		if (isIE(request)) { | 
				
			|||
			codedFileName = java.net.URLEncoder.encode(codedFileName, "UTF8"); | 
				
			|||
		} else { | 
				
			|||
			codedFileName = new String(codedFileName.getBytes("UTF-8"), "ISO-8859-1"); | 
				
			|||
		} | 
				
			|||
		response.setHeader("content-disposition", "attachment;filename=" + codedFileName); | 
				
			|||
		ServletOutputStream out = response.getOutputStream(); | 
				
			|||
		workbook.write(out); | 
				
			|||
		out.flush(); | 
				
			|||
	} | 
				
			|||
} | 
				
			|||
Some files were not shown because too many files changed in this diff
					Loading…
					
					
				
		Reference in new issue