Microsoft.EntityFrameWork 中的 SQLite 加密

问题描述

我目前正在尝试在使用 Microsoft 实体框架时使用官方 SEE 扩展来加密 sqlite 数据库

我可以在使用 ADO.NET 时加密数据库。但是收到错误“您在连接字符串中指定了密码,但本机 sqlite 库‘e_sqlite3不支持加密” 使用实体框架时。

使用的 Nuget 包:

[Microsoft.EntityFrameWork.Core Microsoft.EntityFrameWork.Core.sqlite sqlite.Encryption.Extension System.Data.sqlite.Core]

请您建议如何使用官方 SEE 扩展程序修复此错误

CustomDBContext.cs:

private readonly bool _created = false;

public CustomDbContext(DBContextOptions<CustomDbContext> options):base(options){

if(!_created)
{
_created = true;
Database.EnsureCreated();
}
}

public DbSet<SampleEntity> SampleEntities {get; set;}

Program.cs:

static void Main(string[] args)
{
var services = new ServiceCollection();
ConfigureService(services);
using ServiceProvider provider = services.BuildServiceProvider();
provider.GetService<ICustomDBContext>();
}

private static void ConfigureServices(ServiceCollection services)
{
string password = Convert.ToHexString(Encoding.Default.GetBytes("aes256:test");

sqliteCommand.Execute("PRAGMA activate_extensions='see-7bb07b8d471d642e'",sqliteExecuteType.NonQuery,@"Data Source=c:\users\test.db");

sqliteConnectionStringBuilder connectionStringBuilder = new(){
ConnectionString = @"Data Source=c:\users\test.db;Password="+password};

sqliteConnection conn = new(connectionStringBuilder.ConnectionString);

connection.open();
connection.ChangePassword(password);
services.AddDbContext<CustomDBContext>(options => options.Usesqlite(connection));
}

解决方法

要使用官方 SQLite 扩展进行加密,请选择实体框架直到 EF6,因为 System.Data.SQLite 库只支持到 EF6,不直接支持 EF 核心。

如果我们仍然需要使用实体框架核心,那么我们也可以考虑使用其他选项,例如使用支持 EF 核心的 SQLCipher 进行加密。

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...