wxsqlit3 虽然实现了sqlite3的加密接口,但默认下载的二进制文件中确没有实现加密,如果需要加密的sqlite3,需要我们自己动手编译.
在这里我将wxsqlite3编译成Static lib来使用.注意:wxsqlite3的代码依赖于 sqlite3. 这里为了方便,我将sqlite3也编译成Static Lib.
编译步骤如下:
分为两大步:
一. 编译加密的sqlite3
二. 编译wxsqlite3
最新的 wxsqlite3-1.9.9 相对于以前的版本在加密实现源码部分调整为纯C代码了,这对于编译的步骤来说相当简单了.
一. 编译加密的sqlite3
1. 下载wxsqlite3-1.9.9.zip后,解压到wxsqlite3-1.9.9
(http://sourceforge.net/projects/wxcode/files/Components/)
2. 下载www.sqlite.org的sqlite-amalgamation-3_XXXX.zip,将压缩包中的文件全部提取到 wxsqlite3-1.9.9\sqlite3\secure\src\codec-c 下(写这篇文章时用的版本是3.6.23.1).
sqlite3_rekey
sqlite3_key
3. 打开VS,新建一个"static lib",工程名为"sqlite3Encrypt",保存到"wxsqlite3-1.9.9\sqlite3"下.
4. 导入文件:只要单纯的导入 sqlite3secure.c 这个文件就好了.
5. 设置工程属性: (为方便使用 将sqlite3的输出调整到wxsqlite3工程的输出目录中).在这一步中,分为Debug与Release版.(可以通过新建工程时建一个DLL工程,这样就内置了两个版本的配置,然后再将"常规->配置类型"设置为"静态库(lib)"就可以了.)
常规->输出目录:
"..\..\lib\vc_lib"
C/C++->预处理->预处理器定义:
sqlITE3ENCRYPT_EXPORTS
sqlITE_ENABLE_FTS3
sqlITE_ENABLE_FTS3_PARENTHESIS
sqlITE_ENABLE_RTREE
sqlITE_SECURE_DELETE
sqlITE_SOUNDEX
sqlITE_HAS_CODEC
CODEC_TYPE=CODEC_TYPE_AES128
"..\..\lib\vc_lib\sqlite3EncryptD.pdb" //Debug版
"..\..\lib\vc_lib\sqlite3Encrypt.pdb" //Release版
$(OutDir)\$(ProjectName)D.lib //Debug版
$(OutDir)\$(ProjectName).lib //Release版
6. 编译生成 sqlite3EncryptD.lib,sqlite3Encrypt.lib
二. 编译wxsqlite3.
wxsqlite3的编译需要wxWidgets库.去http://www.wxwidgets.org/下载安装包默认安装后,进入"wxWidgets-2.9.0\build\msw"下找到VS的工程文件打开后,编译debug与Release版(这两个版本默认是Static lib).
1. 到"wxsqlite3-1.9.9\build"下找到VS的工程文件打开.这里我只编译 "Static Unicode Debug Monolithic Static"与 "Static Unicode Release Monolithic Static" 版.
2. 设置工程属性:
C/C++->常规->附加包含目录:
"C:\wxWidgets-2.9.0\lib\vc_lib\mswud";"C:\wxWidgets-2.9.0\include";..\include;..\sqlite3\include //Debug版
"C:\wxWidgets-2.9.0\lib\vc_lib\mswu";"C:\wxWidgets-2.9.0\lib\include";..\include;..\sqlite3\include //Release版
C/C++->预处理->预处理器定义:
WXsqlITE3_HAVE_MetaDATA=1 //修改0为1
3. 编译生成. wxcode_msw28ud_wxsqlite3.lib,wxcode_msw28u_wxsqlite3.lib
使用:
要使用 wxsqlite3,也是需要 wxWidgets库的.
例:
1. 新建一个控制台项目
2. 设置工程属性:
C/C++->常规->附加包含目录:
"C:\wxWidgets-2.9.0\include" \
"C:\wxWidgets-2.9.0\lib\vc_lib\mswud" // Debug版 --- wxWidgets 库
"C:\wxWidgets-2.9.0\lib\vc_lib\mswu" // Release版 /
"??\wxsqlite3-1.9.9\include" // wxsqlite3 include 目录。
链接器->常规->附加库目录:
"C:\wxWidgets-2.9.0\lib\vc_lib";"??\wxsqlite3-1.9.9\lib\vc_lib"; // Debug版
"C:\wxWidgets-2.9.0\lib\vc_lib";"??\wxsqlite3-1.9.9\lib\vc_lib" // Release版
链接器->输入->附加依赖项:
wxcode_msw28ud_wxsqlite3.lib wxbase29ud.lib sqlite3EncryptD.lib // Debug版
sqlite3Encrypt.lib wxcode_msw28u_wxsqlite3.lib wxbase29u.lib // Release版
3. 在代码中引用 #include "wx/wxsqlite3.h"
完成~!
作者mail:fishseewater@gmail.com
原文链接:https://www.f2er.com/sqlite/202462.html