VC2010中编译Sqlite3为静态库并带加密功能的方法。

lcy_888 2011-10-30 01:12:53
废话不多说,直接贴出方法,目的在于请路过老鸟帮助测试一下功能是否全面,是否真正实现了加密(反正我用记事本打开生成的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
/////////
...全文
2950 14 打赏 收藏 转发到动态 举报
写回复
用AI写文章
14 条回复
切换为时间正序
请发表友善的回复…
发表回复
hametan 2012-09-29
  • 打赏
  • 举报
回复
楼主

我出现
>sqlite3secure.obj : error LNK2005: _sqlite3_temp_directory 已经在 sqlite3.obj 中定义 N多个已经定义
1> 正在创建库 D:\web\work\项目\sqlite-3071400\Release\sqlite3.lib 和对象 D:\web\work\项目\sqlite-3071400\Release\sqlite3.exp
1>D:\web\work\项目\sqlite-3071400\Release\sqlite3.dll : fatal error LNK1169: 找到一个或多个多重定义的符号

另外就是SQLITE我用的sqlite-3071400 wxsqlite3-3.0.0.1 这两个版本,不知道怎么解决,望赐教。谢谢。
aslaka 2012-04-16
  • 打赏
  • 举报
回复
擦,老子搞了半天也没搞定,可不可以讲清楚一点,鄙人较水!
小米渣的逆袭 2011-12-30
  • 打赏
  • 举报
回复
我已经试验成功,不过mobile下有些头文件要修改下
小米渣的逆袭 2011-12-30
  • 打赏
  • 举报
回复
我已经试验成功,不过mobile下有些头文件要修改下
小米渣的逆袭 2011-12-30
  • 打赏
  • 举报
回复
太有用了 谢谢你哥
lcy_888 2011-10-30
  • 打赏
  • 举报
回复
我已经上传(免分下载),链接如下:
http://download.csdn.net/detail/lcy_888/3734987
lcy_888 2011-10-30
  • 打赏
  • 举报
回复
还有,请确保你们是下载的sqlite-amalgamation-XXXXXX.zip。
lcy_888 2011-10-30
  • 打赏
  • 举报
回复
请注意如下设置:
只把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
ggt87125 2011-10-30
  • 打赏
  • 举报
回复
codec.c;codec.h 编译出错,

错误 1 error C2061: 语法错误: 标识符“Btree” e:\sqlite3\vssqlite3\vssqlite3\vssqlite3\codec.h 65 1 vsSQLite3
错误 2 error C2065: “SQLITE_MAX_PAGE_SIZE”: 未声明的标识符 e:\sqlite3\vssqlite3\vssqlite3\vssqlite3\codec.h 66 1 vsSQLite3
错误 3 error C2057: 应输入常量表达式 e:\sqlite3\vssqlite3\vssqlite3\vssqlite3\codec.h 66 1 vsSQLite3
错误 4 error C2059: 语法错误:“}” e:\sqlite3\vssqlite3\vssqlite3\vssqlite3\codec.h 67 1 vsSQLite3
错误 5 error C2143: 语法错误 : 缺少“)”(在“*”的前面) e:\sqlite3\vssqlite3\vssqlite3\vssqlite3\codec.h 69 1 vsSQLite3
错误 6 error C2143: 语法错误 : 缺少“{”(在“*”的前面) e:\sqlite3\vssqlite3\vssqlite3\vssqlite3\codec.h 69 1 vsSQLite3
错误 7 error C2059: 语法错误:“)” e:\sqlite3\vssqlite3\vssqlite3\vssqlite3\codec.h 69 1 vsSQLite3
错误 8 error C2143: 语法错误 : 缺少“)”(在“*”的前面) e:\sqlite3\vssqlite3\vssqlite3\vssqlite3\codec.h 70 1 vsSQLite3
ggt87125 2011-10-30
  • 打赏
  • 举报
回复
[Quote=引用楼主 lcy_888 的回复:]
废话不多说,直接贴出方法,目的在于请路过老鸟帮助测试一下功能是否全面,是否真正实现了加密(反正我用记事本打开生成的DB文件看不到写入记录的明文了)。

一、用开源的wxsqlite3(我用的版本是3.2.1.3)
1、到SQLite官网http://www.sqlite.org/下载sqlite-amalgamation-XXXXXX.zip(我下的版本是3.78)

,它已经包含了所有……
[/Quote]

选择编译成dll时候 怎么报错呢 那里有设置不对吗?
ggt87125 2011-10-30
  • 打赏
  • 举报
回复
谢谢 学习了
havedown 2011-10-30
  • 打赏
  • 举报
回复
收藏备用,谢谢楼主分享。

16,472

社区成员

发帖
与我相关
我的任务
社区描述
VC/MFC相关问题讨论
社区管理员
  • 基础类社区
  • Web++
  • encoderlee
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

        VC/MFC社区版块或许是CSDN最“古老”的版块了,记忆之中,与CSDN的年龄几乎差不多。随着时间的推移,MFC技术渐渐的偏离了开发主流,若干年之后的今天,当我们面对着微软的这个经典之笔,内心充满着敬意,那些曾经的记忆,可以说代表着二十年前曾经的辉煌……
        向经典致敬,或许是老一代程序员内心里面难以释怀的感受。互联网大行其道的今天,我们期待着MFC技术能够恢复其曾经的辉煌,或许这个期待会永远成为一种“梦想”,或许一切皆有可能……
        我们希望这个版块可以很好的适配Web时代,期待更好的互联网技术能够使得MFC技术框架得以重现活力,……

试试用AI创作助手写篇文章吧