Bitcoin Block(.dat)数据解析

本文转自 玩币族
一、Block 预览
 使用编辑器比如Sublime打开blk00000.dat。
 .dat文件以Little-Endian格式存储Block数据,比如下面的就是创世块的数据:
Bitcoin Block(.dat)数据解析_第1张图片
二、Block结构
 Block由5个部分组成,以magic数据开始:
Bitcoin Block(.dat)数据解析_第2张图片
三、魔法数
 每个块总是以魔法数开始,正式网络是0xD9B5BEF9,测试网络是0x0709110B。
四、块头部
Bitcoin Block(.dat)数据解析_第3张图片
版本号
 目前的块版本号有1和2,在227836及之后的块的版本号都是2,在之前的块有的是2有的是1。
目标值
 目标值0x1D00FFFF由两个部分组成:指数0x1D(=29)和尾数0x00FFFF,真实的目标值的大小计算方式是:
 目标值=尾数*256指数
 所以这里的目标值为:
 0xFFFF0000000000000000000000000000000000000000000000000000。
随机数
 随机数用于挖矿时生成符合要求的块哈希。
五、交易个数
 描述交易个数字节的长度和大小如下表:
Bitcoin Block(.dat)数据解析_第4张图片
 如果随机数之后的第一个字节比0xfd小,那么该字节就是交易大小的字节,比如创世块的随机数后的第一个字节是0x01,那么创世块里的交易个数为1。
 如果第一个字节是0xfd那么0xfd后面的两个字节就是交易大小的字节,以此类推。
六、交易
 每个交易都由6个部分组成
Bitcoin Block(.dat)数据解析_第5张图片
 每个交易输入由5个部分组成
Bitcoin Block(.dat)数据解析_第6张图片
上一个交易哈希值
 对于coinbase交易不存在上一个交易,所以示例中的值是
 0x0000000000000000000000000000000000000000000000000000000000000000
上一个交易的输出位置
 对于coinbase它的值总是0xFFFFFFFF
 每个交易输出由3个部分组成
Bitcoin Block(.dat)数据解析_第7张图片
输出值
 示例中的输出值0x12A05F200转换成十进制大小是5000000000。
输出脚本
 输出脚本定义了该交易输出再次被花费的方式。

你可能感兴趣的:(Bitcoin)