当我们在以下代码上运行 proguard 时,它应该删除 Logging 语句:
Log.d(TAG, "field= "+field+“ : enhancedfield=”+enhancedfield);
但是...编译后你会看到:
Log.d(TAG, new StringBuilder().append("Field= ").append(field)
.append(“ : enhancedfield=”).append(enhancedfield).toString());
现在,当我们对此运行 proguard 时,你会得到一些剩菜:
new StringBuilder().append("Field= ").append(field)
.append(“ : enhancedfield=”).append(enhancedfield).toString();
这会将信息泄露给潜在的黑客......
我能做什么:声明一个final static boolean
并且仅在值为true
. 因为该值可以在编译时确定,所以当该值为 false 时将不包含日志记录代码。但这污染了我的代码,所以我对此并不满意。
现在我的问题:我怎样才能改善这种行为?留下更少的剩菜并泄露更少的信息?