通過註解完美解決混淆問題
混淆是程式碼安全一個很有效的措施,防止程式碼在市場中裸奔,Android studio通過寫proguard-rules.pro檔案來混淆,mainfest中的類不混淆,四大元件和Application的子類和Framework層下所有的類預設不會進行混淆,對於四大元件是不可以混淆的,之前還有人和我爭論過,manifest中需要的是配置完整路徑,一旦混淆了,路徑或者名稱就變了,怎麼還能找到?
第三方會提供防混淆程式碼,避免必要的包和類被混淆掉,但是對於一些日常開發中使用proguard-rules.pro檔案來混淆會有一下弊端:
- 靈活性差,需要絕對路徑
- 不便於擴充套件,每次都需要去proguard-rules.pro檔案下配置
- 冗餘太多,比如一個包下面部分類不需要混淆,這就造成了一堆混淆程式碼
既然混淆檔案中可以保留指定的註解,那何不使用註解來解決上面所述的一大堆問題呢?程式碼量很少,卻很有用,如下:
/**
* 可配置類,方法,屬性,配置後,將不會被混淆
* Created by apple on 2017/8/3.
*/
@Retention(RetentionPolicy.CLASS)
@Target({ElementType.TYPE, ElementType.METHOD, ElementType.CONSTRUCTOR, ElementType.FIELD})
public @interface KeepNotProguard {
}
proguard-rules.pro檔案下需要如下配置:
-keep @com.zero.framework.annotation.KeepNotProguard class * {*;}
-keep class * {
@com.zero.framework.annotation.KeepNotProguard <fields>;
}
-keepclassmembers class * {
@com.zero.framework.annotation.KeepNotProguard <methods>;
}
gradle檔案如下:
buildTypes {
release {
minifyEnabled true
proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
}
}
預設的minifyEnabled是false,改為true才會進行混淆。
下面做一組對比,如下:
/**
* Created by Zero on 2017/5/31.
*/
public class TestPresenter extends BasePresenter {
private ITest iView;
private int test = -1;
@Override
protected void initBaseData(Context context, Handler handler, BaseInterface iView, Intent intent) {
if (iView!=null) {
if (iView instanceof ITest) {
this.iView = (ITest) iView;
}
}
}
@Override
protected void handMsg(Message msg) {
}
public void commit(){
}
public void getCommit() {
}
}
在需要使用的地方只需要一個註解就可以搞定,示例如下:
/**
* Created by Zero on 2017/5/31.
*/
public class TestPresenter extends BasePresenter {
@KeepNotProguard
private ITest iView;
private int test = -1;
@Override
@KeepNotProguard
protected void initBaseData(Context context, Handler handler, BaseInterface iView, Intent intent) {
if (iView!=null) {
if (iView instanceof ITest) {
this.iView = (ITest) iView;
}
}
}
@Override
@KeepNotProguard
protected void handMsg(Message msg) {
}
public void commit(){
}
public void getCommit() {
}
}
PS:以上只是一個示例,在類上加了@KeepNotProguard整個類便不會被混淆。
對於反編譯沒了解的,可以通過Android逆向分析之反編譯 、Android逆向分析之從Smali到java 獲取,部落格中附上反編譯工具下載地址。
專案已上傳,戳此進入github。
微信掃我^_^
相關文章
- 通過Observable解決搜尋框問題
- 通過 sysprocesses 解決Sql死鎖問題SQL
- “正在註冊字型”問題解決
- SpringBoot中通過CORS解決跨域問題Spring BootCORS跨域
- 解決機器學習問題有通法機器學習
- [轉]Android專案原始碼混淆問題解決方法Android原始碼
- spring通過註解配置Spring
- 解決「問題」,不要解決問題
- 解決Mysql中只能通過localhost登陸不能通過ip登陸的問題MySqllocalhost
- 通過IPFS技術解決NFT的永久儲存問題
- 通過nginx中轉獲取不到IP的問題解決Nginx
- oracle 通過trigger解決drop許可權問題Oracle
- 完美解決jspdf各種中文亂碼問題JS
- 移動端滾動穿透問題完美解決方案穿透
- Activity 與 Fragment 通訊(99%)完美解決方案Fragment
- 【譯】Python 是解決任何問題的完美工具Python
- TCP通訊之經典問題解決TCP
- 一個lua問題解決過程
- 解決超過會話數問題會話
- 詳解Dart中如何通過註解生成程式碼Dart
- base64碼通過http傳輸 +號變 空格 問題解決HTTP
- 解決問題
- 關於Mysql 4.1語言問題的完美解決方法(轉)MySql
- shell指令碼中文註釋亂碼問題(解決)指令碼
- Trace檔案過量生成問題解決
- munium學習過程中問題解決
- 解決Android通過BitmapFactory獲取圖片寬高度相反的問題Android
- 在Terminal中通過代理訪問GitHub(解決訪問GitHub速度慢的問題)Github
- 完美解決setInterval在瀏覽器切換時加速的問題瀏覽器
- 完美解決html中select的option不能隱藏的問題。HTML
- 不修改任何檔案,完美解決QQ與360共存問題
- 完美解決微耕門禁系統提示驅動版本過低返廠升級問題
- yum問題解決
- sqlitedabaseislocked問題解決SQLite
- dump 解決問題
- 解決Eclipse中文註釋部分亂碼的問題Eclipse
- 解決tomcat伺服器下,只能通過localhost,而不能通過127.0.0.1或者本地ip地址訪問的問題Tomcat伺服器localhost127.0.0.1
- 發現問題,解決問題