调试手机中数据库的福音:Android-Debug-Database
2603297241
8年前
<p>目前在"浏览器"中调试App越来越流行.</p> <p>比如非死book开源的一个工具Stetho让Chrome调试Android. </p> <p>本文介绍了一个开源项目"Android-Debug-Database".</p> <p>他可以在浏览器中调试DB</p> <p>涉及到"取数据-起服务-远程调用", 希望对大家有用哦</p> <h2><strong>前言</strong></h2> <p>一般,我们调试手机中的数据库是很麻烦的,通常来说是如下几种方式:</p> <ol> <li> <p>将手机中的SQLite数据库导出到电脑,通过电脑端的软件来查看这个数据库,执行相关的SQL语句,看结果如何。</p> </li> <li> <p>Root手机,在手机上安装RE文件管理器,进入应用程序的包下,找到你的数据库的文件,然后再查看数据库中。</p> </li> <li> <p>Android Studio有相关的插件,方便操作,但是有的需要收费,使用起来也不是很爽。</p> </li> </ol> <p>现在, AMIT SHEKHAR 开源了 <strong> Android-Debug-Database </strong> ,利用这个库,我们可以通过浏览器方便的查看的数据库啦,并且可以执行SQL语句,岂不是很爽!</p> <h2>特色</h2> <ol> <li> <p>可以查看你的应用中所有的数据库。</p> </li> <li> <p>可以查看你的应用中所有的shared preferences(额外福利)。</p> </li> <li> <p>对你指定的数据库执行SQL语句。</p> </li> <li> <p>对你指定的数据库中的数据进行可视化的编辑。</p> </li> <li> <p>将数据库直接下载下来。</p> </li> </ol> <h2>如何使用</h2> <p>在你的build.gradle添加如下: debugCompile 'com.amitshekhar.android:debug-db:1.0.0' debugCompile的作用:只在你debug编译时起作用,当你release的时候就没必要使用它了。</p> <p>这就完了,你不需要任何其他的代码啦。</p> <p>下面当你在App启动的时候,你要注意查看下你的logcat,会有这么一行: D/DebugDB: Open http://XXX.XXX.X.XXX:8080 把它复制到你电脑的浏览器,你就可以看到你的App中的数据库,和shared preferences</p> <p>界面如下:</p> <p style="text-align:center"><img src="https://simg.open-open.com/show/50fed3bb9376b77d32594c330ed0058a.jpg"></p> <h2>原理</h2> <p style="text-align:center">整体结构如下:</p> <p style="text-align:center"><img src="https://simg.open-open.com/show/0803297882d1cb2bf36406c8a6c6f24e.png"></p> <p>DebugDB为你的应用程序开启了一个线程:</p> <p style="text-align:center"><img src="https://simg.open-open.com/show/ec2306968173766fe58333f9de15ae8c.jpg"></p> <p>这个线程不断的处理浏览器发过来的请求(Socket形式)</p> <p style="text-align:center"> <img src="https://simg.open-open.com/show/d8a75c12201b892afdfcc0630d32068d.jpg"></p> <p>根据Socket发过来的内容,它进行判断:根据不同的请求,处理,返回不同的结果:</p> <p style="text-align:center"> <img src="https://simg.open-open.com/show/f0a76e836facdf29f351b535479dc75e.jpg"></p> <p>其他:浏览器中的内容从哪里来的?为啥它能发送请求数据? debug-db将具有交互性的html发送给了浏览器:</p> <p style="text-align:center"><img src="https://simg.open-open.com/show/5dccb0922322f4c8cfbe4028f046e3ef.jpg"></p> <p>浏览器有的交互能力,基于html js 这些设计到了前端知识,有时间再聊呗~~</p> <h2> </h2> <p> </p> <p>来自:http://mp.weixin.qq.com/s?__biz=MzI0NTcxNTg5Mg==&mid=2247483976&idx=1&sn=617ba1d4223834615ddcb58b1fc98863&chksm=e94b0493de3c8d8552fd2526a856eebe8a3935898221b385b86e603971422042ba61246e4e5d&mpshare=1&scene=23&srcid=03017hZbacQABIhyeAZWRUXE#rd</p> <p> </p>