Stetho简化Android调试(一)

在开发 Android 应用的时候,有时候我们需要查看数据库SharePreference等。通常的做法是把相关文件pull出来,而前提必须是手机得root。如果没有root,那就只能通过打印或其它方式查看,整个过程非常麻烦。

ChromeDeveloper ToolsWeb前端开发带来很大便捷。StethoFacebook开源的一个工具,我们借助Stetho结合Developer Tools,能够很轻松直观的调试、查看 Android 应用中的数据。

使用步骤


  1. 添加依赖
dependencies { 
    compile 'com.facebook.stetho:stetho:1.3.1' 
    // 如果需要查看网络请求信息(根据需要,选择依赖)
    compile 'com.facebook.stetho:stetho-okhttp3:1.3.1'  // 使用okhttp3作为网络底层库
    compile 'com.facebook.stetho:stetho-okhttp:1.3.1' // 使用okhttp作为网络底层库 
    compile 'com.facebook.stetho:stetho-urlconnection:1.3.1' // 使用urlconnection作为网络底层库
} 
  1. Application中初始化
public class MyApplication extends Application {
  
  public static OkHttpClient okHttpClient;

  public void onCreate() {
    super.onCreate();
    //  一般使用默认初始化配置足够使用
    Stetho.initializeWithDefaults(this);
    // 如果需要查看网络请求相关信息(以使用okhttp3为例)
    initOkHttpClient();
  }

  private void initOkHttp() {
      okHttpClient =  new OkHttpClient()
            .newBuilder()
            .addNetworkInterceptor(new StethoInterceptor()) // 这里添加一个拦截器即可
            .build();
  }

}

至此,我们的应用配置完毕。是不是超级简单?
接下来看怎么使用Developer Tools查看应用的各种信息。

  1. 打开Chrome输入chrome://inspect
inspect

如果第1、2步配置正确的话,就可以看到以上页面。点击inspec

Developer Tools

注意:如果第一次启动,这个页面有可能会一片空白。因为Developer Tools在连接远程服务器,这个连接需要科学上网。如果页面加载成功后再次打开,就不需要科学上网了。

Developer Tools功能说明


  1. Elements
Elements

就像uiautomatorviewer.bat工具一样,可以查看页面视图的层级结构。

  1. Network
Network

网络请求的会话信息都包含在这里,可以点击单个会话到详情,查看具体的报文信息。如下:

Network Detail
  1. Resources
Resources

在这个选项卡里面,就可以查看应用保存的信息,包括SharePreference数据库,并且可以执行SQL语句,直接修改SharePreference的内容。如下:

Web SQL
SharePreference
  1. Console
Console

该控制台允许使用JavaScript代码与应用程序Android SDK交互。如下:

Console Result
context.getResources().getString(R.string.app_name);

运行以上代码可以得到应用下对应的字符串资源。

importPackage(android.util);
Log.d("WaitingAnd", "chuang");

运行以上代码可以在Logcat打印一条日志。

importPackage(android.widget);
importPackage(android.os);
var handler = new Handler(Looper.getMainLooper());
handler.post(function() { Toast.makeText(context, "Hello Stetho", Toast.LENGTH_LONG).show() });

运行以上代码可以在应用中直接显示Toast

注意:使用Console功能需要添加依赖,否则会提示Not supported without stetho-js-rhino dependency

compile 'com.facebook.stetho:stetho-js-rhino:1.4.2'
  1. Screencast
Screencast
赶快用起来吧!_


作者:WaitingAnd
链接:https://www.jianshu.com/p/42303aa8299a
來源:简书
简书著作权归作者所有,任何形式的转载都请联系作者获得授权并注明出处。
posted @   mingruqi  阅读(817)  评论(0编辑  收藏  举报
编辑推荐:
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
阅读排行:
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· 单线程的Redis速度为什么快?
· 展开说说关于C#中ORM框架的用法!
· Pantheons:用 TypeScript 打造主流大模型对话的一站式集成库
点击右上角即可分享
微信分享提示