我想在我部署的设备上查看我的应用程序中创建的数据库内容。我可以在模拟器中使用sqlite命令查看,但无法在真实设备上查看。有人知道如何在真实设备中进行操作吗?
如果应用程序被标记为 debuggable,则不需要 root 权限。您可以使用 run-as
adb 命令。
例如,要使用 sqlite:
adb shell "run-as com.your.package sqlite3 databases/database_name"
adb shell "run-as com.your.package cat databases/database_name > /sdcard/some_name"
adb pull /sdcard/some_name
实际上您的真实设备没有被root,因此您没有权限访问/data/data/<Application>/database/
目录。
唯一的解决方案是将该文件复制到外部存储,并通过SQLiteManager或任何其他SQLite工具查看它。
试试这个,
你可以将数据库复制到SD卡中,这样你就可以看到你的数据库了。
public void backup() {
try {
File sdcard = Environment.getExternalStorageDirectory();
File outputFile = new File(sdcard,
"YourDatabase.db");
if (!outputFile.exists())
outputFile.createNewFile();
File data = Environment.getDataDirectory();
File inputFile = new File(data,
"data/"+getPackageName()+"/databases/"+"YourDatabase.db");
InputStream input = new FileInputStream(inputFile);
OutputStream output = new FileOutputStream(outputFile);
byte[] buffer = new byte[1024];
int length;
while ((length = input.read(buffer)) > 0) {
output.write(buffer, 0, length);
}
output.flush();
output.close();
input.close();
} catch (IOException e) {
e.printStackTrace();
throw new Error("Copying Failed");
}
}
copyFile(new File("data/data/<app>/database"),new File("mnt/sdcard/...."))
。public void copyFile(File filesrc, File filedst)
{
try
{
FileInputStream localFileInputStream = new FileInputStream(filesrc);
FileOutputStream localFileOutputStream = new FileOutputStream(filedst);
byte[] arrayOfByte = new byte[1024];
while (true)
{
int i = localFileInputStream.read(arrayOfByte);
if (i == -1)
{
localFileOutputStream.close();
localFileInputStream.close();
break;
}
localFileOutputStream.write(arrayOfByte, 0, i);
}
}
catch (Exception localException)
{
Log.d("XXX", "ExceptioncopyFile:" + localException.getMessage(), localException);
}
}
run-as
(甚至最近也是如此,例如问题58373)。 - bwt