VC2010中编译Sqlite3为静态库并带加密功能的方法
来源:互联网 发布:智能网络液晶电视 编辑:程序博客网 时间:2024/06/15 15:09
废话不多说,直接贴出方法,目的在于请路过老鸟帮助测试一下功能是否全面,是否真正实现了加密(反正我用记事本打开生成的DB文件看不到写入记录的明文了)。
一、用开源的wxsqlite3(我用的版本是3.2.1.3)
1、到SQLite官网http://www.sqlite.org/下载sqlite-amalgamation-XXXXXX.zip(我下的版本是3.78)
,它已经包含了所有的源文件,也不需要另外的辅助工具了,解压到某一目录,如Sqlite3。
2、在VS2010里新建一个空工程,把所有文件放入工程内;
3、到http://wxcode.sourceforge.net/components/wxsqlite3下载wxsqlite3,然后把sqlite3secure.c
请注意如下设置:
只把sqlite3secure.c文件加入到工程即可(其它文件是拷贝到工程目录下,但不用加入项目中),我的工程目录下的文件是这几个:
codec.c;codec.h;rijndael.c;rijndael.h;codecext.c;shell.c;sqlite3.c;sqlite3.h;sqlite3secure.c
4、在配置属性中设置配置类型为静态库(.Lib),添加预处理:
SQLITE_HAS_CODEC=1
CODEC_TYPE=CODEC_TYPE_AES128
SQLITE_CORE
THREADSAFE
SQLITE_SECURE_DELETE
SQLITE_SOUNDEX
SQLITE_ENABLE_COLUMN_METADATA
5、编译生成Lib文件。编译时如提示未找到某某文件,则从wxsqlite3的sqlite3\secure\src\codec-c目录内拷贝相关文件至你的工程目录下再编译即可,具体要拷贝的文件有:
codec.c;codec.h;rijndael.c;rijndael.h;codecext.c
sqlite3_key是输入密钥,如果数据库已加密必须先执行此函数并输入正确密钥才能进行操作,如果数据
库没有加密,执行此函数后进行数据库操作反而会出现“此数据库已加密或不是一个数据库文件”的错
误。
int sqlite3_key( sqlite3 *db, const void *pKey, int nKey),db 是指定数据库,pKey 是密钥,
nKey 是密钥长度。例:sqlite3_key( db, "abc", 3);
sqlite3_rekey是变更密钥或给没有加密的数据库添加密钥或清空密钥,变更密钥或清空密钥前必须先正
确执行 sqlite3_key。在正确执行 sqlite3_rekey 之后在 sqlite3_close 关闭数据库之前可以正常操
作数据库,不需要再执行 sqlite3_key。
int sqlite3_rekey( sqlite3 *db, const void *pKey, int nKey),参数同上。
清空密钥为 sqlite3_rekey( db, NULL, 0)。
其实SQLite的两个加密函数使用起来非常的简单,下面分情况说明:
1、 给一个未加密的数据库添加密码:如果想要添加密码,则可以在打开数据库文件之后,关闭数据库
文件之前的任何时刻调用sqlite3_key函数即可,该函数有三个参数,其中第一个参数为数据库对象,第
二个参数是要设定的密码,第三个是密码的长度。例如:sqlite3_key(db,"1q2w3e4r",8); //给
数据库设定密码1q2w3e4r
注:如果数据库没有加密,执行此函数后进行数据库操作反而会出现“此数据库已加密或不是一个数据
库文件”的错误?经测试,只能在新建数据库时设置密码!
2、 读取一个加密数据库中的数据:完成这个任务依然十分简单,你只需要在打开数据库之后,再次调
用一下sqlite3_key函数即可,例如,但数据库密码是123456时,你只需要在代码中加入sqlite3_key
(db,"123456",6);
3、 更改数据库密码:首先你需要使用当前的密码正确的打开数据库,之后你可以调用sqlite3_rekey
(db,"112233",6) 来更改数据库密码。
4、删除密码:也就是把数据库恢复到明文状态。这时你仍然只需要调用sqlite3_rekey函数,并且把该
函数的第二个参数置为NULL或者"",或者把第三个参数设为0。
三、使用SQLITE3数据库在stdafx.h文件中加入的代码
#define SQLITE_HAS_CODEC 1
extern "C"
{
#include "sqlite3/sqlite3.h"
};
#ifdef _DEBUG
#pragma comment(lib, "sqlite3/Sqlite3EncryptionD.lib")
#else
#pragma comment(lib, "sqlite3/Sqlite3Encryption.lib")
#endif
/////////
原帖出处http://bbs.csdn.net/topics/380018685
上传(免分下载),链接如下:
http://download.csdn.net/detail/lcy_888/3734987
- VC2010中编译Sqlite3为静态库并带加密功能的方法。
- VC2010中编译Sqlite3为静态库并带加密功能的方法
- C2010中编译Sqlite3为静态库并带加密功能的方法
- 使用VC6编译带加密功能的SQLITE3静态库
- vc2010设置为静态编译
- sqlite3 编译静态库
- sqlite3.7.9 VC2010编译说明
- sqlite3.7.9 VC2010编译说明
- VC2010动态库转换为静态库
- 使用VS2017静态编译sqlite3,生成静态的sqlite3.lib
- 编译iOS上可用的sqlite3静态库
- sqlite3加密功能--sqlcipher
- VC2010中 调用DLL的方法
- 使用VS2010编译sqlite3,生成静态的sqlite3.lib
- 静态编译sqlite3
- vc++6源码在VC2010中编译提示iostream.h库找不到问题的解决办法
- sqlite3 中执行带变量的命令
- sqlite3开启数据库加密功能
- windows文件比较命令
- ubuntu下安装配置SSH
- 章小结
- 打印100以内的素数
- Window.open() 全攻略
- VC2010中编译Sqlite3为静态库并带加密功能的方法
- 2013 多校第九场 hdu 4699 Editor(vector OR splay tree)
- 多态的优势与特点,为什么用多态
- Delegate如何进行类型转换?
- 【讲解各种手机所有内存卡知识】
- Unix 环境高级编程学习笔记(一)
- 【原创分享】嵌入式linux应用之内核移植定制篇-后篇(修复部分问题)(linux-3.8.12 mini2440)
- 备份所有短信
- 输入一个整数n,求从1 到n 这n 个整数的十进制表示中1 出现的次数)