Microsoft.Data.Sqlite + SQLitePCLRaw 实现 SQLite 加密的完整 WinForms 示例

Microsoft.Data.Sqlite + SQLitePCLRaw 实现 SQLite 加密的完整 WinForms 示例

在这里插入图片描述

一、安装 NuGet 包

通过“程序包管理器控制台”执行下面代码安装相关包

Install-Package Microsoft.Data.Sqlite
Install-Package SQLitePCLRaw.bundle_e_sqlcipher

二、添加窗口控件和添加代码

1. EncryptedDb.cs文件

/// <summary>
/// SQLite 加密数据库操作类
/// </summary>
public static class EncryptedDb
{
   
    // 数据库文件路径(自动创建在程序根目录)
    public static readonly string DbPath = Path.Combine(AppDomain.CurrentDomain.BaseDirectory, "encrypted.db");

    // 初始化 SQLitePCL 加密支持
    static EncryptedDb()
    {
   
        SQLitePCL.Batteries_V2.Init(); // 必须初始化加密组件
    }

    /// <summary>
    /// 创建加密数据库连接
    /// </summary>
    /// <param name="password">数据库密码</param>
    public static SqliteConnection CreateConnection(string password)
    {
   
        var connStr = new SqliteConnectionStringBuilder
        {
   
            DataSource = DbPath,
            Mode = SqliteOpenMode.ReadWriteCreate,
            Password = password // 设置密码
        }.ToString();

        Console.WriteLine($"数据库连接字符串:{
     connStr}");
        return new SqliteConnection(connStr);
        
    }

    /// <summary>
    /// 验证密码是否正确
    /// </summary>
    public static bool VerifyPassword(string password)
    {
   
        try
        {
   
            using (var conn = CreateConnection(password))
            {
   
                conn.Open(); // 密码错误会抛出异常
                return true;
            }
        }
        catch
        {
   
            return false;
        }
    }

    /// <summary>
    /// 修改数据库密码
    /// </summary>
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值