C2010中编译Sqlite3为静态库并带加密功能的方法
来源:互联网 发布:幼儿算术手指算法视频 编辑:程序博客网 时间:2024/05/22 08:11
http://bbs.csdn.net/topics/380018685
废话不多说,直接贴出方法,目的在于请路过老鸟帮助测试一下功能是否全面,是否真正实现了加密(反正我用记事本打开生成的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
文件加入到工程即可;
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的加密函数说明
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
/////////
- C2010中编译Sqlite3为静态库并带加密功能的方法
- VC2010中编译Sqlite3为静态库并带加密功能的方法。
- VC2010中编译Sqlite3为静态库并带加密功能的方法
- 使用VC6编译带加密功能的SQLITE3静态库
- sqlite3 编译静态库
- 使用VS2017静态编译sqlite3,生成静态的sqlite3.lib
- 编译iOS上可用的sqlite3静态库
- sqlite3加密功能--sqlcipher
- 使用VS2010编译sqlite3,生成静态的sqlite3.lib
- 静态编译sqlite3
- sqlite3 中执行带变量的命令
- sqlite3开启数据库加密功能
- VS2012中创建Web服务并编译为dll的方法
- OpenCV编译为静态库的补充
- OpenCV编译为静态库的补充
- c调用sqlite3的编译方法
- SQLite3的加密
- OpenCV 1.0 在VS2005中编译为静态库所需的设置
- arp(地址解析协议)
- SQL Server 函数
- oracle 的一些学习语句
- !NAT and Traversal NAT(TURN/STUN/ICE)
- Office情趣:足球液晶:这个季节属于运动!
- C2010中编译Sqlite3为静态库并带加密功能的方法
- SQL Server索引进阶第十一篇:索引碎片分析与解决(上)
- Linux学习笔记3--linux下库文件的创建和使用及其他
- mdev的使用方法和原理
- 绑定回车事件
- mysql中int、bigint、smallint 和 tinyint的区别与长度 Posted on February 25, 2012
- 666
- Android 签名
- poj 2965 The Pilots Brothers' refrigerator(技巧枚举)