SQLite Encryption(加密)新姿势

什么vb.net教程是SQLite?

SQLite是一个C语言实现c#教程的小型、快速、自包含、高可靠性、功能全面的SQL数据库引擎。

起因:
刚好项目上有个需求,需要python基础教程使用VS2019+.Net famework 4.6.1+sqlite完成数据层。

System.Data.SQLite库

先尝试了官方的System.Data.SQLite 包。

首先,使用VS2019创建.名字为 TestSqlite的.Net famework 4.6.1的控制台项目。

通过nuget安装
![(https://img-blog.csdnimg.cn/20210703172632243.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3E5MTM3NzcwMzE=,size_16,color_FFFFFF,t_70)

这个库依赖了很多如linq、EF6等其他java基础教程库.个人不是很喜欢···有需要的朋友直接安装是可以的。

Stub.System.Data.SQLite.Core.NetFramework

这个库没有依赖项···这里推荐···
在这里插入图片描述

通过nuget安装后使用如下代sql教程码成功运行。

using System;
using System.Data.SQLite;

namespace TestSqlite
{
    internal class Program
    {
        private static void Main(string[] args)
        {
            string cs = "Data Source=TestSqlite.sqlite";//数据库连接字符串
            string stm = "SELECT SQLITE_VERSION()";//查看版本
            var con = new SQLiteConnection(cs);//创建连接
            con.Open();
            var cmd = new SQLiteCommand(stm, con);
            string version = cmd.ExecuteScalar()
                .ToString();//查看版本
            Console.WriteLine($"SQLite version: {version}");
            Console.ReadKey();
        }
    }
}

运行后成功,可以看到版本是3.35.5
在这里插入图片描述
在bin文件夹下也生成了sqlite数据库
在这里插入图片描述

加密失败

作为一个数据库,没有密码是不行的。
于是我们在连接字符串加上password
在这里插入图片描述
运行,报错

System.IO.FileNotFoundException:“未能加载文件或程序集“System.Data.SQLite.SEE.License, Version=1.0.114.0, Culture=neutral, PublicKeyToken=433d9874d0bb98c5”或它的某一个依赖项。系统找不到指定的文件。”

在这里插入图片描述
这个System.Data.SQLite.SEE(SQLite Encryption Extension) 是System.Data.SQLite 的官方 SQLite 加密扩展包。

没错···SQlite开源版本是加密收费的···购买需要2000$·····
在这里插入图片描述

贫穷让我另谋出路

曲线救国 :Microsoft.Data.Sqlite

经过资料查询,发现微软的Microsoft.Data.Sqlite 库支持,所以再次进行尝试。

首先,使用VS2019创建.名字为 TestSqlite的.Net famework 4.6.1的控制台项目。

通过NuGet安装 Microsoft.Data.Sqlite.Core和 SQLitePCLRaw.bundle_e_sqlcipher
在这里插入图片描述
在这里插入图片描述

通过程序包管理器安装

Install-Package Microsoft.Data.Sqlite.Core
另外我们需要安装加密包
Install-Package SQLitePCLRaw.bundle_e_sqlcipher·

Dapper.Crud

个人比较喜欢Dapper,不喜欢的小伙伴可以使用自己的ORM,不用安装这个,使用自己喜欢的方式创建表即可。

Install-Package Dapper.Crud

安装完成后使用如下代码

using System;
using System.Data;
using Dapper;
using Microsoft.Data.Sqlite;
namespace TestSqlite
{
    internal class Program
    {
        
        private static void Main(string[] args)
        {

          var connStr = @"Data Source=TestSqlite.sqlite;";//连接字符串

          var conn = new SqliteConnectionStringBuilder(connStr)
            {
                Mode = SqliteOpenMode.ReadWriteCreate,
                Password = "password"
            }.ToString();//使用这个方式设置密码,避免sql注入

            var connection = new SqliteConnection(conn);//创建SQLite连接
            if (connection.State == ConnectionState.Closed)
            {
       
                connection.Open();
                var createTableSqlStr = @"CREATE TABLE  if not exists ""Alarm"" ( ""Id"" INTEGER NOT NULL, ""AlarmName"" TEXT, ""AlarmTypeId"" INTEGER, PRIMARY KEY ( ""Id"" ) );";
                var result = connection.Execute(createTableSqlStr);//使用Dapper执行sql语句创建表
                Console.ReadKey();
            }

         
        }

        
    }
}

运行后成功!
在这里插入图片描述
这里有个需要注意的点:

在设置密码创建数据库后,需要使用ORM执行sql创建表,如果是空数据库,是未加密的··可以直接打开。原因暂未可知。希望知道的大佬能告知

我们使用Navicat for SQLite 打开,如果出现以下弹窗,就说明加密成功了!
在这里插入图片描述

使用Navicat for SQLite 打开加密数据库

没有Navicat的童鞋点这里下载安装

替换sqlite3.dll

步骤如下:
打开Bin文件夹下的runtimes

在这里插入图片描述
根据自己系统选择文件夹x64还是x86
复制win-x64\native 下的e_sqlcipher.dll
在这里插入图片描述
打开Navicat 的安装目录,将刚刚复制的e_sqlcipher.dll复制到该目录下。
备份sqlite3.dll(将该dll复制到其他文件夹下),
然后将复制的e_sqlcipher.dll改名成 sqlite3.dll 替换掉原来的sqlite3.dll

设置密码

在数据库连接右键编辑连接-->高级-->设置数据库文件位置-->勾选已加密-->设置密码-->勾选保存密码
在这里插入图片描述
双击连接数据库,连接成功!!
在这里插入图片描述

__EOF__

作  者:OneByOneDotNet
出  处:https://www.cnblogs.com/ma-nong01/p/14988073.html

  • 0
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
智慧校园整体解决方案是响应国家教育信息化政策,结合教育改革和技术创的产物。该方案以物联网、大数据、人工智能和移动互联技术为基础,旨在打造一个安全、高效、互动且环保的教育环境。方案强调从数字化校园向智慧校园的转变,通过自动数据采集、智能分析和按需服务,实现校园业务的智能化管理。 方案的总体设计原则包括应用至上、分层设计和互联互通,确保系统能够满足不同用户角色的需求,并实现数据和资源的整合与共享。框架设计涵盖了校园安全、管理、教学、环境等多个方面,构建了一个全面的校园应用生态系统。这包括智慧安全系统、校园身份识别、智能排课及选课系统、智慧学习系统、精品录播教室方案等,以支持个性化学习和教学评估。 建设内容突出了智慧安全和智慧管理的重要性。智慧安全管理通过分布式录播系统和紧急预案一键启动功能,增强校园安全预警和事件响应能力。智慧管理系统则利用物联网技术,实现人员和设备的智能管理,提高校园运营效率。 智慧教学部分,方案提供了智慧学习系统和精品录播教室方案,支持专业级学习硬件和智能化网络管理,促进个性化学习和教学资源的高效利用。同时,教学质量评估中心和资源应用平台的建设,旨在提升教学评估的科学性和教育资源的共享性。 智慧环境建设则侧重于基于物联网的设备管理,通过智慧教室管理系统实现教室环境的智能控制和能效管理,打造绿色、节能的校园环境。电子班牌和校园信息发布系统的建设,将作为智慧校园的核心和入口,提供教务、一卡通、图书馆等系统的集成信息。 总体而言,智慧校园整体解决方案通过集成先进技术,不仅提升了校园的信息化水平,而且优化了教学和管理流程,为学生、教师和家长提供了更加便捷、个性化的教育体验。
Python的sqlite3模块是用于操作SQLite数据库的官方模块,它本身并不提供数据库加密的功能。但是,我们可以使用其他库或方法来实现对SQLite数据库加密保护。 一种常用的方法是使用pysqlcipher3库,它是一个SQLite数据库加密扩展。使用pysqlcipher3库,我们可以为SQLite数据库设置密码,以确保只有知晓密码的用户能够访问和操作数据库。 以下是一个简单的示例代码,展示如何使用pysqlcipher3库为SQLite数据库加密: ``` import pysqlcipher3 from sqlite3 import dbapi2 as sqlite # 设置数据库加密密码 password = "my_password" # 创建或打开一个已经加密数据库 conn = sqlite.connect('encrypted_db.db') conn.execute(f"ATTACH DATABASE 'encrypted_db.db' AS encrypted KEY '{password}'") conn.execute("SELECT sqlcipher_export('encrypted')") conn.execute("DETACH DATABASE encrypted") # 对数据库中的数据进行操作 cursor = conn.cursor() cursor.execute("CREATE TABLE IF NOT EXISTS users (id INTEGER PRIMARY KEY AUTOINCREMENT, name TEXT)") cursor.execute("INSERT INTO users (name) VALUES ('John')") cursor.execute("SELECT * FROM users") print(cursor.fetchall()) # 关闭数据库连接 conn.close() ``` 在上面的示例中,我们首先导入pysqlcipher3库。然后,我们设置了一个密码,用于加密数据库。接下来,我们使用`sqlite3.connect()`方法连接数据库,并执行一系列操作,包括创建表、插入数据和查询数据。最后,我们关闭数据库连接。 需要注意的是,使用pysqlcipher3库时,需要先安装相应的依赖库和工具,如OpenSSL、SQLCipher等。具体的安装步骤可以参考pysqlcipher3的官方文档。 除了使用pysqlcipher3库,我们还可以使用其他第三方库或工具实现SQLite数据库加密。例如,可以使用sqlcipher库、ApSW库以及其他第三方库。在选择使用哪个库时,需要考虑其兼容性、易用性以及所提供的功能和安全性。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值