Skip to content
项目
群组
代码片段
帮助
当前项目
正在载入...
登录 / 注册
切换导航面板
C
cocktail-party-server
项目
项目
详情
活动
周期分析
仓库
仓库
文件
提交
分支
标签
贡献者
图表
比较
统计图
议题
0
议题
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
CI / CD
CI / CD
流水线
作业
日程
统计图
Wiki
Wiki
代码片段
代码片段
成员
成员
折叠边栏
关闭边栏
活动
图像
聊天
创建新问题
作业
提交
问题看板
Open sidebar
cocktail-party
cocktail-party-server
Commits
bd09e5b1
提交
bd09e5b1
authored
11月 01, 2021
作者:
RuoYi
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
修复字符串无法被反转义问题
上级
181f62c1
隐藏空白字符变更
内嵌
并排
正在显示
1 个修改的文件
包含
23 行增加
和
11 行删除
+23
-11
EscapeUtil.java
...src/main/java/com/ruoyi/common/utils/html/EscapeUtil.java
+23
-11
没有找到文件。
ruoyi-common/src/main/java/com/ruoyi/common/utils/html/EscapeUtil.java
浏览文件 @
bd09e5b1
...
...
@@ -69,26 +69,37 @@ public class EscapeUtil
*/
private
static
String
encode
(
String
text
)
{
int
len
;
if
((
text
==
null
)
||
((
len
=
text
.
length
())
==
0
))
if
(
StringUtils
.
isEmpty
(
text
))
{
return
StringUtils
.
EMPTY
;
}
StringBuilder
buffer
=
new
StringBuilder
(
len
+
(
len
>>
2
));
final
StringBuilder
tmp
=
new
StringBuilder
(
text
.
length
()
*
6
);
char
c
;
for
(
int
i
=
0
;
i
<
len
;
i
++)
for
(
int
i
=
0
;
i
<
text
.
length
()
;
i
++)
{
c
=
text
.
charAt
(
i
);
if
(
c
<
64
)
if
(
c
<
256
)
{
buffer
.
append
(
TEXT
[
c
]);
tmp
.
append
(
"%"
);
if
(
c
<
16
)
{
tmp
.
append
(
"0"
);
}
tmp
.
append
(
Integer
.
toString
(
c
,
16
));
}
else
{
buffer
.
append
(
c
);
tmp
.
append
(
"%u"
);
if
(
c
<=
0xfff
)
{
// issue#I49JU8@Gitee
tmp
.
append
(
"0"
);
}
tmp
.
append
(
Integer
.
toString
(
c
,
16
));
}
}
return
buffer
.
toString
();
return
tmp
.
toString
();
}
/**
...
...
@@ -145,11 +156,12 @@ public class EscapeUtil
public
static
void
main
(
String
[]
args
)
{
String
html
=
"<script>alert(1);</script>"
;
String
escape
=
EscapeUtil
.
escape
(
html
);
// String html = "<scr<script>ipt>alert(\"XSS\")</scr<script>ipt>";
// String html = "<123";
// String html = "123>";
System
.
out
.
println
(
EscapeUtil
.
clean
(
html
));
System
.
out
.
println
(
EscapeUtil
.
escape
(
html
)
);
System
.
out
.
println
(
EscapeUtil
.
unescape
(
html
));
System
.
out
.
println
(
"clean: "
+
EscapeUtil
.
clean
(
html
));
System
.
out
.
println
(
"escape: "
+
escape
);
System
.
out
.
println
(
"unescape: "
+
EscapeUtil
.
unescape
(
escape
));
}
}
编写
预览
Markdown
格式
0%
重试
或
添加新文件
添加附件
取消
您添加了
0
人
到此讨论。请谨慎行事。
请先完成此评论的编辑!
取消
请
注册
或者
登录
后发表评论