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博客

相关推荐
NocoBase41 分钟前
8 人团队如何效率拉满?——创联云的开发方法论
数据库·低代码·开源
kgduu1 小时前
go-ethereum core之交易索引txIndexer
服务器·数据库·golang
摇滚侠1 小时前
全面掌握 PostgreSQL 关系型数据库,PostgreSQL 介绍,笔记02
数据库·笔记·postgresql
百锦再1 小时前
国产数据库替代MongoDB的技术实践:金仓数据库赋能浙江省人民医院信息化建设新展望
java·开发语言·数据库·mongodb·架构·eclipse·maven
程序边界1 小时前
MongoDB迁移到KES实战全纪录(下):性能优化与实践总结
数据库·mongodb·性能优化
武子康1 小时前
Java-160 MongoDB副本集部署实战 单机三实例/多机同法 10 分钟起集群 + 选举/读写/回滚全流程
java·数据库·sql·mongodb·性能优化·系统架构·nosql
这儿有一堆花1 小时前
使用 Actix-web 开发高性能 Web 服务
前端·数据库
与衫2 小时前
SQL 调试不再靠猜:Gudu SQL Omni 让血缘分析一键可视化
数据库·sql
ZZZKKKRTSAE2 小时前
MySQL一篇速通
数据库·mysql·1024程序员节
阿祥~2 小时前
windows 安装 Redis
数据库·redis·缓存