SQLite 数据库加密的一种解决方案

SQLite 数据库加密的一种解决方案

SQLite是一个非常小巧的跨平台嵌入式数据库,它的数据库以文件的形式存放在本地磁盘上,但是在其开源的免费版中它却缺少了一个数据库中几乎是 必备的功能,那就是对于数据库的加密。SQLite的数据库文件可以被任何的文本编辑工具打开,从而获取到其中的数据,这一点令很多开发者感到不安。 



但是其实SQLite是支持数据库加密的,前些天看到了网友arris的帖子,具体如下:

sqlite 的源代码中原本就考虑了加密的实现,并且保留了接口sqlite3_key和sqlite3_rekey,只是这两个函数在free版本中没有实现,但幸 运的是,sqlite的源代码的代码是开放并允许修改,我们可以很方便的增加加密的实现。在http://www.sqlite.com.cn /POParticle/3/216.Html链接的的代码包中就包含有可加密sqlite的源代码的实现,我根据这个包编译了一个可加密的 sqlite。这个包加密实现调用了windows API 的加密函数,所以只能在windows中使用。

这个可加密的版本是在一 个ADO.NET 2.0 SQLite Data Provider的基础上改过来的(http://www.sqlite.com.cn/POParticle/3/216.Html),据原作者声称效 率损失在千分之一以下。原始工程是基于VS2005的,但是考虑到其普及性还不是很广,所以重新建立了一个居于VC2003的工程。

其实SQLite的两个加密函数使用起来非常的简单,下面分情况说明:

① 给一个未加密的数据库添加密码:如果想要添加密码,则可以在打开数据库文件之后,关闭数据库文件之前的任何时刻调用sqlite3_key函数即可,该函 数有三个参数,其中第一个参数为数据库对象,第二个参数是要设定的密码,第三个是密码的长度。例 如:sqlite3_key(db,"1q2w3e4r",8); //给数据库设定密码1q2w3e4r
② 读取一个加密数据库中的数据:完成这个任务依然十分简单,你只需要在打开数据库之后,再次调用一下sqlite3_key函数即可,例如,但数据库密码是123456时,你只需要在代码中加入sqlite3_key(db,"123456",6);
① 更改数据库密码:首先你需要使用当前的密码正确的打开数据库,之后你可以调用sqlite3_rekey(db,"112233",6) 来更改数据库密码。
② 删除密码:也就是把数据库恢复到明文状态。这时你仍然只需要调用sqlite3_rekey函数,并且把该函数的第二个参数置为NULL或者"",或者把第三个参数设为0。

加密后数据库文件显示为乱码:

 

  为此我建立了一个简单的示例:

sqlite3 *db;
sqlite3_stmt *stat;
char *zErrMsg = 0;
char temp[256], FileRoot[256];
char buffer2[1024]="0";
sprintf(temp, _T("%s"), _T("utf.db"));
CCodingConv::GB2312_2_UTF8(FileRoot, 256, temp, 0);
sqlite3_open(FileRoot, &db);
if(db == NULL)
{
return -1;
}
sqlite3_key(db,"1q2w3e4r",8);
sqlite3_exec(db, "CREATE TABLE list (fliename varchar(128) UNIQUE, fzip text);", 0, 0, &zErrMsg);
sqlite3_prepare(db, "insert into list values ('中文GB2312编码',?);", -1, &stat, 0);
strcpy(temp, "测试数据UTF-8的支持情况");
int len = (int)strlen(temp);
sqlite3_bind_text(stat, 1, temp, len, NULL);
sqlite3_step(stat);
sqlite3_prepare(db, "select * from list;", -1, &stat, 0);
sqlite3_step(stat);
const unsigned char * test = sqlite3_column_text(stat, 1);
int size = sqlite3_column_bytes(stat, 1);
printf("%s", test);
sqlite3_finalize(stat);
//sqlite3_rekey(db,"",0);
sqlite3_close(db); 

 

具体的源代码如下:

SQLite3.3.7 加密版源代码(VC2003

SQLite3.3.7 加密版源代码(VC2005

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: Linux QtSqlite加密是指在Linux系统上使用QtSqlite库对数据库进行加密处理的过程。QtSqlite是基于SQLite的C++库,用于在Qt框架下操作数据库SQLite一种轻型、嵌入式数据库引擎,广泛用于各种应用程序的数据存储和管理。 要在Linux上使用QtSqlite加密功能,可以借助Qt提供的QtCipherSqlitePlugin插件。QtCipherSqlitePlugin是一个用于对SQLite数据库进行加密和解密的插件,它可以在数据库打开和关闭的过程中对数据进行加密和解密操作,保护数据库的机密性。 使用QtCipherSqlitePlugin进行加密时,先需要在Qt应用程序中加载该插件,并将其注册到数据库驱动中。然后,可以通过设置数据库加密密钥和算法类型来指定加密方式。常见的加密算法包括AES和DES等。 加密后的数据库文件在存储和传输过程中更加安全,无法直接被读取和修改。在使用数据库时,需要提供正确的密钥才能解密数据进行操作。而没有密钥的人则无法对数据库进行读写操作,保证了数据的机密性和安全性。 总而言之,Linux QtSqlite加密和QtCipherSqlitePlugin的使用可以有效保护数据库的安全。通过对数据库进行加密处理,可以防止敏感数据的泄漏和篡改,为应用程序和用户提供更高的数据安全保障。 ### 回答2: Linux QtSQLITE加密是指在Linux操作系统中使用QtSQLITE库进行数据库操作时,对数据库进行加密的过程。QtSQLITE是一个用于在Qt应用程序中访问和操作SQLite数据库的插件。 QtCipherSQLitePlugin是一个在Qt应用程序中使用的SQLite数据库加密插件。它提供了一种轻松而安全的方法来对SQLite数据库进行加密和解密操作。使用QtCipherSQLitePlugin,我们可以通过在连接到数据库之前设置加密密钥来保护数据库中的数据。这样,即使数据库文件被非法访问,也无法获取到其中的明文数据。 要使用QtCipherSQLitePlugin,首先需要在项目中添加相应的插件文件,并在代码中进行相关设置。然后,我们可以在代码中使用QtSQLITE库提供的API进行数据库操作,如创建表、插入数据、查询数据等。在连接到数据库之前,我们可以通过使用QtCipherSQLitePlugin提供的接口设置加密密钥,以保护数据库中的数据。 使用Linux QtSQLITE加密和QtCipherSQLitePlugin可以有效地保护数据库中的敏感数据。通过加密数据库,即使数据库文件被非法获取,也无法直接获取到其中的明文数据。这样可以提高数据的安全性,并保护用户的隐私。 总结来说,Linux QtSQLITE加密和QtCipherSQLitePlugin是一种用于在Linux操作系统中使用QtSQLITE库对SQLite数据库进行加密解决方案。它提供了一种简单而安全的方法来保护数据库的数据,加强数据的安全性。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值