美文网首页
Android静态代码分析

Android静态代码分析

作者: swust_cp | 来源:发表于2018-06-27 15:46 被阅读28次

    Android 静态代码分析

    • Android Studio IDE Inspections

      1. IDE默认集成,通过IDE下安装目录 <android studio path>/bin/inspect.sh 进行执行,path需要绝对路径指定。比如:

        /Applications/Android\ Studio.app/Contents/bin/inspect.sh ~/tw/android/XXX ~/tw/android/XXX/.idea/inspectionProfiles/Project_Default.xml ~/tw/android/XXX/inspect_report -v2 -d ~/tw/android/XXX/host-demo

        在执行完成后,可以将inspect_report中的xml结果,通过IDE的View Offline Inspections Result…进行加载显示。

      2. 或者通过Android Studio中的Analyze -> inpsect code执行:

        图一

        可以自定义需要检测的inpsect的scope,或者export Inspection profile,通过上述的inspect.sh执行。

        inpsect result:

        image-20180623153950310.png

        可以手动导出HMTL或者XML。使用Inspection手动检查

    • Android Lint

      1. Android lint是通过ADT引入的一个工具,通过lint --list可以查看当前ADT版本所支持的所有issues(前提需要将~/Library/Android/sdk/tools/bin加入到PATH):

        图三
      2. 运行./gradlew lint,可以得到对应project的lint report以及具体的issue信息:

        图四
      3. 配置Android lint,可以通过在build.gradle中添加lintOptions进行配置,具体可通过添加field name或者添加lint.xml文件进行配置,默认加载Project目录下的lint.xml

        常用配置说明:

        • abortOnError = true,发现Error级别Lint问题时会中断编译
        • ignoreWarnings = true,不检查Warning级别的Lint问题
        • lintConfig,默认为lint.xml,指定XML配置文件位置
        • enable,配置要检查的问题
        • disable,指定不检查的问题
        • check,指定所有要检查的问题,没有指定的都不检查
        image.png

        lint也支持自定义rule来检查,更多关于lintOptions的使用:

        Writing custom lint rules

        使用lint改进你的代码

        DSL object for configuration lint options

    • 第三方工具集成,如Checkstyle,FindBugs,PMD

      比如Checkstyle插件,运行其中一个project结果:

      image.png

    继续阅读关于lint和checkstyle的配置:Android Lint & Checkstyle

    相关文章

      网友评论

          本文标题:Android静态代码分析

          本文链接:https://www.haomeiwen.com/subject/uxabyftx.html