关于sqlite和wxsqlite的数据库加密

OK,开始.
Sqlite这个东东,轻型开源数据库,firefox等的配置数据库用的就是它,由于开源版本不提供数据库内容加密功能,只提供了两个加密接口,所以,要使用数据库内容加密,还得自己动手(跟同事讨论,觉得可以自己实现个简单的,嘎嘎).我用的是wxWidgets,自带一个封装的Sqlite操作的API库-wxsqlite,wxsqlite又实现了sqlite的数据库加密的两个接口,现成的东东在,所以把它集成进去就好了.(厄,想起来了,最开始不是为了整加密功能,而是wxsqlite自带的编译好的sqlite.lib是伪静态的,编译完自带sample后每次运行程序都会弹个需要dll的框出来,所以需要自己生成静态的lib库,Orz,记性...)
现在言归正传,具体步骤,环境-VS2008 express:
1.下载wxsqlite(我的是wxsqlite3-1.9.6),sqlite的amalgamation和source包(我的是sqlite-amalgamation-3_6_19.zip和sqlite-source-3_6_19.zip),解压缩.
2.先编译生成sqlite库,解压缩sqlite-amalgamation-*.zip和sqlite-source-*.zip到一个目录,例如sqlite3,然后把wxsqlite自带的sqlite\secure\src\codec-c目录拷贝到sqlite3目录下,在sqlite3下建VC空白工程,添加文件codec-c里头的sqlite3secure.c,打开codec.h在#include "rijndael.h"下面添加#include "../sqliteInt.h",在sqlite3secure.c中把#include "sqlite3.c"改成#include "../sqlite3.c",改变工程编译选项,加入/D "THREADSAFE=1" /D "SQLITE_SOUNDEX" /D "SQLITE_ENABLE_COLUMN_METADATA" /D "SQLITE_HAS_CODEC" /D "SQLITE_SECURE_DELETE" /D "SQLITE_CORE",记得生成的是.lib文件.build,生成.lib文件...
3.拷贝生成的.lib文件到wxsqlite\sqlite\lib目录下,替换以前的sqlite3.lib
4.去wxsqlite\build目录,我的是打开wxsqlite3_vc9.sln,修改include目录,修改preprocessor:WXSQLITE3_HAVE_CODEC=1,编译生成.lib...
5.打开wxsqlite自带的sample,修改include目录和library目录,编译看看是否成功...
搞定...

下午补:
依同理搞定XP下用MinGW编译生成的.a文件,不同的是编译生成libsqlite3.a用的IDE是codeblock,测试wxsqlite自带sample通过,可以着手研究研究咋使用鸟...

 

》》》》》》》》》》》》》》》》》》》》》》》》》

 

wxSqlite3的GCC版本编译方法

应网友询问,摸索了一下wxsqlite3的GCC编译方法.
出处:http://www.cnblogs.com/fishseewater/archive/2010/12/29/1921056.html

准备工具:

1、CodeBlocks (老邓编译版:)(这个版本中包含了很多工具,就不需要再配置了,可以拿来就用:)
2、wxWidgets的GCC库。(老邓版中的包含了,如果你用的不是老邓版的,可以怎行下载编译。)
下载:http://code.google.com/p/portablecb/downloads/list?can=1&q=&colspec=Filename+Summary+Uploaded+ReleaseDate+Size+DownloadCount
3、wxSqlite3的源程序。


解压后,目录结构如下:


打开CodeBlocks后,我们需要配置一个全局变量

如下图:(老邓版的已经配置了)


然后导入wxSqlite3目录中的 Build\wxsqlite3_vc9.sln


导入后,会有两个工程,另一个是Demo程序,可能学习wxSqlite3的用法。
然后设置wxSqlite3的工程属性,主要是一些“头文件”与“库”的搜索路径设置。
wxSqliet3的工程中有非常多的编译配置,为说明问题,这里选择一个 Unicode版的Dll做示例,
其它的大同小异~


设置好搜索路径后,还需再设置一下导入库的文件名,因为VS生成的wxWidgets的库名与GCC生成的不同,
这里需要设置一下。下图:


至此:基本的设置都完成了,可以回到IDE开始编译了,
在Build targets选择刚才的配置好的编译配置。
然后在wxSqlite3工程上右键->Build。


如果不出意外,
在wxSqlite3的目录下应该有以下文件了:

 
那这个DLL就是我们需要的文件了,其它工程配置方法类似~。


后注: 

  自从用SQlite3数据库后,wrapper用过好几个,其中wxSqlite3用的时间是最长的,也是完成项目最多的。

不可否认,wxSqlite3 很优雅,使用也很方便,但最近了现了一个不是问题的问题。

要使用wxSqlite3类,就必须在项目中引用wxWidget库。我的wxWidgets库是自己编译的。本人为追求性能,

一般电脑都是裸奔,但一次系统在感染exe病毒后,全部重做了,这时再维护以前项目时,却来了大问题~

