最近在做一个嵌入式设备,因为设计密码问题,所以需要对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/