创建一个带有Monotuch的SQLite数据库-拒绝权限



我正在尝试使用Monotouch 3.0.3.4创建一个Sqlite数据库。在iPhone模拟器上一切都很好,但我在测试iPhone上得到了以下错误:

DataLayer.CreateDatabase异常:System.UnauthorizedAccessException:拒绝访问路径"/private/var/mobile/Applications/4B4944BB-EC37-4B0C-980C-1A9B60DACB44/TestApp.app/myDatabase.db3"。

这是我正在使用的代码:

// creates database and tables if they do not exist.
public void CreateDatabase ()
{
string sql = string.Empty;
string dbFileName = "myDatabase.db3";
try {
          if (!File.Exists (dbFileName)) {
    // create database
    SqliteConnection.CreateFile (dbFileName);  //This is where the error occurs
    Console.WriteLine ("CreateDatabase: Database created."); 
            ... 
    }  
      catch (Exception ex) {
        Console.WriteLine ("CreateDatabase Exception: " + ex.ToString ());
    }
    ...

我也尝试过指定个人文件夹,但没有效果。我需要做些什么来确保权限是正确的?

谢谢!

单色3.0.3.4

这很可能是MonoDevelop 3.0.3.4。请参阅关于MonoDevelop获取MonoTouch版本。

"/private/var/mobile/Applications/4B4944BB-EC37-4B0C-980C-1A9B60DACB44/TestApp.app/myDatabase.db3"

在设备上,应用程序是经过签名的,因此它们的内容不能更改(不破坏签名)。因此,不允许更改.app目录中的内容。

您应该在Documents目录中创建(或复制)数据库,然后以读写方式打开数据库。

有关更多详细信息,请参阅链接文章。

最新更新