需要重新编译wxWidgets库,晕呀~。

  所以现在本人在VS工程中能不用第三方库尽量不用,如果必需要用,一定选开源,出了问题好排除,同时尽量很小巧的库。

太大的库负担重。

  曾想把wxqlite3类改造成STD版的,但发现其内部与wxWidgets依赖太紧密了,分离的劳动量太大,遂放弃~。

现在VS数据库开发搭配是 wxSqlite3中的加密Sqlite3库(只用其加密实现,不用其wrapper。)+自己修改过的KompexSQLiteWrapper。

  他日,如果选wxWidgets做UI库开发时,我会必选项 wxSqlite3.~~~

 

》》》》》》》》》》》》》》》》》》

 

如何对sqlite3数据库进行加密

一.请先按笔者的文章,先生成sqlite3的动态链接库

如何使用VC6编译sqlite3源码生成动态链接库(版本:sqlite-source-3_6_23_1)
二.解过互联网获取wxsqlite3-1.9.8.zip软件开发包

三.解压

解压展开wxsqlite3-1.9.8.zip软件开发包
四.拷贝

将目录wxsqlite3-1.9.8/sqlite3/secure/src/codec-c下的所有文件拷贝到sqlite3的工程目录下
五.添加头文件:

将codec.h、rijndael.h以及sha2.h该三个头文件添加进工程的Header File中
修改codec.h头文件

打开codec.h在#include "rijndael.h"下面添加#include "sqliteInt.h"
六.修改文件pager.c

打开sqlite3secure.c源文件,将整个文件进行复制;

然后粘贴到pager.c文件最后,语句“#endif ”语句之前,即可;

注意:也可将粘贴部分里面的多余的“#ifndef SQLITE_OMIT_DISKIO,以及#endif ”删除掉;

七.新增2个编译开关:

1.SQLITE_HAS_CODEC;

2.THREADSAFE;

八.在sqlite3.def文件最后新增2行:

sqlite3_key以及sqlite3_rekey

也就是多导出sqlite3_key和sqlite3_ rekey两个函数。


九.编译(End)。

 

》》》》》》》》》》》》》》

 

如何使用VC6编译sqlite3源码生成动态链接库(版本:sqlite-source-3_6_23_1)

一.版本:

2010-Mar-30  Version3.6.23.1
二.源代码获取:

在官网的http://www.sqlite.org/download.html的Download页面下载:

sqlite-source-3_6_23_1.zip
三.创建Win32动态链接库工程

1.打开VC新建一个“Win32 Dynamic-Link Library”工程,命名为:sqlite3;

2.在接下来的对话框中选择"An empty DLL project",点 FINISH->OK;
四.将文件添加进工程

将sqlite-source-3_6_22里的文件添加到sqlite3工程中:

1.将sqlite-source-3_6_22下的所有*.C文件添加在工程的Source File中

2.将sqlite-source-3_6_22下的所有*.h文件添加在工程的Header File中

注意:不要将tclsqlite.c源文件添加进工程中;
五.文件说明:

1. tclsqlite.c用于生成基于TCL的API,如果需要编译,则需要另外下载tcl.h头文件;

2. shell.c用于生成命令行模式的sqlite.exe;

3. fts3*.c是全文索引的模块;

4. rTree.c是建立数据库R树索引的模块;
六.编译参数:

点击VC6的菜单【Project】-【Settings…】-【C/C++】书签--【Preprocessor definitions:】

添加如下4个编译选项,每个编译选项之间用逗号分隔开来。

1. SQLITE_CORE

2. SQLITE_ENABLE_RTREE

3. SQLITE_ENABLE_COLUMN_METADATA

4. SQLITE_ENABLE_FTS3

七.下载sqlite-amalgamation-3_6_23_1.zip:

在官网的http://www.sqlite.org/download.html的Download页面下载

sqlite-amalgamation-3_6_23_1.zip
八.将sqlite3.def文件添加在工程的Header File目录中:

1.解压sqlite-amalgamation-3_6_23_1.zip;

2.将sqlite-amalgamation-3_6_23_1目录下的sqlite3.def文件拷贝至sqlite3工程中;

3.在工程的Header File目录添加sqlite3.def文件;
九.按F7进行编译:


 
附注:更多编译信息请参考如下:

官方的编译信息:

http://www.sqlite.org/compile.html

如何用Visual Studio.NET开发环境进行编译

http://www.sqlite.org/cvstrac/wiki?p=HowToCompileWithVsNet

更多参考:

小老虎多多的如何使用VC6编译sqlite3(版本:sqlite-source-3_6_22)

 

》》》》》》》》》》》》》》》》》》

 

如何使用VC6编译sqlite-source-3_6_22

引言:

小老虎多多使用VC6编译sqlite-source-3_6_22的编译方法。

