Qt 使用Sqlite3数据库加密

最近在做一个嵌入式设备,因为设计密码问题,所以需要对sqlite数据库进行加密,但是找了好多例子都不能达到要求,好在最后终于找到一可用资源,本人亲测可用。

源码:https://download.csdn.net/download/lsyrhz/10461435

 源码下下来包含了加密插件的源码还有一个测试的程序,首先需要编译sqlitecipher.pro项目了,编译debug和release后分别把生成的sqlitecipherd.dll 和sqlitecipher.dll 拷到对应的qt安装目录的sql驱动插件目录下plugins/sqldrivers下,就能在程序里进行使用了。
1.检查 QtCipherSqlitePlugin 是否成功加载
我们可以使用下面的代码检查 QtCipherSqlitePlugin 是否成功加载:
("QSQLITE", "QMYSQL", "QMYSQL3", "QODBC", "QODBC3", "QPSQL", "QPSQL7", "SQLITECIPHER")
DB File Path is: "C:/Users/Bozone/Documents/test_c.db"
1 : "AAA"
2 : "BBB"
3 : "CCC"
4 : "DDD"
5 : "EEE"
6 : "FFF"
7 : "GGG"
----------

1 : "ZZZ"
2 : "BBB"
3 : "CCC"
4 : "DDD"
5 : "EEE"
6 : "FFF"
7 : "GGG"
----------

1 : "ZZZ"
2 : "BBB"
3 : "CCC"
5 : "EEE"
6 : "FFF"
7 : "GGG"
Press <RETURN> to close this window...



1
qDebug() << QSqlDatabase::drivers();
如果输出中有 SQLITECIPHER 的名字,那么恭喜你,插件没有问题!
为没有加密的数据库增加密码
Qt 默认提供的 SQLite 插件是没有加密功能的。新版本的 QtCipherSqlitePlugin 支持为原本没有加密的数据库增加密码,使用方法如下:
C++
1
2
3
4
5
6
7
8
9
QSqlDatabase dbconn = QSqlDatabase::addDatabase("SQLITECIPHER");
dbconn.setDatabaseName("test.db");
dbconn.setPassword("test");
dbconn.setConnectOptions("QSQLITE_CREATE_KEY");
 
if (!dbconn.open()) {
    qDebug() << "Can not open connection: " << dbconn.lastError().driverText();
    exit(CONNECTION_FAILED);
}
上面的代码,我们使用 test.db 数据库,将密码设置为 test,同时指定连接选项为QSQLITE_CREATE_KEY。此时,调用open()函数之后,QtCipherSqlitePlugin 将使用改密码为这个数据库进行加密。
删除数据库密码
QtCipherSqlitePlugin 可以删除数据库密码,此时需要提供原密码,并使用连接选项QSQLITE_REMOVE_KEY,如下:
C++
1
2
3
4
5
6
7
8
9
QSqlDatabase dbconn = QSqlDatabase::addDatabase("SQLITECIPHER");
dbconn.setDatabaseName("test.db");
dbconn.setPassword("test");
dbconn.setConnectOptions("QSQLITE_REMOVE_KEY");
 
if (!dbconn.open()) {
    qDebug() << "Can not open connection: " << dbconn.lastError().driverText();
    exit(CONNECTION_FAILED);
}
更新数据库密码
QtCipherSqlitePlugin 可以更新数据库原有密码,需要设置原密码,并且使用连接选项QSQLITE_UPDATE_KEY设置新密码,具体代码如下:
C++
1
2
3
4
5
6
7
8
9
QSqlDatabase dbconn = QSqlDatabase::addDatabase("SQLITECIPHER");
dbconn.setDatabaseName("test.db");
dbconn.setPassword("test");
dbconn.setConnectOptions("QSQLITE_UPDATE_KEY=newtest");
 
if (!dbconn.open()) {
    qDebug() << "Can not open connection: " << dbconn.lastError().driverText();
    exit(CONNECTION_FAILED);
}
如果原密码不正确,QtCipherSqlitePlugin 会直接返回错误。
如果新密码设置为空,例如QSQLITE_UPDATE_KEY=,则作用等同于删除密码。


详细地址:https://www.devbean.net/2016/05/qt-sqlite-plugin-with-encryption-v05/

没有更多推荐了,返回首页

私密
私密原因:
请选择设置私密原因
  • 广告
  • 抄袭
  • 版权
  • 政治
  • 色情
  • 无意义
  • 其他
其他原因:
120
出错啦
系统繁忙,请稍后再试

关闭