云题海 - 专业文章范例文档资料分享平台

当前位置:首页 > PDF文件结构

PDF文件结构

  • 62 次阅读
  • 3 次下载
  • 2025/6/16 6:05:41

PDF(Portable Document Format,便携式文档结构)是一种很有用的文件格式,其最大的特点是平台无关而且功能强大(支持文字/图象/表单/链接/音乐/视频等).做PDF的解析,首先要熟悉PDF文件的物理结构和逻辑结构。PDF文件物理结构可分为以下几块: 1.文件头

文件头是PDF文件的第一行,格式如下:

%PDF-1.4

这是个固定格式,表示这个PDF文件遵循的PDF规范版本,目前PDF的生成工具,除了官方的acrobat,其他生成的以1.4版本的居多。对于做PDF开发来说,一个最简单的原则就是生成PDF的时候尽量符合低版本规范,以保证大多数解析器能支持;解析PDF的时候尽量支持高版本的规范,以保证支持大多数工具生成的PDF文件。

从1.4版本以后,PDF文件的版本并不唯一的只是在这里表示了,可能后面会改写(catalog的Version词条),所以解析PDF的时候,如果这里的版本大于等于1.4,应该再比较一下catalog里面的version,取其中高一点的版本。

2.对象集合

这是一个PDF文件最重要的部分,文件中用到的所有对象,包括文本/图象/音乐/视频/字体/超连接/加密信息/文档结构信息等等,都在这里定义。格式如下:

2 0 obj

... end obj

一个对象的定义包含4个部分:

前面的2是对象序号,其用来唯一标记一个对象;0是生成号,按照PDF规范,如果一个PDF文件被修改,那这个数字是累加的,它和对象序号一起标记是原始对象还是修改后的对象,但是实际开发中,很少有用这种方式修改PDF的,都是重新编排对象号;obj和endobj是对象的定义范围,可以抽象的理解为这就是一个左括号和右括号;省略号部分是PDF规定的任意合法对象(一共8种,见后面附A)。

可以通过R关键字来引用任何一个对象,比如要引用上面的对象,可以使用2 0 R,需要主意的是,R关键字不仅可以引用一个已经定义的对象,还可以引

用一个并不存在的对象,而且效果就和引用了一个空对象一样。

3.交叉引用表

交叉引用表是PDf文件内部一种特殊的文件组织方式,可以很方便的根据对象号随机访问一个对象。其格式如下: xref 0 1

0000000000 65535 f 4 1

0000000009 00000 n 8 3

0000000074 00000 n 0000000120 00000 n 0000000179 00000 n

其中,xref是开始标志,表示以下为一个交叉引用表的内容;每个交叉引用表又可以分为若干个子段,每个子段的第一行是两个数字,第一个是对象起始号,后面是连续的对象个数,接着每行是这个子段的每个对象的具体信息——每行的前10个数字代表这个这个对象相对文件头的偏移地址,后面的5位数字是生成号(用于标记PDF的更新信息,和对象的生成号作用类似),最后一位f或n表示对象是否被使用(n表示使用,f表示被删除或没有用)。上面这个交叉引用表一共有3个子段,分别有1个,1个,3个对象,第一个子段的对象不可用,其余子段对象可用。 4.trailer:

通过trailer可以快速的找到交叉引用表的位置,进而可以精确定位每一个对象;还可以通过它本身的字典还可以获取文件的一些全局信息(作者,关键字,标题等),加密信息,等等。具体形式如下: trailer <<

key1 value1 key2 value2 key3 value3

… >> startxref 553 %%EOF

trailer后面紧跟一个字典,包含若干键-值对。具体含义如下: 键 Size

值类型

值说明

会有多个对象集合、交叉引用表、trailer,最后一个trailer的这个字段记录了之前所有对象的个数。这个值必须是直接对象。

Prev

整形数字 当文件有多个对象集合、交叉引用表和trailer时,才会有

