SQLite 3.7.13的加密解密(三)—— 创建加密解密函数

本文涉及的产品
密钥管理服务KMS,1000个密钥,100个凭据,1个月
简介:

先不用管上面的编译错误,创建crypt.ccrypt.h,用来实现加密解密函数和相应接口的定义。

crypt.c里实现了加密解密函数,代码如下:

#include "crypt.h"

#include "memory.h"

 

/***********

 关键加密函数

 ***********/

int My_Encrypt_Func(unsigned char * pData, unsigned int data_len,

              unsigned char * key, unsigned int len_of_key)

 

{

       unsigned int i;

       unsigned char bit, val;

 

       for (i = 0; i < data_len; i++)

       {

              val = ~(*pData);

              *pData = val;

              pData++;

       }

       return 0;

}

 

/***********

 关键解密函数

 ***********/

int My_DeEncrypt_Func(unsigned char * pData, unsigned int data_len,

              unsigned char * key, unsigned int len_of_key)

 

{

       unsigned int i;

       unsigned char bit, val;

 

       for (i = 0; i < data_len; i++)

       {

              val = ~(*pData);

              *pData = val;

              pData++;

       }

       return 0;

}

这里加密解密函数就是简单的采用了求反的操作,目的是用来演示加密和解密。以后实际运用中把这两个函数内的算法修改为自己的加密解密算法即可。

注意:这里的加密解密函数实际上没有用到Key值,因此加密后使用任意Key值均可以解开数据库,但是加密后,用第三方工具是不能直接打开的。

 

crypt.h用来声明加密解密函数的定义,以便sqlite3.c包含加密解密接口,代码如下:

/**

 加密函数

 */

int My_Encrypt_Func(unsigned char * pData, unsigned int data_len,

              unsigned char * key, unsigned int len_of_key);

 

/**

 解密函数

 */

int My_DeEncrypt_Func(unsigned char * pData, unsigned int data_len,

              unsigned char * key, unsigned int len_of_key);

注意:网上的代码中,参数key定义为“const char *”类型,与sqlite3.c代码一起编译时会有错误,这里按照sqlite3.c中的类型修改为“unsigned char *”类型。






本文转自 tywali 51CTO博客,原文链接:http://blog.51cto.com/lancelot/940812,如需转载请自行联系原作者
目录
相关文章
|
7月前
|
算法 数据库 数据安全/隐私保护
rsa加密解密,使用rsa对密码加密
rsa加密解密,使用rsa对密码加密
|
6月前
|
存储 安全 数据库
对称加密的日常实践应用:以AES为例的加密解密指南
**摘要:** 本文介绍了对称加密算法AES在数据安全中的应用,强调了其在文件、通信和数据库加密中的重要性。通过Python示例展示了如何使用`cryptography`库实现AES-256的加密和解密,涉及密钥生成、CBC模式及PKCS7填充。同时,提醒注意密钥管理、模式选择和填充方式的选择对加密安全性的影响。
610 1
|
6月前
|
数据库 数据安全/隐私保护 数据库管理
QT中sqlite数据库数据加密/混淆---MD5/SHA1/SHA2/SHA3
QT中sqlite数据库数据加密/混淆---MD5/SHA1/SHA2/SHA3
|
5月前
|
算法 安全 数据安全/隐私保护
支付系统---微信支付09------数字签名,现在Bob想要给Pink写一封信,信件的内容不需要加密,怎样能够保证信息的完整性,使用信息完整性的主要手段是摘要算法,散列函数,哈希函数,H称为数据指纹
支付系统---微信支付09------数字签名,现在Bob想要给Pink写一封信,信件的内容不需要加密,怎样能够保证信息的完整性,使用信息完整性的主要手段是摘要算法,散列函数,哈希函数,H称为数据指纹
|
6月前
|
Java BI C#
技术笔记:SM4加密算法实现Java和C#相互加密解密
技术笔记:SM4加密算法实现Java和C#相互加密解密
106 0
|
7月前
|
Java 关系型数据库 MySQL
MySql数据库级别MD5加密java MD5加密解密工具包
MySql数据库级别MD5加密java MD5加密解密工具包
|
7月前
|
存储 算法 安全
加密解密(RSA)非对称加密算法
加密解密(RSA)非对称加密算法
|
7月前
|
数据库连接 API 数据库
SQLite3 数据库 C语言API 打开函数sqlite3_open 详解
SQLite3 数据库 C语言API 打开函数sqlite3_open 详解
319 0
|
7月前
|
PHP 数据安全/隐私保护
|
7月前
|
SQL 存储 关系型数据库
MySQL 时间日期函数,流程控制函数,加密解密函数以及聚合查询函数
MySQL 时间日期函数,流程控制函数,加密解密函数以及聚合查询函数
70 0