FreeSql.Provider.SqliteCore如何加密
FreeSql.Provider.SqliteCore
是FreeSql
基于微软提供的最新的Microsoft.Data.Sqlite.Core
驱动的实现。
相关文章
支持的版本
- .NETStandard2.0+
- net6.0
由于目前处于测试阶段,可使用myget源安装FreeSql.Provider.SqliteCore
包。
dotnet add package FreeSql.Provider.SqliteCore --source https://www.myget.org/F/ncc/api/v3/index.json --prerelease
不支持加密
0.安装包。
dotnet add package SQLitePCLRaw.bundle_e_sqlite3
dotnet add package FreeSql.Provider.SqliteCore
直接正常使用其他包一样使用FreeSql即可。SQLitePCLRaw.bundle_e_sqlite3
包不支持加密,但此种方式是官方实现的SQlite
版本
捆绑 | 描述 |
---|---|
SQLitePCLRaw.bundle_e_sqlite3 | 在所有平台上提供一致版本的 SQLite 。 包括 FTS4、FTS5、JSON1 和 R* 树扩展。 建议使用 |
SQLitePCLRaw.bundle_e_sqlcipher | 提供 SQLCipher 的非官方开放源代码内部版本。 |
FreeSql.Provider.SqliteCore如何加密
那我们不安装 SQLitePCLRaw.bundle_e_sqlite3
包,换SQLitePCLRaw.bundle_e_sqlcipher
只有sqlcipher才支持加密。
0.选择一个目录,创建一个控制台项目OvOv.FreeSqlMicrosoftSqliteCore
dotnet new console -n OvOv.FreeSqlMicrosoftSqliteCore
cd OvOv.FreeSqlMicrosoftSqliteCore
1.安装包
dotnet add package SQLitePCLRaw.bundle_e_sqlcipher
dotnet add package FreeSql.Provider.SqliteCore --source https://www.myget.org/F/ncc/api/v3/index.json --prerelease
- 连接串直接指定Password=xxx即可
创建一个类g.cs
,可直接通过g.sqlite
访问到IFreeSql
对象
public class g
{
static Lazy<IFreeSql> sqliteLazy = new Lazy<IFreeSql>(() =>
{
var fsql = new FreeSql.FreeSqlBuilder()
.UseConnectionString(FreeSql.DataType.Sqlite, @"Data Source=local.db;Password=123qwe")
.UseAutoSyncStructure(true)
.UseLazyLoading(true)
.UseMonitorCommand(
cmd => Trace.WriteLine("\r\n线程" + Thread.CurrentThread.ManagedThreadId + ": " + cmd.CommandText)
)
.Build();
return fsql;
}
);
public static IFreeSql sqlite => sqliteLazy.Value;
}
测试加密,增加一些数据。Program.cs
中测试
Test();
static void Test()
{
IInsert<Topic> insert = g.sqlite.Insert<Topic>();
var items = new List<Topic>();
for (var a = 0; a < 10; a++) items.Add(new Topic { Id = a + 1, Title = $"newTitle{a}", Clicks = a * 100 });
var affrows = insert.AppendData(items).ExecuteAffrows();
Console.WriteLine("affrows:" + affrows);
var list = g.sqlite.Select<Topic>().ToList();
Console.WriteLine("count:" + list.Count);
}
[Table(Name = "tb_topic_insert")]
class Topic
{
[Column(IsIdentity = true, IsPrimary = true)]
public int Id { get; set; }
public int Clicks { get; set; }
public string Title { get; set; }
public DateTime CreateTime { get; set; }
}
运行项目
dotnet run
验证是否登录是否加密?
重新运行时,删除 连接串中的Password,发现无法获取数据。或使用Navicat Premium
工具发现无法连接。
+ .UseConnectionString(FreeSql.DataType.Sqlite, @"Data Source=local.db;")
- .UseConnectionString(FreeSql.DataType.Sqlite, @"Data Source=|DataDirectory|local.db;Password=123qwe")
提示如下内容,但使用密码时又能正常访问数据。
SqliteException: SQLite Error 26: 'file is not a database'.
相比包 FreeSql.Provider.Sqlite
来说,目前存在一些限制,
|DataDirectory| 默认不支持
需要使用前,指定具体的文件夹,此处相当于指定了当前dll
所在目录,即bin/Debug/net6.0
。参考
string dataSubDirectory = Path.Combine(AppContext.BaseDirectory);
if (!Directory.Exists(dataSubDirectory))
Directory.CreateDirectory(dataSubDirectory);
AppDomain.CurrentDomain.SetData("DataDirectory", dataSubDirectory);
即
public class g
{
static Lazy<IFreeSql> sqliteLazy = new Lazy<IFreeSql>(() =>
{
string dataSubDirectory = Path.Combine(AppContext.BaseDirectory);
if (!Directory.Exists(dataSubDirectory))
Directory.CreateDirectory(dataSubDirectory);
AppDomain.CurrentDomain.SetData("DataDirectory", dataSubDirectory);
var fsql = new FreeSql.FreeSqlBuilder()
.UseConnectionString(FreeSql.DataType.Sqlite, @"Data Source=|DataDirectory|local.db;Password=123qwe")
.UseAutoSyncStructure(true)
.UseLazyLoading(true)
.UseMonitorCommand(
cmd => Trace.WriteLine("\r\n线程" + Thread.CurrentThread.ManagedThreadId + ": " + cmd.CommandText)
)
.Build();
return fsql;
}
);
public static IFreeSql sqlite => sqliteLazy.Value;
}
具体的链接串,请参考 https://docs.microsoft.com/zh-cn/dotnet/standard/data/sqlite/connection-strings
如下数学函数不支持
- Floor
- Ceiling
- Log10
- Pow
- Sqrt
- Cos
TimeSpanTest 测试 类中 不通过、ulong最大值,最小值,超出范围。
- 不支持
public void Days()
{
var data = new List<object>();
data.Add(select.Where(a => a.CreateTime.TimeOfDay.Days == 0).ToList());
}
- 不支持
public void Minutes()
{
var data = new List<object>();
data.Add(select.Where(a => a.CreateTime.TimeOfDay.Minutes > 0).ToList());
}
FreeSql修改Sqlite密码
static int UpdatePassword(string newPassword)
{
var quotedNewPassword = g.sqlite.Ado.ExecuteScalar("SELECT quote(@newPassword)", new Dictionary<string, string> { { "newPassword", newPassword } }) as string;
int x = g.sqlite.Ado.ExecuteNonQuery("PRAGMA rekey = " + quotedNewPassword);
return x;
}
//新密码修改成其他数据后,将无法插入数据
string newPassword = "123qwe";
int x = UpdatePassword(newPassword);
Console.WriteLine("密码修改返回值:" + x);
//返回值 -1 正常
完整代码
作者: 、天上月OvO
出处:https://cnblogs.com/igeekfan
本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利。如有问题或建议,请多多赐教,非常感谢。