QT使用SQLCipher加密SQLite

1. SQLCipher下载

方式1:

通过网盘分享的文件:QtCipherSqlitePlugin-master.zip

链接: https://pan.baidu.com/s/1ueZMUUUj6T5er7b3fUSmNg 提取码: ic5b

方式2:

SQLCipher: SQLCipher 提供了对 SQLite 数据库的传输层进行全面加密的工具。通过使用 SQLCipher ,整个加密过程对客户端是透明的,无需改动应用程序。

2. 使用QT编译

(1) 打开sqlitecipher.pro项目,直接配置编译器编译

(2) 打开得到的编译产物目录,复制文件:

(a)把该目录下的lib\cmake\Qt5Sql路径下的文件复制到你QT安装路径的\5.12.0\mingw73_64\lib\cmake\Qt5Sql下.其中5.12.0和mingw73_64更改为你自己的QT版本和需要使用数据库加密的编译器.

(b)把该目录下的\plugins\sqldrivers路径下的.a后缀文件复制到你QT安装路径的5.12.0\mingw73_64\lib下.其中5.12.0和mingw73_64更改为你自己的QT版本和需要使用数据库加密的编译器.

(c)把该目录下的\plugins\sqldrivers路径下的.dll后缀文件复制到你QT安装路径的5.12.0\mingw73_64\plugins\sqldrivers下.其中5.12.0和mingw73_64更改为你自己的QT版本和需要使用数据库加密的编译器.

3. 验证

复制代码
#include "Widget.h"
#include <QApplication>
#include <QSqlDatabase>
#include <QDebug>
#include <QtSql>
#include <QCoreApplication>
#include <QStandardPaths>
#include <QDir>
#include <QFile>
#include <QDebug>

//db.setConnectOptions("QSQLITE_USE_CIPHER=aes256cbc;");

int main(int argc, char *argv[])
{
    QApplication a(argc, argv);
    
    Widget w;
    w.show();

    qDebug() << QSqlDatabase::drivers();

    return a.exec();
}

输出信息中有SQLITECIPHER即为成功.

4. 使用

和普通使用一样,只不过打开之前使用

复制代码
db.setConnectOptions("QSQLITE_USE_CIPHER=aes256cbc;");
QSQLITE_USE_CIPHER参数根据需求自己选择

5. 参考

QSqlite数据库加密方法_qt cipher setconnectoption-CSDN博客

相关推荐
可涵不会debug31 分钟前
金仓数据库:破解电子证照国产化难题,开启政务效能新篇
数据库·政务
元闰子1 小时前
对 Agent-First 数据库的畅想
数据库·后端·aigc
java水泥工1 小时前
学科竞赛管理系统|基于SpringBoot和Vue的学科竞赛管理系统(源码+数据库+文档)
数据库·vue.js·spring boot
kobe_OKOK_1 小时前
django 数据库迁移
数据库·oracle·django
寻星探路2 小时前
数据库造神计划第二十一天---JDBC编程
数据库·oracle
A-刘晨阳3 小时前
从MongoDB到金仓:一次电子证照系统的平滑国产化升级实践
数据库·mongodb
瓜瓜怪兽亚3 小时前
前端基础知识---10 Node.js(三)
数据结构·数据库·node.js
掘根5 小时前
【Qt】常用控件3——显示类控件
开发语言·数据库·qt
码码哈哈爱分享5 小时前
MariaDB 与 MySQL 区别
数据库·mysql·mariadb
爱敲代码的TOM5 小时前
深入MySQL底层1-存储引擎与索引
数据库·mysql