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

简介:

先不用管上面的编译错误,创建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,如需转载请自行联系原作者
目录
相关文章
|
2天前
|
算法 数据库 数据安全/隐私保护
rsa加密解密,使用rsa对密码加密
rsa加密解密,使用rsa对密码加密
|
24天前
|
存储 算法 安全
加密解密(RSA)非对称加密算法
加密解密(RSA)非对称加密算法
|
2月前
|
数据库连接 API 数据库
SQLite3 数据库 C语言API 打开函数sqlite3_open 详解
SQLite3 数据库 C语言API 打开函数sqlite3_open 详解
66 0
|
4月前
|
PHP 数据安全/隐私保护
|
4月前
|
SQL 存储 关系型数据库
MySQL 时间日期函数,流程控制函数,加密解密函数以及聚合查询函数
MySQL 时间日期函数,流程控制函数,加密解密函数以及聚合查询函数
49 0
|
5月前
|
关系型数据库 MySQL 数据安全/隐私保护
零基础带你学习MySQL—加密函数和系统函数(十六)
零基础带你学习MySQL—加密函数和系统函数(十六)
|
9月前
|
SQL 运维 安全
[MySQL]流程控制函数&加密与解密函数&MySQL信息函数&其他函数
[MySQL]流程控制函数&加密与解密函数&MySQL信息函数&其他函数
|
10月前
|
JSON 前端开发 安全
ajax中实现访问url已阅即焚的解决方案(url动态参数、变量加密、常量不变、php加密解密、API访问验证方式)
ajax中实现访问url已阅即焚的解决方案(url动态参数、变量加密、常量不变、php加密解密、API访问验证方式)
186 0
|
10月前
|
JSON 安全 关系型数据库
php传递url参数加密验证的解决方案(加密解密、安全验证过滤)
php传递url参数加密验证的解决方案(加密解密、安全验证过滤)
257 0
|
10月前
|
存储 算法 前端开发
php动态密码和加密解密函数的使用(动态密码、Discuz核心函数AuthCode、任意输入密码验证)
php动态密码和加密解密函数的使用(动态密码、Discuz核心函数AuthCode、任意输入密码验证)
162 0
php动态密码和加密解密函数的使用(动态密码、Discuz核心函数AuthCode、任意输入密码验证)