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

相关推荐
是店小二呀8 分钟前
【金仓数据库征文】金仓数据库(KingbaseES)迁移与集群部署实战:从MySQL到KES的全流程解析
数据库·mysql·金仓数据库 2025 征文·数据库平替用金仓
一只专注api接口开发的技术猿17 分钟前
1688 API 自动化采集实践:商品详情实时数据接口开发与优化
大数据·运维·数据库·自动化
昔我往昔42 分钟前
MySQL中为什么使用B+树结构、B+树和普通的平衡树的区别
数据库·b树·mysql
翁正存1 小时前
MySQL为什么选择B+树
数据库·b树·mysql
码农黛兮_461 小时前
MySQL 数据库集群部署、性能优化及高可用架构设计
数据库·mysql·性能优化
AllenO.o2 小时前
Redis五种数据结构详解
java·数据结构·数据库·redis·缓存
消失在人海中2 小时前
数据分析基础:需要掌握的入门知识
数据库·人工智能·数据分析
闪电麦坤952 小时前
SQL:SELF JOIN(自连接)与CROSS JOIN(交叉连接)
数据库·sql·mysql
码农飞哥2 小时前
互联网大厂Java面试实战:从Spring Boot到微服务的技术问答与解析
java·数据库·spring boot·安全·微服务·面试·电商
周盛欢3 小时前
数据库故障排查指南
数据库·mysql