您的位置:首页 > 移动开发 > Android开发

Android studio混淆打包日志 混淆日志 查看

2017-10-27 14:53 429 查看
一 打混淆包,带正式签名

1 编辑proguard-rules.txt文件,配置好不能混淆的类或方法,否则会报错。

a、需要反射的代码

b、系统接口

c、Jni接口

d、需要序列号和反序列化的代码(即实现Serializable、Parcelable接口的JavaBean)

e、与服务端进行元数据交互的JavaBean(JSON、XML中对应的类) 

2 检查 gradle.build文件中的buildTypes  release节点,确认minifyEnabled true

3 LogUtils工具类中关闭log的打印

4 可以直接在AS自带的命令行里面 执行gradle clean assembleRelease 打包

5 找到 ./build/outputs/apk/XXX-release.apk

  注意备份mapping文件 ./build/outputs/mapping/release/mapping.txt

二 通过mapping文件查看混淆后的报错问题:

1,进入android  sdk目录 sdk/tools/proguard/bin/proguardgui.sh   将这个文件拖到命令行中,这样就可以进入一个图形界面操作了。

2, ReTrace-->导入 mapping.txt文件,将崩溃收集器文件中的报错日志粘贴到 Obfuscated stack trace中,然后点击 ReTrace! 按钮,这样你就可以看到混淆前的代码了,定位bug当然不在话下啦!





注意:将log日志按照格式进行粘贴到:obfuscated stack trace中:

格式:为(每一行要有 【[b]at 】,不然识别不出来)[/b]

 FATAL EXCEPTION: main

                                                                        Process: com.dxiang.demozxing01, PID: 13580

                                                                        java.lang.ArithmeticException: divide by zero

                                                                            at com.dxiang.demozxing.MainActivity.onClick(MainActivity.java:131)

                                                                            at android.view.View.performClick(View.java:4444)

                                                                            at android.view.View$PerformClick.run(View.java:18457)

                                                                            at android.os.Handler.handleCallback(Handler.java:733)

                                                                            at android.os.Handler.dispatchMessage(Handler.java:95)

                                                                            at android.os.Looper.loop(Looper.java:136)

                                                                            at android.app.ActivityThread.main(ActivityThread.java:5113)

                                                                            at java.lang.reflect.Method.invokeNative(Native Method)

                                                                            at java.lang.reflect.Method.invoke(Method.java:515)

                                                                            at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:796)

                                                                            at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:612)

                                                                            at dalvik.system.NativeStart.main(Native Method)
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: