3DES标准算法库方便实现加解密

时间:2014-06-22 08:19:19
【文件属性】:

文件名称:3DES标准算法库方便实现加解密

文件大小:5KB

文件格式:RAR

更新时间:2014-06-22 08:19:19

DES

#ifdef __cplusplus extern "C" { #endif /** * \brief DES context structure */ typedef struct { unsigned long esk[32]; /*!< DES encryption subkeys */ unsigned long dsk[32]; /*!< DES decryption subkeys */ } des_context; /** * \brief Triple-DES context structure */ typedef struct { unsigned long esk[96]; /*!< Triple-DES encryption subkeys */ unsigned long dsk[96]; /*!< Triple-DES decryption subkeys */ } des3_context; /** * \brief DES key schedule (56-bit) * * \param ctx DES context to be initialized * \param key 8-byte secret key */ void my_des_set_key( des_context *ctx, unsigned char key[8] ); /** * \brief DES block encryption (ECB mode) * * \param ctx DES context * \param input plaintext block * \param output ciphertext block */ void des_encrypt( des_context *ctx, unsigned char input[8], unsigned char output[8] ); /** * \brief DES block decryption (ECB mode) * * \param ctx DES context * \param input ciphertext block * \param output plaintext block */ void des_decrypt( des_context *ctx, unsigned char input[8], unsigned char output[8] ); /** * \brief DES-CBC buffer encryption * * \param ctx DES context * \param iv initialization vector (modified after use) * \param input buffer holding the plaintext * \param output buffer holding the ciphertext * \param len length of the data to be encrypted */ void my_des_cbc_encrypt( des_context *ctx, unsigned char iv[8], unsigned char *input, unsigned char *output, int len ); /** * \brief DES-CBC buffer decryption * * \param ctx DES context * \param iv initialization vector (modified after use) * \param input buffer holding the ciphertext * \param output buffer holding the plaintext * \param len length of the data to be decrypted */ void my_des_cbc_decrypt( des_context *ctx, unsigned char iv[8], unsigned char *input, unsigned char *output, int len ); /** * \brief Triple-DES key schedule (112-bit) * * \param ctx 3DES context to be initialized * \param key 16-byte secret key */ void des3_set_2keys( des3_context *ctx, unsigned char key[16] ); /** * \brief Triple-DES key schedule (168-bit) * * \param ctx 3DES context to be initialized * \param key 24-byte secret key */ void des3_set_3keys( des3_context *ctx, unsigned char key[24] ); /** * \brief Triple-DES block encryption (ECB mode) * * \param ctx 3DES context * \param input plaintext block * \param output ciphertext block */ void des3_encrypt( des3_context *ctx, unsigned char input[8], unsigned char output[8] ); /** * \brief Triple-DES block decryption (ECB mode) * * \param ctx 3DES context * \param input ciphertext block * \param output plaintext block */ void des3_decrypt( des3_context *ctx, unsigned char input[8], unsigned char output[8] ); /** * \brief 3DES-CBC buffer encryption * * \param ctx 3DES context * \param iv initialization vector (modified after use) * \param input buffer holding the plaintext * \param output buffer holding the ciphertext * \param len length of the data to be encrypted */ void des3_cbc_encrypt( des3_context *ctx, unsigned char iv[8], unsigned char *input, unsigned char *output, int len ); /** * \brief 3DES-CBC buffer decryption * * \param ctx 3DES context * \param iv initialization vector (modified after use) * \param input buffer holding the ciphertext * \param output buffer holding the plaintext * \param len length of the data to be decrypted */ void des3_cbc_decrypt( des3_context *ctx, unsigned char iv[8], unsigned char *input, unsigned char *output, int len ); /* * \brief Checkup routine * * \return 0 if successful, or 1 if the test failed */ int des_self_test( void ); #ifdef __cplusplus } #endif #endif /* des.h */


【文件预览】:
3DES算法库
----des3.c(24KB)
----des3.h(4KB)

网友评论

  • 挺好的 ,赞一个
  • 不错,可以使用
  • 不错,算法测试通过。
  • 能不能说明一下,怎么用
  • 代码简洁,特别是矩阵变换部分写的很好,初学者受益良多!
  • 派上大用场了,感谢分享...就是注释还不是很详细
  • 代码简洁易懂,3DES CBC模式的加密算法与工具计算的一致,不过解密算法好像有点问题,有待参详。
  • 代码缺少注释,和调用示例 ,不过还是不错的
  • 算法没问题,但跟C#的结果不一样
  • 好像正能满足我的需求,谢谢!
  • 很好的资源,研究研究
  • 用来参考一下很好
  • 一般般,代码缺少注释
  • 工作上很需要。谢谢分享。
  • 非常有用,谢谢
  • 挺好用的,thanks
  • 挺好用的,还有使用例子
  • 一般吧,但不是我想要的东西。
  • 非常有用,谢谢
  • 不错,包括3des cbc\ecb两种模式,代码简洁易懂。
  • 挺好用的,还有使用例子
  • 可以使用,谢谢分享~
  • 包含 des3.c和des3.h两个文件, 有对应的ECB 和 CBC 模式的加解密函数实现
  • 是标准库 可以使用