自言自语

I'm Wang Xianyuan, writing for myself, more studying, more experience…

Qt+SQLite数据加密的一种思路

By

了解Qt是比较早的,可是一直没有耐心去做一个练习。近期花了差不多两周时间做了次Qt开发练习,基本完成了Qt的入门,逃脱微软平台又迈出了几小步。Qt虽然是C++的,但开发应用是比较方便的,我觉得它在界面设计、消息传递方面超过了Delphi,甚至在一些方面更优于.net WinForm。给入门造成门槛的是关于Qt的中文资料相对较少,遇到问题寻找解决方法的成本较高,需要极大的耐心。

在学习Qt的时候在考虑一个问题——数据如何做到一定程度的保密而且能对数据进行方便的查询?首先想到是用数据库,而数据库需要有专门的数据库服务器支持,比如Oracle、MySQL、SQLServer,有没有一种不需要数据库服务器支持的数据库呢?自然又会想到Access、SQLite等。Access 的加密形同虚设,SQLite要支持加密需要修改并重新编译其源码或者购买高级的SQLite版本。

当我打开Qt自带的关于数据库操作的Demo时,无意看到两行代码:

[code:c#]

QSqlDatabase db = QSqlDatabase::addDatabase(“QSQLITE”);
db.setDatabaseName(“:memory:”);

[/code]

用的是上面提到的SQLite数据库,而这个数据库的路径并不像是在本地文件的路径。经查,这么设定可以直接在内存中创建一个SQLite数据库。这样,数据是可以实现不落地的。那么一个具有一定保密功能,同时又拥有数据库查询性能,而且无需数据库服务器支持的数据存储方案有了。大概思路是这样的:

1.在资源文件中附加文本格式的数据文件,如果对安全性还有担心,可以加密这个数据文件。
2.在程序第一次启动时在内存中创建SQLite数据库,将这些数据插入到库中。

这样之后,当需要对数据进行查询、排序操作时就可以方便地通过数据库功能来实现了,同时保证数据库不落地,数据是比较安全的。唯一要付出的成本是每次程序启动时都要去将数据插入到即时创建的数据库中,适用于数据条数和单笔数据都不大,而查询性能要求较高的情况。

6 Comments

  1. chenbl
    June 19, 2010 at 9:08 pm

    重出江湖!:D

  2. June 19, 2010 at 10:37 pm

    算不上重出,一直就爱好这玩意儿。:p

  3. June 21, 2010 at 12:53 pm

    关注, QT在linux应用广泛啊。

  4. August 8, 2010 at 6:18 pm

    只是了解了点GTK,QT不太会 呵呵!!

  5. 捷易通
    August 25, 2010 at 8:29 am

    对这一块不是很了解。

  6. January 19, 2011 at 1:34 pm

    为什么我的博客上没有回复评论的功能 ? 是我没有设置好 ?