CQM*_*CQM 104 database android adb android-sqlite internal-storage
在非root用户设备上,我可以使用run-as带有我的包名称的命令导航到包含数据库的数据文件夹.我满意的大多数文件类型只是查看,但我想从Android设备拉数据库.
是否有一个download copy或move亚行外壳,这部分命令?我想下载数据库文件并使用数据库浏览器查看其内容.
这里的一个答案涉及将整个应用程序包转换为压缩存档,但是一旦完成并移动到机器上,如何提取该存档就没有进一步的答案,当我可能有一个更直接的解决方案开始
Ale*_* P. 218
通过userAndroid的设计构建(这是你在手机上解锁引导程序并用手机userdebug或eng软件刷机)限制访问内部存储 - 每个应用程序只能访问自己的文件.幸运的是软件开发商不愿意根自己的手机谷歌提供了一种方式来访问内部存储的可调试使用它们的软件包的版本run-as命令.
要从/data/data/debuggable.app.package.name/databases/fileAndroid 5.1+设备下载,请运行以下命令:
adb exec-out run-as debuggable.app.package.name cat databases/file > file
要一次下载文件夹中的多个文件/data/data/debuggable.app.package.name/- 请使用tar:
adb exec-out run-as debuggable.app.package.name tar c databases/ > databases.tar
adb exec-out run-as debuggable.app.package.name tar c shared_prefs/ > shared_prefs.tar
mar*_*mor 69
接受的答案对我来说不再有效(被Android阻止?)
所以我这样做了:
> adb shell
shell $ run-as com.example.package
shell $ chmod 666 databases/file
shell $ exit                                               ## exit out of 'run-as'
shell $ cp /data/data/package.name/databases/file /sdcard/
shell $ run-as com.example.package
shell $ chmod 600 databases/file
> adb pull /sdcard/file .
Ift*_*fta 14
如果有人想从调试应用程序中提取数据库,可以使用以下过程:
- 搜索并打开设备文件资源管理器
- 选择您的手机,然后浏览到
data/data目录
- 现在找到您的应用程序包并转到数据库文件夹.您可以在那里看到数据库,然后右键单击,您将获得将其保存在驱动器中的选项.
我发布了一个简单的shell脚本来转储数据库:
它执行两种不同的方法:
\r某些设备输出到shell的字符.从这里您可以使用各种CLI或GUI SQLite应用程序,如sqlite3或sqlitebrowser,来浏览数据库的内容.
我无法为我工作,但这个:
adb shell
run-as package.name
cat /databases/databaseFileName.db > /sdcard/copiedDatabaseFileName.db
exit
exit
adb pull /sdcard/copiedDatabaseFileName.db /file/location/on/computer/
第一个出口是退出run-as,第二个出口是退出adb shell以进行拉取.
adb exec-out run-as xxx.yyy.zzz cat somefile > somefile对于应用程序的调试版本,使用命令提取单个文件非常方便。但您必须对多个文件执行多次。这是我用来提取目录的简单脚本。
#!/bin/bash
P=
F=
D=
function usage()
{
    echo "$(basename $0) [-f file] [-d directory] -p package"
    exit 1
}
while getopts ":p:f:d:" opt
do
    case $opt in
        p)
            P=$OPTARG
            echo package is $OPTARG
            ;;
        f)
            F=$OPTARG
            echo file is $OPTARG
            ;;
        d)
            D=$OPTARG
            echo directory is $OPTARG
            ;;
        \?)
            echo Unknown option -$OPTARG
            usage
            ;;
        \:)
            echo Required argument not found -$OPTARG
            usage
            ;;
    esac
done
[ x$P == x ] && {
    echo "package can not be empty"
    usage
    exit 1
}
[[ x$F == x  &&  x$D == x ]] && {
    echo "file or directory can not be empty"
    usage
    exit 1
}
function file_type()
{
    # use printf to avoid carriage return
    __t=$(adb shell run-as $P "sh -c \"[ -f $1 ] && printf f || printf d\"")
    echo $__t
}
function list_and_pull()
{
    t=$(file_type $1)
    if [ $t == d ]; then
        for f in $(adb shell run-as $P ls $1)
        do
            # the carriage return output from adb shell should
            # be removed
            mkdir -p $(echo -e $1 |sed $'s/\r//')
            list_and_pull $(echo -e $1/$f |sed $'s/\r//')
        done
    else
        echo pull file $1
        [ ! -e $(dirname $1) ] && mkdir -p $(dirname $1)
        $(adb exec-out run-as $P cat $1 > $1)
    fi
}
[ ! -z $D ] && list_and_pull $D
[ ! -z $F ] && list_and_pull $F
希望它会有所帮助。该脚本也可以在gist上找到。
典型用法是
$ ./exec_out.sh -p com.example.myapplication -d databases
然后它会将您的应用程序数据库目录(即 )下的所有文件提取/data/data/com.example.myapplication/databases到当前目录中。
| 归档时间: | 
 | 
| 查看次数: | 78962 次 | 
| 最近记录: |