關於php MD5的16位raw binary輸出和32位字串輸出
因為需要php aes加密資料,考慮使用php MD5 輸出16位的binary作為密鑰。
google 了一下“php MD5 16”? 竟然發現很多文章建議用截取字串的方式實現,語句如下所示:
?
也許他們需要一個長度是16位的隨機字串, 更可能的是他們理解錯了MD5的真正意義。
?
erlang:md5("aaa") .%%輸出:<<71,188,229,199,79,88,159,72,103,219,213,126,156,169,248,8>>
從上面的語句可以看出,erlang:md5輸出一個16位的binary資料,每一位為8bit,16*8 共128bits。
也就是說MD5輸出的是一組,16位(16Byte)128bits的資料。
?
PHP: md5("aaa") //輸出:47bce5c74f589f4867dbd57e9ca9f808
?
MD5 binary format and HEX string?format 對照表如下所示:
| binary: |
71 |
188 |
229 |
199 |
79 |
88 |
159 |
72 |
103 |
219 |
213 |
126 |
156 |
169 |
248 |
8 |
| 16進位表示: |
47 |
bc |
e5 |
c7 |
4f |
58 |
9f |
48 |
67 |
db |
d5 |
7e |
9c |
a9 |
f8 |
08 |
71 如果用十六進位表示就是47; 188十六進位就是bc , 等等。
?
現在我們來看一看PHP的MD5函數:
?
PHP:md5("aaa")輸出的32位長度的字串:47, bc, e5, c7, 4f, 58, 9f, 48, 67, db, d5, 7e, 9c, a9, f8, 08,
其實相當於將16byte binary 資料用HEX表示出來。 類似於顏色RGB(255,255,255)=>#FF FF FF。
?
PHP:md5("aaa", ture) 輸出16byte binary資料。binary資料解析如下所示:?
?
$bin = md5("aaa",ture);for($a=0;$a?