Xamarin Forms,sqlite-net-pcl,Android数据库文件位置

时间:2018-12-06 11:10:55

标签: android sqlite xamarin

我正在通过各种版本的Android运行的Xamarin Forms应用程序中使用SQLite(通过“ sqlite-net-pcl” nuget包)。

出于诊断目的,我需要使数据库文件可下载到PC(即使仅在调试模式下也是如此),但似乎无论我将其放在哪个Android文件夹中,之后都找不到。

(默认情况下)我正在将文件放置在...

System.IO.Path.Combine(Environment.GetFolderPath(System.Environment.SpecialFolder.Personal), "database.db")

请注意,在上面我使用的是Mono库而不是Android库来查找文件夹。

我已经尝试了大多数“ Environment.SpecialFolder”选项,理想情况下,我希望确定当通过USB从PC浏览到该设备时可使用的“ Downloads”文件夹路径的方法(此PC \ MyDevice \内部共享存储\下载),但我无法找到一种方法来确定该文件夹在不同设备和Android版本之间的位置。

有人可以告诉我如何获取该“下载”文件夹的路径,或者甚至如何获取该文件夹的父目录,以便我可以创建自己的子文件夹吗?我怀疑我将需要使用Android.OS.Environment.DirectoryDownloads或类似软件,但我似乎无法正确使用该软件。

谢谢。

1 个答案:

答案 0 :(得分:0)

您可以在Android上本地执行以下操作:

File sd = Environment.GetExternalStoragePublicDirectory(Environment.ExternalStorageDirectory.Path);
if(sd.CanWrite())
{
       string currentDBPath = sqlConnectionObj.DatabasePath;
       string backupDBPath = "backupname.db";
       File currentDB = new File(currentDBPath);
       File backupDB = new File(sd, backupDBPath);
       if(currentDB.Exists())
        {
           FileChannel src = new FileInputStream(currentDB).Channel;
           FileChannel dst = new FileOutputStream(backupDB).Channel;
           dst.TransferFrom(src, 0, src.Size());
           src.Close();
           dst.Close();          
        }
}          

这应该在您的SD卡根路径中创建一个数据库文件

是的,别忘了设置清单中SD卡上的写入权限,如下所示。

<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />

如果还不可用,您可能还必须更改检查运行时权限。