一.创建Win32动态链接库工程
1.打开VC新建一个“Win32 Dynamic-Link Library”工程,命名为:sqlite3;
2.在接下来的对话框中选择"An empty DLL project",点 FINISH->OK;

二.将文件添加进工程
将sqlite-source-3_6_22里的文件添加到sqlite3工程中:
1.将sqlite-source-3_6_22下的所有*.C文件添加在工程的Source File中
2.将sqlite-source-3_6_22下的所有*.h文件添加在工程的Source File中

三.按F7进行编译

出现如下错误:

d:/learn/sqlite3/tclsqlite.c(28) : fatal error C1083: Cannot open include file: 'tcl.h': No such file or directory

说明:tclsqlite.c用于生成基于TCL的API,如果要编译,这需要另外下载tcl.h;shell.c用于生成命令行模式的sqlite.exe;

四.删除掉文件tclsqlite.c
再此处去掉文件tclsqlite.c,不让此文件参加编译,按F7重新编译
出现如下错误
fts3_tokenizer.obj : error LNK2005: _sqlite3_api already defined in fts3.obj
rtree.obj : error LNK2005: _sqlite3_extension_init already defined in fts3.obj
rtree.obj : error LNK2005: _sqlite3_api already defined in fts3.obj

五.编译通过方案
1.编译通过的方案一:
添加编译选项SQLITE_CORE 和SQLITE_ENABLE_FTS3
以及SQLITE_ENABLE_RTREE,再次按F7进行编译
 
2.编译通过的方法二:
2.1添加编译选项
如果仅仅添加SQLITE_ENABLE_FTS3和以及SQLITE_ENABLE_RTREE两个编译选项,不添加SQLITE_CORE编译选项;
2.2修改文件sqlite3ext.h
在文件sqlite3ext.h的
#define SQLITE_EXTENSION_INIT1     const sqlite3_api_routines *sqlite3_api = 0;
行下面添加,添加如下内容:
#define EXTERN_SQLITE_EXTENSION_INIT1     extern const sqlite3_api_routines *sqlite3_api = 0;

2.3修改fts3.c和fts3_tokenizer.c两个文件

在fts3.c和fts3_tokenizer.c此2个文件里,将SQLITE_EXTENSION_INIT1修改为EXTERN_SQLITE_EXTENSION_INIT1,具体如下:

#ifndef SQLITE_CORE
  #include "sqlite3ext.h" 
  EXTERN_SQLITE_EXTENSION_INIT1
#else
  #include "sqlite3.h"
#endif

2.4修改文件rtree.c
将rtee.c文件的里,将SQLITE_EXTENSION_INIT1修改为extern const sqlite3_api_routines *sqlite3_api即可,具体如下:
#ifndef SQLITE_CORE
  #include "sqlite3ext.h" 
  extern const sqlite3_api_routines *sqlite3_api; 
#else
  #include "sqlite3.h"
#endif
 
附注说明:
1. rTree.c是建立数据库R树索引的模块;
2. fts3*.c是全文索引模块

 

》》》》》》》》》》》》》》》》》》》》》》

  • 0
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
使用Python绘制混淆矩阵,可以使用sklearn.metrics包中的confusion_matrix函数。首先,需要将预测结果和真实标签以类似的格式赋值给y_pred和y_true变量。然后,可以使用confusion_matrix函数生成混淆矩阵C,可以通过labels参数指定类别的标签。接下来,可以使用matplotlib.pyplot中的函数绘制矩阵图,使用plt.matshow(C, cmap=plt.cm.Reds)来展示混淆矩阵的颜色。可以使用plt.annotate函数在矩阵图中显示每个元素的值。最后,可以使用plt.xlabel和plt.ylabel函数设置x轴和y轴的标签。最后,使用plt.show函数显示绘制好的混淆矩阵图。 [1 [2] 示例代码如下: ```python from sklearn.metrics import confusion_matrix import matplotlib.pyplot as plt y_pred = [] # 预测结果 y_true = [] # 真实标签 C = confusion_matrix(y_true, y_pred, labels=['0','1','2','3','4']) plt.matshow(C, cmap=plt.cm.Reds) for i in range(len(C)): for j in range(len(C)): plt.annotate(C[j, i], xy=(i, j), horizontalalignment='center', verticalalignment='center') plt.ylabel('True label') plt.xlabel('Predicted label') plt.show() ``` 这段代码会根据给定的预测结果和真实标签生成混淆矩阵,并使用矩阵图展示混淆矩阵的颜色。每个元素表示预测为某个类别的样本数量。通过调整代码中的参数和标签,可以根据不同的需求进行自定义。 [1 [2 [3<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [详解使用python绘制混淆矩阵confusion_matrix)](https://download.csdn.net/download/weixin_38580959/12861679)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT0_1"}}] [.reference_item style="max-width: 50%"] - *2* *3* [利用python绘制混淆矩阵](https://blog.csdn.net/weixin_43818631/article/details/121309660)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT0_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值