OCF文件解析过程

来源:互联网 发布:删除数组中指定元素 编辑:程序博客网 时间:2024/06/05 17:29

参阅文档OMA-Download-DRMCF-V1_0-20040615-A.pdf和程序验证,已经利用java程序成功解析经过DRM加密的dcf文件。

dcf字节流解析:

dcf规范版本               1 byte    值始终为1
ContentType长度           1 byte    ContentType长度
ContentURL长度            1 byte    ContentURL长度(contentID的长度)
ContentType               n byte    ContentType(现在默认为text/html)
ContentURL                n byte    ContentURL(contentID  根据约定为32位字符串)
头描述信息长度             Uintvar   头描述信息长度
加密数据长度               Uintvar   加密数据长度
头描述信息                 n byte    头描述信息
加密数据                   n byte    加密数据

关键点说明:

1、Uintvar类型占的字节数是可变的,表示整数,最多为5个字节,判断具体占多少个字节方法:字节的最高位作为标志位,高位为1表示后面还有一个字节  
  高位为0表示这是最后一个字节,其余的7位表示整数的值,字节序是高位在前低位在后。(测试用的dcf文件比较小,都只占了一个byte)

2、加密数据组成:加密数据包括两部分,前面16个字节为加密内容的初始化向量(根据RFC2630填充的,具体什么东西不知道),从第17字节开始到文件末尾为真实的数据。

3、DRM的解密密钥为26位的字符串,但是AES-CBC-128加密算法的解密密钥为128位(16位字符串),所以解密前需要先用Base64把解密密钥转码为16位字符串。

4、客户端解密过程:
 (1)、按字节流读出dcf
 (2)、分别取头三个字节,根据第二个和第三个字节表示的长度信息获取ContentType和ContentURL,从而得到contentID。
 (3)、将contentID发往DRM,经过鉴权后取得解密密钥(内容许可证)。
 (4)、解密内容许可证,获得26位的字符串。
 (5)、用Base64把26位的字符串转码为16位字符串,作为解密密钥。
 (6)、根据Uintvar规则,取得后面头描述信息和加密数据的长度。
 (7)、根据长度分别截取字节流获得头描述信息和加密数据。
 (8)、用解密密钥解密加密的数据,得到明文。
 (9)、将明文的前16字节(初始化向量)去掉,获得原始数据。
 (10)、根据ContentType,将原始数据字节流保存为相应文件,完成整个解密过程。

原创粉丝点击