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,将原始数据字节流保存为相应文件,完成整个解密过程。
- OCF文件解析过程
- 解析Txt文件的过程
- XML文件的解析过程
- android prop文件解析过程
- OCF源码分析
- OCF的组成结构
- sax解析xml文件过程总结
- avi在opencore中的文件解析过程
- init.rc文件解析过程详解
- class文件的(解析)执行过程
- Android init.rc文件解析过程分析
- IAR生成文件链接过程解析
- IAR生成文件链接过程解析
- Android-LayoutInflater布局文件解析过程分析
- 自定义VIEW中的XML文件解析过程
- Android XML布局文件解析过程源码解析
- JVM 深入学习:Java 解析 Class 文件过程解析
- Android XML布局文件解析过程源码解析
- Ubuntu中设置vim的行号
- WINDOWS下安装多个MySQL
- Sybase 索引的使用和优化
- SHChangeNotify
- [Leetcode] Search in Rotated Sorted Array
- OCF文件解析过程
- ViewData与ViewBag比较
- Eclipse快速上手指南之使用ANT
- 嵌入式系统的硬件基本结构和软件层次结构
- Ajax初识_通过ajax校验数据(xml)
- Eclipse插件FatJar安装与使用
- JavaScript中把数字转换为字符串
- OLTP和OLAP
- 手机和网络结合 是社会的必然趋势(中移动已经行动了)