`
jiorry
  • 浏览: 277044 次
  • 性别: Icon_minigender_1
  • 来自: 兰州
社区版块
存档分类
最新评论

关于php MD5的16位raw binary输出和32位字符串输出

阅读更多

因为需要php aes加密数据,考虑使用php MD5 输出16位的binary作为密钥。

google 了一下“php MD5 16”  竟然发现很多文章建议用截取字符串的方式实现,语句如下所示:

<?php echo substr(md5("admin"),8,16); // 16位MD5加密 ?>

 

也许他们需要一个长度是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<strlen($bin);$a++){
    echo ord( $bin[$a] ).','; //每一都位打印出来
}
//输出:71,188,229,199,79,88,159,72,103,219,213,126,156,169,248,8,

 

分享到:
评论

相关推荐

    二进制与字符串之间的转换类CBinary

    CBinary类,处理二进制与字符串之间的转换

    Java计算文件MD5值(支持大文件)

    * 求一个字符串的md5值 * @param target 字符串 * @return md5 value */ public static String MD5(String target) { return DigestUtils.md5Hex(target); } public static void main...

    binary-string:验证值是否为二进制字符串

    二进制字符串 验证值是否为二进制字符串。安装$ npm install validate.io-binary-string 要在浏览器中使用,请使用 。用法 var isBinaryString = require ( 'validate.io-binary-string' ) ;isBinaryString( 值 ) ...

    MD5加密算法(Java语言描述)

     对MD5算法简要的叙述可以为:MD5以512位分组来处理输入的信息,且每一分组又被划分为16个32位子分组,经过了一系列的处理后,算法的输出由四个32位分组组成,将这四个32位分组级联后将生成一个128位散列值。...

    SQL Server字符串处理函数大全

    字符串函数对二进制数据、字符串和表达式执 行不同的运算。此类函数作用于CHAR、VARCHAR、 BINARY、 和VARBINARY 数据类型以及可以隐式转换为CHAR 或VARCHAR的数据类型。可以在SELECT 语句的SELECT 和WHERE 子句...

    pls_interger 和binary_integer的区别与多种数据类型说明

    行类型包括 RAW 和 LONG RAW 两种类型,用来存储二进制数据,不会在字符集间转换。 * RAW:类似于 CHAR,声明方式 RAW(L),L 为长度,以字节为单位,作为数据库列最大 2000,作为变量最大 32767 字节。 * LONG RAW...

    SQLServer字符串处理函数大全[文].pdf

    在实际应用中,字符串处理函数可以用于各种字符串操作,例如将字符串转换为大写或小写、去除字符串中的空格、截取字符串的部分内容、查找字符串中的子串等。 例如,使用 CHARINDEX() 函数可以查找字符串中的某个...

    md5 base64 guid crc16

    md5字符串加密 生成guid唯一随机字符串 base64字符串加解密 文件crc16校验值 示例: Option Explicit Private Declare Function MD5String Lib "CommonFunc.dll" (ByVal s As String) As String Private Declare ...

    cef_binary64位

    应用于此博客https://blog.csdn.net/ldy597321444/article/details/84677752

    Nexus 5 OTA update-binary 和 update-script

    Nexus 5 OTA update-binary 和 update-script ,recovery刷机包制作

    hex-to-binary:将十六进制字符串转换为二进制字符串

    十六进制到二进制 npm install hex-to-binary -S 用法 var hexToBinary = require ( 'hex-to-binary' ) ; var hexString = 'AF30B' ; // 10101111001100001011 console . log ( hexToBinary ( hexString ) ) ;

    wgetwin-1_5_3_1-binary

    wgetwin-1_5_3_1-binary,包含可用实例,已经实际测试过

    cef_binary_3.2171.1979_编译好的32位和64位文件

    压缩包中包含cef 3.2171.1979版本的头文件、lib文件和dll文件,包含32位和64位,其中libcef_dll_wrapper.lib 为debug版本,libcef_dll_wrapper_r.lib 为 release 版本。 注意:编译版本为vs2010,不支持其他版本的vs...

    SQL字符串操作函数.doc

    字符串函数对二进制数据、字符串和表达式执行不同的运算。此类函数作用于CHAR、VARCHAR、 BINARY、 和VARBINARY 数据类型以及可以隐式转换为CHAR 或VARCHAR的数据类型

    二值神经网络(Binary Neural Networks)最新综述.md

    神经网络二值化能够**最大程度地降低模型的存储占用和模型的计算量**,将神经网络中**原本 32 位浮点数参数量化至 1 位定点数**,**降低了模型部署的存储资源消耗,同时极大加速了神经网络的推断过程**。但二值化会...

    BinaryBomb实验-计算机系统基础-gddrxy

    一个“binary bombs”(二进制炸弹,下文将简称为炸弹)是一个Linux可执行C程序,包含了7个阶段(phase1~phase6和一个隐藏阶段)。炸弹运行的每个阶段要求学生输入一个特定的字符串,若的输入符合程序预期的输入,该...

    U盘启动盘制作工具 Win32DiskImager-1.0.0-binary.rar

    U盘启动盘制作工具 Win32DiskImager-1.0.0-binary.rar

    binary-tools win编译php工具包

    win环境编译php工具包, 还有个自己下载

    cef_binary2

    集成chrome 内核收集到的 cef_binary , 包含cef 1x,2x,41,43 版本。 具体看 https://www.spotify.com/sg-en/opensource/ cef 对应 chrome版本 cef_binary_3.2357.1271.g8e0674e_windows32 cef_binary_3....

    ftp的ASCII模式和Binary模式的区别

    ftp的ASCII模式和Binary模式的区别

Global site tag (gtag.js) - Google Analytics