欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

.NET+Sqlite支持加密的操作方法

 更新時(shí)間:2021年12月30日 10:28:15   作者:天上有木月OvO  
這篇文章主要介紹了.NET+Sqlite如何支持加密,如果想支持登錄加密,需要另外的擴(kuò)展SQLite?加密擴(kuò)展(SQLite?Encryption?Extension,),具有讀取/寫(xiě)入?AES?加密數(shù)據(jù)庫(kù)的附加功能,需要的朋友可以參考下

Sqlite

SQLite 來(lái)源于公共領(lǐng)域 SQLite Is Public Domain、
確保代碼不會(huì)受到任何專(zhuān)有或許可內(nèi)容的污染,沒(méi)有任何來(lái)自互聯(lián)網(wǎng)上的未知來(lái)源復(fù)制。即全是原創(chuàng)的。

雖然是免費(fèi)的,無(wú)需許可證,可用于任何目的,但如果你的公司必須要一個(gè)許可證,你也能申請(qǐng)授權(quán)https://sqlite.org/purchase/license.

但不支持加密。如果想支持登錄加密,需要另外的擴(kuò)展SQLite 加密擴(kuò)展(SQLite Encryption Extension,),具有讀取/寫(xiě)入 AES 加密數(shù)據(jù)庫(kù)的附加功能。具體授權(quán)可參考 https://www.sqlite.org/prosupport.html

Sqlite加密

一直以來(lái),FreeSql開(kāi)發(fā)群中,總會(huì)有一些開(kāi)發(fā)者來(lái)詢(xún)問(wèn)Sqlite加密的問(wèn)題,事實(shí)上,官方提供的Sqlite加密功能是收費(fèi)的。當(dāng)連接串上使用Password時(shí),會(huì)提示授權(quán)問(wèn)題。
如果底層依賴(lài)于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

如果底層依賴(lài)于Microsoft.Data.Sqlite 也會(huì)提示

You specified a password in the connection string, but the native SQLite

library 'e_sqlite3' doesn't support encryption.

System.Data.SQLite.Core

創(chuàng)建一個(gè)控制臺(tái)項(xiàng)目,起名 OvOv.SqliteSystemCore

dotnet new console -n OvOv.SqliteSystemCore
cd OvOv.SqliteSystemCore

安裝包

dotnet add package System.Data.SQLite.Core

使用SQLiteConnection創(chuàng)建一個(gè)連接,使用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();

運(yùn)行項(xiàng)目

dotnet run

就會(huì)出現(xiàn)如下錯(cuò)誤。

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'.

系統(tǒng)找不到指定的文件?!?/p>

Microsoft.Data.Sqlite

創(chuàng)建一個(gè)控制臺(tái)項(xiàng)目,起名 OvOv.SqliteMicrosoft

dotnet new console -n OvOv.SqliteMicrosoft
cd OvOv.SqliteMicrosoft

安裝包

dotnet add package Microsoft.Data.Sqlite

使用SqliteConnection創(chuàng)建一個(gè)連接,使用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();

運(yùn)行項(xiàng)目

dotnet run

就會(huì)出現(xiàn)如下錯(cuò)誤。

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()

其實(shí)微軟已經(jīng)提供了加密的方案。

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

重新運(yùn)行項(xiàng)目 ,就會(huì)發(fā)現(xiàn),他正常執(zhí)行。沒(méi)有任何報(bào)錯(cuò)。

有關(guān)使用不同的本機(jī)庫(kù)進(jìn)行加密的詳細(xì)信息,請(qǐng)參閱自定義 SQLite 版本。

我們從 自定義 SQLite 版本上可以看到。

默認(rèn)情況下,主 Microsoft.Data.Sqlite 包引入 SQLitePCLRaw.bundle_e_sqlite3。 若要使用不同的捆綁,請(qǐng)改為安裝 Microsoft.Data.Sqlite.Core 包以及要使用的捆綁包。

