網站首頁 編程語言 正文
Sqlite
SQLite
來源于公共領域 SQLite Is Public Domain
、
確保代碼不會受到任何專有或許可內容的污染,沒有任何來自互聯網上的未知來源復制。即全是原創的。
雖然是免費的,無需許可證,可用于任何目的,但如果你的公司必須要一個許可證,你也能申請授權https://sqlite.org/purchase/license.
但不支持加密。如果想支持登錄加密,需要另外的擴展SQLite 加密擴展(SQLite Encryption Extension,),具有讀取/寫入 AES 加密數據庫的附加功能。具體授權可參考 https://www.sqlite.org/prosupport.html
Sqlite加密
一直以來,FreeSql
開發群中,總會有一些開發者來詢問Sqlite
加密的問題,事實上,官方提供的Sqlite加密功能是收費的。當連接串上使用Password
時,會提示授權問題。
如果底層依賴于System.Data.SQLite.Core
,
Could not load file or assembly 'System.Data.SQLite.SEE.License, Version=1.0.115.5, Culture=neutral, PublicKeyToken=433d9874d0bb98c5, processorArchitecture=MSIL
如果底層依賴于Microsoft.Data.Sqlite
也會提示
You specified a password in the connection string, but the native SQLite
library 'e_sqlite3' doesn't support encryption.
System.Data.SQLite.Core
創建一個控制臺項目,起名 OvOv.SqliteSystemCore
dotnet new console -n OvOv.SqliteSystemCore cd OvOv.SqliteSystemCore
安裝包
dotnet add package System.Data.SQLite.Core
使用SQLiteConnection
創建一個連接,使用Password指定密碼
using System.Data.SQLite; static void Open() { string baseConnectionString = "Data Source=local.db"; var connectionString = new SQLiteConnectionStringBuilder(baseConnectionString) { Password = "123qwe" }.ToString(); using SQLiteConnection? connection = new SQLiteConnection(connectionString); connection.Open(); } Open();
運行項目
dotnet run
就會出現如下錯誤。
System.IO.FileNotFoundException:“Could not load file or assembly
'System.Data.SQLite.SEE.License, Version=1.0.115.5, Culture=neutral, PublicKeyToken=433d9874d0bb98c5, processorArchitecture=MSIL'.
系統找不到指定的文件。”
Microsoft.Data.Sqlite
創建一個控制臺項目,起名 OvOv.SqliteMicrosoft
dotnet new console -n OvOv.SqliteMicrosoft cd OvOv.SqliteMicrosoft
安裝包
dotnet add package Microsoft.Data.Sqlite
使用SqliteConnection
創建一個連接,使用Password指定密碼
using Microsoft.Data.Sqlite; static void Open() { string baseConnectionString = "Data Source=local.db"; var connectionString = new SqliteConnectionStringBuilder(baseConnectionString) { Mode = SqliteOpenMode.ReadWriteCreate, Password = "123qwe" }.ToString(); using SqliteConnection? connection = new SqliteConnection(connectionString); connection.Open(); } Open();
運行項目
dotnet run
就會出現如下錯誤。
Unhandled exception. System.InvalidOperationException: You specified a password in the connection string,?
but the native SQLite library
'e_sqlite3' doesn't support encryption. at Microsoft.Data.Sqlite.SqliteConnection.Open()
其實微軟已經提供了加密的方案。
https://docs.microsoft.com/zh-cn/dotnet/standard/data/sqlite/encryption?tabs=netcore-cli
dotnet remove package Microsoft.Data.Sqlite dotnet add package Microsoft.Data.Sqlite.Core dotnet add package SQLitePCLRaw.bundle_e_sqlcipher
重新運行項目 ,就會發現,他正常執行。沒有任何報錯。
有關使用不同的本機庫進行加密的詳細信息,請參閱自定義 SQLite 版本。
我們從 自定義 SQLite 版本上可以看到。
默認情況下,主 Microsoft.Data.Sqlite
包引入 SQLitePCLRaw.bundle_e_sqlite3
。 若要使用不同的捆綁,請改為安裝 Microsoft.Data.Sqlite.Core
包以及要使用的捆綁包。
SQLitePCLRaw.bundle_e_sqlcipher
提供 SQLCipher 的非官方開放源代碼內部版本。此版本支持加密。
完整代碼
https://github.com/luoyunchong/dotnetcore-examples/blob/master/Database-Drivers/OvOv.SqliteMicrosoftCore/Program.cs
原文鏈接:https://www.cnblogs.com/igeekfan/p/net-sqlite-encryption.html
相關推薦
- 2022-09-23 基于React路由跳轉的幾種方式_React
- 2022-03-14 springboot下Static變量通過@Value和set方法注入失敗的問題和解決辦法
- 2022-04-10 Android中Protobuf的基本使用介紹_Android
- 2022-04-14 Python中創建表格詳細過程_python
- 2023-02-15 Python二進制轉化為十進制數學算法詳解_python
- 2022-09-01 ASP.NET?Core通用主機的系統配置_實用技巧
- 2022-08-06 WinForm項目中添加幫助文檔功能_C#教程
- 2022-07-21 Eslint代碼保存自動格式化
- 最近更新
-
- window11 系統安裝 yarn
- 超詳細win安裝深度學習環境2025年最新版(
- Linux 中運行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎操作-- 運算符,流程控制 Flo
- 1. Int 和Integer 的區別,Jav
- spring @retryable不生效的一種
- Spring Security之認證信息的處理
- Spring Security之認證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權
- redisson分布式鎖中waittime的設
- maven:解決release錯誤:Artif
- restTemplate使用總結
- Spring Security之安全異常處理
- MybatisPlus優雅實現加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務發現-Nac
- Spring Security之基于HttpR
- Redis 底層數據結構-簡單動態字符串(SD
- arthas操作spring被代理目標對象命令
- Spring中的單例模式應用詳解
- 聊聊消息隊列,發送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠程分支