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