DES加密算法代码

合集下载
相关主题
  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

#ifndef _DES_ENCRYPT_DECRYPT

#define _DES_ENCRYPT_DECRYPT

#define BYTE unsigned char

#define LPBYTE BYTE*

#define LPCBYTE const BYTE*

#define BOOL int

class DES

{

public:

BOOL CDesEnter(LPCBYTE in, LPBYTE out, int datalen, const BYTE key[8], BOOL type); BOOL CDesMac(LPCBYTE mac_data, LPBYTE mac_code, int datalen, const BYTE key[8]); private:

void XOR(const BYTE in1[8], const BYTE in2[8], BYTE out[8]);

LPBYTE Bin2ASCII(const BYTE byte[64], BYTE bit[8]);

LPBYTE ASCII2Bin(const BYTE bit[8], BYTE byte[64]);

void GenSubKey(const BYTE oldkey[8], BYTE newkey[16][8]);

void endes(const BYTE m_bit[8], const BYTE k_bit[8], BYTE e_bit[8]);

void undes(const BYTE m_bit[8], const BYTE k_bit[8], BYTE e_bit[8]);

void SReplace(BYTE s_bit[8]);

};

/*

* CDesEnter 函数说明:

* des加密/解密入口

* 返回:

* 1则成功,0失败

* 参数:

* in 需要加密或解密的数据

* 注意:in缓冲区的大小必须和datalen相同.

* out 加密后或解密后输出。

* 注意:out缓冲区大小必须是8的倍数而且比datalen大或者相等。

* 如datalen=7,out缓冲区的大小应该是8,datalen=8,out缓冲区的大小应该是8,

* datalen=9,out缓冲区的大小应该是16,依此类推。

* datalen 数据长度(字节)。

* 注意:datalen 必须是8的倍数。

* key 8个字节的加密或解密的密码。

* type 是对数据进行加密还是解密

* 0 表示加密 1 表示解密

*/

BOOL DES::CDesEnter(LPCBYTE in, LPBYTE out, int datalen, const BYTE key[8], BOOL type) {

//判断输入参数是否正确,失败的情况为:

//!in: in指针(输入缓冲)无效

//!out: out指针(输出缓冲)无效

//datalen<1:数据长度不正确

//!key:加/解密密码无效

//type && ((datalen % 8) !=0:选择解密方式但是输入密文不为8的倍数

if((!in) || (!out) || (datalen<1) || (!key) || (type && ((datalen % 8) !=0)))

return false;

if(type==0) //选择的模式是加密

{

// 用于存储待加密字串最后的若干字节

// DES算法是以8个字节为单位进行加密,如果待加密字串以8为单位分段加密时,最后一段不足

//8字节,则在后面补0,使其最后一段的长度为8字节

// te8bit是作为存储待加密字串最后一段(不足8字节)的变量

BYTE te8bit[8]={0,0,0,0,0,0,0,0};

// 这是待加密字串的调整长度

// 如果原始长度是8的整数倍,则调整长度的值和原来的长度一样

// 如果原始长度不是8的整数倍,则调整长度的值是能被8整除且不大于原来长度的最大整数。 //也就是不需要补齐的块的总长度。

int te_fixlen = datalen - (datalen % 8);

// 将待加密密文以8为单位分段,把最后长度不足8的一段存储到te8bit中。

for(int i = 0; i < (datalen % 8); i++)

te8bit[i] = in[te_fixlen + i];

// 将待加密字串分以8字节为单位分段加密

for(i = 0; i < te_fixlen; i += 8)

endes(in + i, key, out + i);

// 如果待加密字串不是8的整数倍,则将最后一段补齐(补0)后加密

if(datalen % 8 != 0)

endes(te8bit, key, out + datalen / 8 * 8);

}

else //选择的模式是解密

{

// 将密文以8字节为单位分段解密

for(int i = 0; i < datalen; i += 8)

undes(in + i, key, out + i);

}

return true;

}

/*

* CDesMAC 函数说明:

* DESMAC 数据验校

* 返回:

* 1则成功,0失败

* 参数:

* mac_data MAC验校数据

* 注意:Mac_data缓冲区的大小(16字节以上)必须和datalen相同,而且应是8的倍数。* out_mac MAC验校输出(8字节)

* dadalen 数据长度(字节)。

* 注意:datalen 必须是16以上而且是8的倍数。

* key 8个字节的验校密码。

*/

BOOL DES::CDesMac(LPCBYTE mac_data, LPBYTE mac_code, int datalen, const BYTE key[8]) {

//判断输入参数是否正确,失败的情况为:

//!mac_data: mac_data指针(输入缓冲)无效

//!mac_code: mac_code指针(输出缓冲)无效

//datalen<16:数据长度不正确

//datalen % 8 != 0:数据长度不为8的整数倍

相关文档
最新文档