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 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/

你可能感兴趣的:(qt,sql)