acl  3.5.3.0
md5.hpp
浏览该文件的文档.
1 #pragma once
2 #include "../acl_cpp_define.hpp"
3 #include "noncopyable.hpp"
4 
5 namespace acl {
6 
7 class istream;
8 
9 class ACL_CPP_API md5 : public noncopyable
10 {
11 public:
12  md5(void);
13  ~md5(void);
14 
15  /**
16  * 可以循环调用此函数添加需要被 md5 的数据
17  * @param dat {const void*} 数据地址
18  * @param len {size_t} dat 数据长度
19  * @return {md5&}
20  */
21  md5& update(const void* dat, size_t len);
22 
23  /**
24  * 必须调用本函数表示 md5 过程结束
25  * @return {md5&}
26  */
27  md5& finish(void);
28 
29  /**
30  * 重置 md5 算法器的状态,从而允许重复使用同一个 md5 对象
31  * @return {md5&}
32  */
33  md5& reset(void);
34 
35  /**
36  * 获得二进制格式的 md5 结果值
37  * @return {const char*} 返回值永远非空,且缓冲区长度为 16 字节
38  */
39  const char* get_digest() const;
40 
41  /**
42  * 获得以字符串形式表示的 m5 结果值
43  * @return {const char*} 返回值永远非空,且以 \0 结尾,且字符串
44  * 长度为 32 字节
45  */
46  const char* get_string() const;
47 
48  /**
49  * 将数据用 md5 算法计算签名值,取得 128 位 (即 16 字节) 二进制结果
50  * @param dat {const void*} 源数据
51  * @param dlen {size_t} dat 数据长度
52  * @param key {const char*} 非空时做为键数据
53  * @param klen {size_t} key 非空时表示 key 的长度
54  * @param out {void*} 存储 md5 结果
55  * @param size {size_t} out 大小,至少应该为 16 字节
56  * @return {const char*} 返回存储结果的地址(即 out 地址)
57  */
58  static const char* md5_digest(const void *dat, size_t dlen,
59  const void *key, size_t klen, void* out, size_t size);
60 
61  /**
62  * 将数据用 md5 算法计算签名值,取得字符串形式的结果
63  * @param dat {const void*} 源数据
64  * @param dlen {size_t} dat 数据长度
65  * @param key {const char*} 非空时做为键数据
66  * @param klen {size_t} key 非空时表示 key 的长度
67  * @param out {void*} 存储 md5 结果
68  * @param size {size_t} out 大小,至少应该为 33 字节
69  * @return {const char*} 返回存储结果的地址(即 out 地址),
70  * 且返回值为以 \0 结尾的 32 字节长度(不含 \0)字符串
71  */
72  static const char* md5_string(const void *dat, size_t dlen,
73  const void *key, size_t klen, char* out, size_t size);
74 
75  /**
76  * 将文件中的内容用 md5 算法计算签名值,并取得字符串形式结果
77  * @param path {const char*} 文件全路径
78  * @param key {const char*} 非空时做为键数据
79  * @param klen {size_t} key 非空时表示 key 的长度
80  * @param out {void*} 存储 md5 结果
81  * @param size {size_t} out 大小,至少应该为 33 字节
82  * @return {int64) 返回所读取的文件数据的长度,下列情况下返回 -1
83  * 1) 打开文件失败
84  * 2) 未从文件中读到数据
85  * 3) out 缓冲区大小 size 小于 33 字节长度
86  */
87 #if defined(_WIN32) || defined(_WIN64)
88  static __int64 md5_file(const char* path, const void *key,
89  size_t klen, char* out, size_t size);
90 #else
91  static long long int md5_file(const char* path, const void *key,
92  size_t klen, char* out, size_t size);
93 #endif
94 
95  /**
96  * 将文件中的内容用 md5 算法计算签名值,并取得字符串形式结果
97  * @param in {istream&} 输入文件流
98  * @param key {const char*} 非空时做为键数据
99  * @param klen {size_t} key 非空时表示 key 的长度
100  * @param out {void*} 存储 md5 结果
101  * @param size {size_t} out 大小,至少应该为 33 字节
102  * @return {int64) 返回所读取的文件数据的长度,下列情况下返回 -1:
103  * 1) 未从输入流中读取数据时
104  * 2) out 缓冲区大小 size 小于 33 字节长度
105  */
106 #if defined(_WIN32) || defined(_WIN64)
107  static __int64 md5_file(istream& in, const void *key,
108  size_t klen, char* out, size_t size);
109 #else
110  static long long int md5_file(istream& in, const void *key,
111  size_t klen, char* out, size_t size);
112 #endif
113 
114  /**
115  * 将 16 字节长度的 MD5 二进制结果转换为 32 字节长度的字符串
116  * @param in {const void*} 128 位(即 16 字节)的 md5 值,即 in 的数据长度
117  * 至少应该 >= 16,否则会引起内存起越界
118  * @param out {char*} 存储字符串形式的结果
119  * @param size {size_t} out 内存大小,至少为 33 字节,否则内部产生断言
120  * @return {const char*} 返回存储结果的地址(即 out 地址),
121  * 且返回值为以 \0 结尾的 32 字节长度(不含 \0)字符串
122  */
123  static const char* hex_encode(const void *in, char* out, size_t size);
124 
125 private:
126  unsigned int buf_[4];
127  unsigned int bytes_[2];
128  unsigned int in_[16];
129 
130  unsigned char digest_[16];
131  unsigned char digest_s_[33];
132 };
133 
134 } // namespace acl
Definition: md5.hpp:9
#define ACL_CPP_API