首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Xamarin表单,sqlite-net-pcl,Android数据库文件位置

Xamarin表单,sqlite-net-pcl,Android数据库文件位置
EN

Stack Overflow用户
提问于 2018-12-06 19:10:55
回答 1查看 503关注 0票数 0

我在Xamarin Forms应用程序中使用SQLite (通过"sqlite-net-pcl“nuget包),该应用程序运行在不同版本的安卓系统上。

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

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

代码语言:javascript
复制
System.IO.Path.Combine(Environment.GetFolderPath(System.Environment.SpecialFolder.Personal), "database.db")

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

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

谁能告诉我如何获得“下载”文件夹的路径,或者甚至如何到达该文件夹的父文件夹,以便我可以创建自己的子文件夹?我怀疑我将需要使用Android.OS.Environment.DirectoryDownloads或类似的东西,但我似乎就是无法正确地做到这一点。

谢谢。

EN

回答 1

Stack Overflow用户

发布于 2018-12-06 20:46:02

你可以在Android上原生做这件事,就像这样:

代码语言:javascript
复制
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卡的权限,如下所示。

代码语言:javascript
复制
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />

此外,您可能需要更改检查运行时权限(如果尚未提供)。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/53650110

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档