标签:style blog http java 使用 io strong 文件 ar
最近一直在研究代码混淆,其中发现一个问题,就是我们定义的一些公用的常量在代码混 淆后,经过反编译,竟然完完整整的显示在我的眼前,比如服务请求地址,竟然以完整路径的形式显示在混淆后的代码中,比自己定义的还要完整,要是这样的话, 代码混淆还有意义吗?当时很郁闷,不过又一想,常量肯定是不能被混淆的,若常量被混淆,1混成个2,其它地方再去引用必然会出错啊,那这怎么办呢?又想进 行混淆,又不想让比较重要的常量明目张胆的显示?办法肯定是有的,只是你愿不愿去思考。我们可以对比下原项目和混淆后解压出来的项目结构,你就知道该怎么 做了:
看到区别了吗,对,区别就在values文件夹,由此可以想到什么?我们可以把相关常 量定义在values文件夹下的string.xml资源文件里,在代码中用getString(R.string.xxx)就可以引用了,这样反编译后 的代码里,是不会再出现明文形式的常量内容了。
可能还有些童鞋不太明白到底该怎样做,现在博主说一下大致方法:
我们通常会在项目中定义一个公共类如:Const.java,其中包含了很多经常使用的常量(包括服务地址)如:
这种写法,经过反编译是很容易看到的,按我说的方法,应该是这样的:
然后在string.xml里定义一个server_ip的值:
接着在自己项目中的Application的onCreate方法中为常量Const.SERVER_IP赋值:
标签:style blog http java 使用 io strong 文件 ar
原文地址:http://www.cnblogs.com/yido9932/p/3937021.html