如何读取第三方应用的数据库?(PART 2)

本文继续探讨如何在Android设备上读取第三方应用的数据库。首先,由于权限限制,需要将数据库复制到公共存储区域,然后使用SQLiteDatabase进行操作。通过cat命令在获得ROOT权限后实现复制。接下来,利用sqlite_master系统表获取数据库中的表信息。最终,展示如何读取并打印表内数据,将原本复杂的过程简化。
摘要由CSDN通过智能技术生成

在上一篇文章中,我们已经获取到了某应用所创建的数据库。如何查看数据库里面的数据呢?当然可以用一些工具来查看db文件,如果我真这么告诉经理,他会不会发飙呢?在这里插入图片描述
既然这样,咱就一步到胃!呃,一步到位!既然咱们能够访问到db所在的目录,理论上是完全可以操作该文件的吧?在安卓中,我们可以通过SQLiteDatabase来操作数据库,搞一搞?停下手吧,db目前所在的目录可是私有空间呢。
在这里插入图片描述
所以,我们在操作数据库之前,需要先做一件神奇的事情,那就是复制一份db文件到公有空间。说起来简单,但是我们可以通过IO流实现嘛?显然还是会因为权限问题,以失败告终的。这个时候我们还是将希望寄托于命令行上,我们可以通过cat命令来进行文件的复制(当然还是要ROOT之后),代码如下:

public static void move(String oldPath,String newPath){
        Process process = null;
        DataOutputStream os = null;
        try{
            String cmd = "cat "+oldPath+" >&#
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值