前言
一般,我们调试手机中的数据库是很麻烦的,通常来说是如下几种方式:
- 将手机中的SQLite数据库导出到电脑,通过电脑端的软件来查看这个数据库,执行相关的SQL语句,看结果如何。
- Root手机,在手机上安装RE文件管理器,进入应用程序的包下,找到你的数据库的文件,然后再查看数据库中。
- Android Studio有相关的插件,方便操作,但是有的需要收费,使用起来也不是很爽。
现在,AMIT SHEKHAR开源了Android-Debug-Database,利用这个库,我们可以通过浏览器方便的查看的数据库啦,并且可以执行SQL语句,岂不是很爽!
特色
- 可以查看你的应用中所有的数据库。
- 可以查看你的应用中所有的shared preferences(额外福利)。
- 对你指定的数据库执行SQL语句。
- 对你指定的数据库中的数据进行可视化的编辑。
- 将数据库直接下载下来。
如何使用
在你的build.gradle添加如下:
debugCompile 'com.amitshekhar.android:debug-db:1.0.0'
debugCompile的作用:只在你debug编译时起作用,当你release的时候就没必要使用它了。
这就完了,你不需要任何其他的代码啦。
下面当你在App启动的时候,你要注意查看下你的logcat,会有这么一行:
D/DebugDB: Open http://XXX.XXX.X.XXX:8080
把它复制到你电脑的浏览器,你就可以看到你的App中的数据库,和shared preferences
界面如下:
原理
整体结构如下:
DebugDB为你的应用程序开启了一个线程:
这个线程不断的处理浏览器发过来的请求(Socket形式)
根据Socket发过来的内容,它进行判断:根据不同的请求,处理,返回不同的结果:
其他:
浏览器中的内容从哪里来的?为啥它能发送请求数据?
debug-db将具有交互性的html发送给了浏览器:
浏览器有的交互能力,基于html js
这些设计到了前端知识,有时间再聊呗~~