这个键,它表示前一个相对于文件头的偏移位置。这个值必须是直接对象。

Root

字典

Catalog字典(文件的逻辑入口点)的对象号。必须是间接对象。

Encrypt 字典 Info 字典 ID 数组 移量。

%%EOF :文件结束符.

一个PDF文件,都会有上面这样的结构(线性化优化的PDF例外,这个后面单独说)。实际一个pdf文件是很复杂的,但是上面几个部分是确定的,只能多不能少.了解了PDF文件的物理结构,就可以提取出一个一个的对象了.PDF中的对象有8种: 1.booleam

用关键字true或false表示,可以是array对象的一个元素,或dictionary对象的一个条目.也可以用在PostScript计算函数里面,做为if或ifesle的一个条件。 2.numeric

包括整形和实型,不支持非十进制数字,不支持指数形式的数字.

文档被保护时,会有这个字段,加密字典的对象号。

存放文档信息的字典,必须是间接对象。 文件的ID

整形数字 所有间接对象的个数。一个PDF文件,如果被更新过,则

startxref: 后面的数字表示最后一个交叉引用表相对于文件起始位置的偏

例:

1)整数 123 4567 +111 -2 范围:正2的31次方-1到负的2的31次方 2)实

数 12.3 0.8 +6.3 -4.01 -3. +.03

范围:±3.403 × 10的38次方 ±1.175 × 10的-38次方

注意:如果整数超过表示范围将转化成实数,如果实数超过范围就出错了

3.string

由一系列0-255之间的字节组成,一个string总长度不能超过65535.string有以下两种方式:

1) 直接字串

由()包含起来的一个字串,中间可以使用转义符\ 例:

(abc) 表示abc (a//) 表示a/

转义符的定义如下:

转义字符 /n /r /t /b /f /( /) // /ddd

2) 十六进制字串

由<>包含起来的一个16进制串,两位表示一个字符,不足两位用0补齐

例:

表示AA和BB两个字符

含义 换行 回车 水平制表符 退格

换页(Form feed (FF)) 左括号 右括号 反斜杠

八进制形式的字符

搜索更多关于: PDF文件结构 的文档
  • 收藏
  • 违规举报
  • 版权认领
下载文档10.00 元 加入VIP免费下载
推荐下载
本文作者:...

共分享92篇相关文档

文档简介:

PDF(Portable Document Format,便携式文档结构)是一种很有用的文件格式,其最大的特点是平台无关而且功能强大(支持文字/图象/表单/链接/音乐/视频等).做PDF的解析,首先要熟悉PDF文件的物理结构和逻辑结构。PDF文件物理结构可分为以下几块: 1.文件头 文件头是PDF文件的第一行,格式如下: %PDF-1.4 这是个固定格式,表示这个PDF文件遵循的PDF规范版本,目前PDF的生成工具,除了官方的acrobat,其他生成的以1.4版本的居多。对于做PDF开发来说,一个最简单的原则就是生成PDF的时候尽量符合低版本规范,以保证大多数解析器能支持;解析PDF的时候尽量支持高版本的规范,以保证支持大多数工具生成的PDF文件。 从1.4版本以后,P

× 游客快捷下载通道(下载后可以自由复制和排版)
单篇付费下载
限时特价:10 元/份 原价:20元
VIP包月下载
特价:29 元/月 原价:99元
低至 0.3 元/份 每月下载150
全站内容免费自由复制
VIP包月下载
特价:29 元/月 原价:99元
低至 0.3 元/份 每月下载150
全站内容免费自由复制
注:下载文档有可能“只有目录或者内容不全”等情况,请下载之前注意辨别,如果您已付费且无法下载或内容有问题,请联系我们协助你处理。
微信:fanwen365 QQ:370150219
Copyright © 云题海 All Rights Reserved. 苏ICP备16052595号-3 网站地图 客服QQ:370150219 邮箱:370150219@qq.com