Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
qq_39073359
jadx
提交
bdb2efdb
J
jadx
项目概览
qq_39073359
/
jadx
与 Fork 源项目一致
从无法访问的项目Fork
通知
1
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
J
jadx
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
未验证
提交
bdb2efdb
编写于
2月 05, 2022
作者:
S
Skylot
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
fix(res): remove static caching map for xml renames (#1364)
上级
a27ba3ff
变更
1
显示空白变更内容
内联
并排
Showing
1 changed file
with
14 addition
and
27 deletion
+14
-27
jadx-core/src/main/java/jadx/core/xmlgen/XmlDeobf.java
jadx-core/src/main/java/jadx/core/xmlgen/XmlDeobf.java
+14
-27
未找到文件。
jadx-core/src/main/java/jadx/core/xmlgen/XmlDeobf.java
浏览文件 @
bdb2efdb
package
jadx.core.xmlgen
;
package
jadx.core.xmlgen
;
import
java.util.HashMap
;
import
java.util.Map
;
import
org.jetbrains.annotations.Nullable
;
import
org.jetbrains.annotations.Nullable
;
import
jadx.core.dex.info.ClassInfo
;
import
jadx.core.dex.info.ClassInfo
;
import
jadx.core.dex.
nodes.ClassNod
e
;
import
jadx.core.dex.
instructions.args.ArgTyp
e
;
import
jadx.core.dex.nodes.RootNode
;
import
jadx.core.dex.nodes.RootNode
;
/*
/*
* modifies android:name attributes and xml tags which are old class names
* Modifies android:name attributes and xml tags which were changed during deobfuscation
* but were changed during deobfuscation
*/
*/
public
class
XmlDeobf
{
public
class
XmlDeobf
{
private
static
final
Map
<
String
,
String
>
DEOBF_MAP
=
new
HashMap
<>();
private
XmlDeobf
()
{
private
XmlDeobf
()
{
}
}
@Nullable
@Nullable
public
static
String
deobfClassName
(
RootNode
rootNode
,
String
potencialClassName
,
String
packageName
)
{
public
static
String
deobfClassName
(
RootNode
root
,
String
potentialClassName
,
String
packageName
)
{
potencialClassName
=
potencialClassName
.
replace
(
'$'
,
'.'
);
if
(
potentialClassName
.
indexOf
(
'.'
)
==
-
1
)
{
if
(
packageName
!=
null
&&
potencialClassName
.
startsWith
(
"."
))
{
return
null
;
potencialClassName
=
packageName
+
potencialClassName
;
}
return
getNewClassName
(
rootNode
,
potencialClassName
);
}
private
static
String
getNewClassName
(
RootNode
rootNode
,
String
old
)
{
if
(
DEOBF_MAP
.
isEmpty
())
{
for
(
ClassNode
classNode
:
rootNode
.
getClasses
(
true
))
{
ClassInfo
classInfo
=
classNode
.
getClassInfo
();
if
(
classInfo
.
hasAlias
())
{
String
oldName
=
classInfo
.
getFullName
();
String
newName
=
classInfo
.
getAliasFullName
();
if
(!
oldName
.
equals
(
newName
))
{
DEOBF_MAP
.
put
(
oldName
,
newName
);
}
}
}
if
(
packageName
!=
null
&&
potentialClassName
.
startsWith
(
"."
))
{
potentialClassName
=
packageName
+
potentialClassName
;
}
}
ArgType
clsType
=
ArgType
.
object
(
potentialClassName
);
ClassInfo
classInfo
=
root
.
getInfoStorage
().
getCls
(
clsType
);
if
(
classInfo
==
null
)
{
// unknown class reference
return
null
;
}
}
return
DEOBF_MAP
.
get
(
old
);
return
classInfo
.
getAliasFullName
(
);
}
}
}
}
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录