Skip to content
项目
群组
代码片段
帮助
正在加载...
帮助
提交反馈
为 GitLab 提交贡献
登录
切换导航
I
ibzlite
项目
项目
详情
动态
版本
周期分析
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
统计图
议题
0
议题
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
CI / CD
CI / CD
流水线
作业
计划
统计图
Wiki
Wiki
代码片段
代码片段
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
统计图
创建新议题
作业
提交
议题看板
打开侧边栏
ibiz4jteam
ibzlite
提交
41f8a2ac
提交
41f8a2ac
编写于
1月 25, 2021
作者:
tangyaolong
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
补充tar.gz压缩逻辑
上级
b28c5359
变更
2
隐藏空白字符变更
内嵌
并排
正在显示
2 个修改的文件
包含
85 行增加
和
3 行删除
+85
-3
DynamicModelConfigExService.java
.../core/extensions/service/DynamicModelConfigExService.java
+9
-3
FileHelper.java
...util/src/main/java/cn/ibizlab/util/helper/FileHelper.java
+76
-0
未找到文件。
ibzlite-core/src/main/java/cn/ibizlab/core/extensions/service/DynamicModelConfigExService.java
浏览文件 @
41f8a2ac
...
...
@@ -42,7 +42,7 @@ public class DynamicModelConfigExService extends DynamicModelConfigServiceImpl {
return
com
.
baomidou
.
mybatisplus
.
core
.
toolkit
.
ReflectionKit
.
getSuperClassGenericType
(
this
.
getClass
().
getSuperclass
(),
1
);
}
@Value
(
"${ibiz.filePath:/app/file/}"
)
@Value
(
"${ibiz.filePath:
d:
/app/file/}"
)
private
String
fileRoot
;
@Autowired
...
...
@@ -52,7 +52,7 @@ public class DynamicModelConfigExService extends DynamicModelConfigServiceImpl {
@Lazy
private
IBZWFFeignClient
wfClient
;
@Value
(
"${ibiz.dynamic.publishpath:/app/file/dynamicModel/publicpath}"
)
@Value
(
"${ibiz.dynamic.publishpath:
d:
/app/file/dynamicModel/publicpath}"
)
private
String
publishPath
;
@Autowired
...
...
@@ -80,7 +80,13 @@ public class DynamicModelConfigExService extends DynamicModelConfigServiceImpl {
throw
new
BadRequestAlertException
(
"单次只允许上传一个模型文件"
,
"DynamicModelConfig"
,
"unzip"
);
File
modelFile
=
fileService
.
getFile
(
items
.
get
(
0
).
getId
());
String
unzipPath
=
modelFile
.
getParent
().
replace
(
"ibizutil"
,
"dynamicmodel"
);
FileHelper
.
unzip
(
modelFile
,
unzipPath
,
true
);
if
(
".gz"
.
equals
(
modelFile
.
getName
().
substring
(
modelFile
.
getName
().
lastIndexOf
(
"."
)))){
FileHelper
.
unTarGz
(
modelFile
,
unzipPath
);
}
else
if
(
".zip"
.
equals
(
modelFile
.
getName
().
substring
(
modelFile
.
getName
().
lastIndexOf
(
"."
)))){
FileHelper
.
unzip
(
modelFile
,
unzipPath
,
true
);
}
JSONObject
system
=
getSystem
(
unzipPath
);
et
.
setSystemId
(
system
.
getString
(
"name"
));
}
catch
(
IOException
e
)
{
...
...
ibzlite-util/src/main/java/cn/ibizlab/util/helper/FileHelper.java
浏览文件 @
41f8a2ac
package
cn
.
ibizlab
.
util
.
helper
;
import
cn.ibizlab.util.domain.FileItem
;
import
cn.ibizlab.util.errors.BadRequestAlertException
;
import
com.alibaba.fastjson.JSONArray
;
import
lombok.extern.slf4j.Slf4j
;
import
org.apache.tools.tar.TarEntry
;
import
org.apache.tools.tar.TarInputStream
;
import
org.springframework.util.ObjectUtils
;
import
org.springframework.util.StringUtils
;
import
java.io.*
;
import
java.nio.charset.Charset
;
import
java.util.Enumeration
;
import
java.util.List
;
import
java.util.zip.GZIPInputStream
;
import
java.util.zip.ZipEntry
;
import
java.util.zip.ZipFile
;
...
...
@@ -62,7 +70,75 @@ public class FileHelper {
}
return
true
;
}
public
static
void
unTarGz
(
File
zipFile
,
String
descDir
)
throws
IOException
{
TarInputStream
tarIn
=
null
;
try
{
tarIn
=
new
TarInputStream
(
new
GZIPInputStream
(
new
BufferedInputStream
(
new
FileInputStream
(
zipFile
))),
1024
*
2
);
//创建输出目录
createDirectory
(
descDir
,
null
);
TarEntry
entry
=
null
;
while
((
entry
=
tarIn
.
getNextEntry
())
!=
null
){
if
(
entry
.
isDirectory
()){
//是目录
entry
.
getName
();
//创建空目录
createDirectory
(
descDir
,
entry
.
getName
());
}
else
{
//是文件
File
tmpFile
=
new
File
(
descDir
+
"/"
+
entry
.
getName
());
//创建输出目录
createDirectory
(
tmpFile
.
getParent
()
+
"/"
,
null
);
OutputStream
out
=
null
;
try
{
out
=
new
FileOutputStream
(
tmpFile
);
int
length
=
0
;
byte
[]
b
=
new
byte
[
2048
];
while
((
length
=
tarIn
.
read
(
b
))
!=
-
1
){
out
.
write
(
b
,
0
,
length
);
}
}
catch
(
IOException
ex
){
throw
ex
;
}
finally
{
if
(
out
!=
null
)
out
.
close
();
}
}
}
}
catch
(
IOException
ex
){
throw
new
IOException
(
"解压归档文件出现异常"
,
ex
);
}
finally
{
try
{
if
(
tarIn
!=
null
){
tarIn
.
close
();
}
}
catch
(
IOException
ex
){
throw
new
IOException
(
"关闭tarFile出现异常"
,
ex
);
}
}
}
/**
* 构建目录
* @param outputDir
* @param subDir
*/
public
static
void
createDirectory
(
String
outputDir
,
String
subDir
)
{
File
file
=
new
File
(
outputDir
);
//子目录不为空
if
(!(
subDir
==
null
||
subDir
.
trim
().
equals
(
""
)))
{
file
=
new
File
(
outputDir
+
"/"
+
subDir
);
}
if
(!
file
.
exists
())
{
if
(!
file
.
getParentFile
().
exists
())
file
.
getParentFile
().
mkdirs
();
file
.
mkdirs
();
}
}
/**
* 复制文件夹
...
...
编辑
预览
Markdown
格式
0%
请重试
or
添加新附件
添加附件
取消
您添加了
0
人
到此讨论。请谨慎行事。
先完成此消息的编辑!
取消
想要评论请
注册
或
登录