Skip to content
项目
群组
代码片段
帮助
正在加载...
登录
切换导航
E
estateplat-encrypt
项目
项目
详情
活动
周期分析
仓库
仓库
文件
提交
分支
标签
贡献者
分枝图
比较
统计图
议题
0
议题
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
CI / CD
CI / CD
流水线
作业
日程
统计图
Wiki
Wiki
代码片段
代码片段
成员
成员
折叠边栏
关闭边栏
活动
分枝图
统计图
创建新议题
作业
提交
议题看板
打开侧边栏
狄熙卜
estateplat-encrypt
Commits
9bafec32
提交
9bafec32
authored
3月 28, 2024
作者:
liyinqiao
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
可能存在Map中value是个List<Map>或是Map,可能存在需要内部结构的key做加密的场景,增加对value内部结构加解密处理逻辑
上级
af624763
显示空白字符变更
内嵌
并排
正在显示
1 个修改的文件
包含
7 行增加
和
9 行删除
+7
-9
MapCryptHandler.java
.../cn/gtmap/bdcdj/core/encrypt/handler/MapCryptHandler.java
+7
-9
没有找到文件。
src/main/java/cn/gtmap/bdcdj/core/encrypt/handler/MapCryptHandler.java
浏览文件 @
9bafec32
...
...
@@ -6,19 +6,14 @@ import org.apache.commons.collections.MapUtils;
import
org.apache.commons.lang3.StringUtils
;
import
org.springframework.util.LinkedCaseInsensitiveMap
;
import
java.util.ArrayList
;
import
java.util.List
;
import
java.util.Map
;
import
java.util.Set
;
import
java.util.*
;
public
class
MapCryptHandler
implements
CryptHandler
{
@Override
public
Object
encrypt
(
Object
param
,
CryptProperties
cryptProperties
,
String
mapid
)
{
Map
map
=
(
Map
)
param
;
List
<
String
>
encryptKeyList
=
getMapEncryptKeys
(
map
,
mapid
,
cryptProperties
);
if
(
CollectionUtils
.
isEmpty
(
encryptKeyList
)){
return
param
;
}
else
{
// liyinqiao 获取最外层的key中有加密配置的key集合 也有可能是内部结构的key需要加密,所以去掉判空直接返回的逻辑。
List
<
String
>
encryptKeyList
=
getMapEncryptKeys
(
map
,
mapid
,
cryptProperties
);
Map
encryptParam
=
new
LinkedCaseInsensitiveMap
(
map
.
size
());
Set
<
Map
.
Entry
>
set
=
map
.
entrySet
();
if
(
CollectionUtils
.
isNotEmpty
(
set
)){
...
...
@@ -27,6 +22,10 @@ public class MapCryptHandler implements CryptHandler{
Object
value
=
entry
.
getValue
();
if
(
encryptKeyList
.
contains
(
key
.
toLowerCase
())){
encryptParam
.
put
(
key
,
CryptHandlerFactory
.
getCryptHandler
(
value
).
encrypt
(
value
,
cryptProperties
,
mapid
));
}
else
if
(
value
!=
null
&&
!(
value
instanceof
String
)){
// liyinqiao Map 的 value 非是普通字符串时 需要对内部结构做加密
Object
enCodeParam
=
CryptHandlerFactory
.
getCryptHandler
(
value
).
encrypt
(
value
,
cryptProperties
,
mapid
);
encryptParam
.
put
(
key
,
enCodeParam
);
}
else
{
encryptParam
.
put
(
key
,
value
);
}
...
...
@@ -34,7 +33,6 @@ public class MapCryptHandler implements CryptHandler{
}
return
encryptParam
;
}
}
private
List
<
String
>
getMapEncryptKeys
(
Map
map
,
String
mapid
,
CryptProperties
cryptProperties
)
{
List
<
String
>
result
=
new
ArrayList
<
String
>();
...
...
编写
预览
Markdown
格式
0%
重试
或
添加新文件
添加附件
取消
您添加了
0
人
到此讨论。请谨慎行事。
请先完成此评论的编辑!
取消
请
注册
或者
登录
后发表评论