SQLitePCLRaw.bundle_e_sqlcipher

提供 SQLCipher 的非官方開(kāi)放源代碼內(nèi)部版本。此版本支持加密。

完整代碼

https://github.com/luoyunchong/dotnetcore-examples/blob/master/Database-Drivers/OvOv.SqliteMicrosoftCore/Program.cs

到此這篇關(guān)于.NET+Sqlite如何支持加密的文章就介紹到這了,更多相關(guān).NET?Sqlite加密內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • ASP.NET?Core使用EF創(chuàng)建關(guān)系模型

    ASP.NET?Core使用EF創(chuàng)建關(guān)系模型

    這篇文章介紹了ASP.NET?Core使用EF創(chuàng)建關(guān)系模型的方法,文中通過(guò)示例代碼介紹的非常詳細(xì)。對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2022-04-04
  • datalist,Repeater和Gridview的區(qū)別分析

    datalist,Repeater和Gridview的區(qū)別分析

    datalist,Repeater和Gridview的區(qū)別分析,需要的朋友可以參考一下
    2013-03-03
  • .net 應(yīng)對(duì)網(wǎng)站訪(fǎng)問(wèn)壓力的方案總結(jié)

    .net 應(yīng)對(duì)網(wǎng)站訪(fǎng)問(wèn)壓力的方案總結(jié)

    本文將總結(jié)下一些應(yīng)對(duì)網(wǎng)站訪(fǎng)問(wèn)壓力的技術(shù)方案。具有很好的參考價(jià)值,下面跟著小編一起來(lái)看下吧
    2017-02-02
  • the sourcesafe database has been locked by the administrator之解決方法

    the sourcesafe database has been locked by the administrator

    今天早上打開(kāi)soucesafe的時(shí)候出現(xiàn)提示:“the sourcesafe database has been locked by the administrator"。仔細(xì)想想, 可能是前天晚上用"f:\analyze.exe" -I- -DB -F -V3 -D "f:\vssData\data" 命今分析的時(shí)候鎖定了database
    2009-04-04
  • .Net之微信小程序獲取用戶(hù)UnionID的實(shí)現(xiàn)

    .Net之微信小程序獲取用戶(hù)UnionID的實(shí)現(xiàn)

    這篇文章主要介紹了.Net之微信小程序獲取用戶(hù)UnionID的實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2019-09-09
  • WPF常用控件用法及介紹

    WPF常用控件用法及介紹

    本文詳細(xì)講解了WPF常用控件用法及介紹,對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2022-01-01
  • asp.net URL編碼與解碼

    asp.net URL編碼與解碼

    通常如果一樣?xùn)|西需要編碼,說(shuō)明這樣?xùn)|西并不適合傳輸。原因多種多樣,如Size過(guò)大,包含隱私數(shù)據(jù),對(duì)于Url來(lái)說(shuō),之所以要進(jìn)行編碼,是因?yàn)閁rl中有些字符會(huì)引起歧義
    2011-12-12
  • asp.net gridview指定某一列滾動(dòng)

    asp.net gridview指定某一列滾動(dòng)

    gridview指定某一列滾動(dòng)的asp.net實(shí)現(xiàn)代碼。
    2009-11-11
  • System.Web中不存在類(lèi)型或命名空間名稱(chēng)script 找不到System.Web.Extensions.dll引用

    System.Web中不存在類(lèi)型或命名空間名稱(chēng)script 找不到System.Web.Extensions.dll引用

    這篇文章主要為大家詳細(xì)介紹了System.Web中不存在類(lèi)型或命名空間名稱(chēng)script,找不到System.Web.Extensions.dll引用的解決方法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-04-04
  • 詳解在Azure上部署Asp.NET Core Web App

    詳解在Azure上部署Asp.NET Core Web App

    這篇文章主要介紹了詳解在Azure上部署Asp.NET Core Web App,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2017-12-12

最新評(píng)論