PDF 文件中的可见签名

Visible Signature in a PDF file

我正在尝试在 PDF 文件中创建可见签名。

获取简单的 PDF "hello world" 文件:

%PDF-1.7

1 0 obj  % entry point
<<
  /Type /Catalog
  /Pages 2 0 R
>>
endobj

2 0 obj
<<
  /Type /Pages
  /MediaBox [ 0 0 200 200 ]
  /Count 1
  /Kids [ 3 0 R ]
>>
endobj

3 0 obj
<<
  /Type /Page
  /Parent 2 0 R
  /Resources <<
    /Font <<
      /F1 4 0 R 
    >>
  >>
  /Contents 5 0 R
>>
endobj

4 0 obj
<<
  /Type /Font
  /Subtype /Type1
  /BaseFont /Times-Roman
>>
endobj

5 0 obj  % page content
<<
  /Length 44
>>
stream
BT
10 05 TD
/F1 12 Tf
(Hello, world!) Tj
ET
endstream
endobj

xref
0 6
0000000000 65535 f 
0000000010 00000 n 
0000000079 00000 n 
0000000173 00000 n 
0000000301 00000 n 
0000000380 00000 n 
trailer
<<
  /Size 6
  /Root 1 0 R
>>
startxref
492
%%EOF

并在第一页的某个位置用 "Yolo" 出现的文本进行签名会产生以下结果:

%PDF-1.7

1 0 obj  % entry point
<<
  /Type /Catalog
  /Pages 2 0 R
>>
endobj

2 0 obj
<<
  /Type /Pages
  /MediaBox [ 0 0 200 200 ]
  /Count 1
  /Kids [ 3 0 R ]
>>
endobj

3 0 obj
<<
  /Type /Page
  /Parent 2 0 R
  /Resources <<
    /Font <<
      /F1 4 0 R 
    >>
  >>
  /Contents 5 0 R
>>
endobj

4 0 obj
<<
  /Type /Font
  /Subtype /Type1
  /BaseFont /Times-Roman
>>
endobj

5 0 obj  % page content
<<
  /Length 44
>>
stream
BT
10 05 TD
/F1 12 Tf
(Hello, world!) Tj
ET
endstream
endobj

xref
0 6
0000000000 65535 f 
0000000010 00000 n 
0000000079 00000 n 
0000000173 00000 n 
0000000301 00000 n 
0000000380 00000 n 
trailer
<<
  /Size 6
  /Root 1 0 R
>>
startxref
492
%%EOF
8 0 obj
<</F 132/Type/Annot/Subtype/Widget/Rect[0 0 0 0]/FT/Sig/DR<<>>/T(Signature1)/V 6 0 R/P 3 0 R/AP<</N 7 0 R>>>>
endobj
6 0 obj
<</Contents <...>/Type/Sig/SubFilter/ETSI.CAdES.detached/M(D:20190626125540+00'00')/ByteRange [0 824 60826 1401]/Filter/Adobe.PPKLite>>
endobj
9 0 obj
<</BaseFont/Helvetica/Type/Font/Subtype/Type1/Encoding/WinAnsiEncoding/Name/Helv>>
endobj
10 0 obj
<</BaseFont/ZapfDingbats/Type/Font/Subtype/Type1/Name/ZaDb>>
endobj
12 0 obj
<</Length 35>>stream
BT
1 15 TD
/Helv 6 Tf
(Yolo) Tj
ET

endstream
endobj
7 0 obj
<</Type/XObject/Resources<</ProcSet [/PDF /Text /ImageB /ImageC /ImageI]>>/Subtype/Form/BBox[0 0 0 0]/Matrix [1 0 0 1 0 0]/Length 8/FormType 1/Filter/FlateDecode>>stream
xœ    
endstream
endobj
3 0 obj
<</Type/Page/Parent 2 0 R/Resources<</Font<</F1 4 0 R>>>>/Contents [12 0 R 5 0 R]/Annots[8 0 R]>>
endobj
2 0 obj
<</Type/Pages/MediaBox[0 0 200 200]/Count 1/Kids[3 0 R]>>
endobj
1 0 obj
<</AcroForm<</Fields[8 0 R]/DR<</Font<</Helv 9 0 R/ZaDb 10 0 R>>>>/DA(/Helv 0 Tf 0 g )/SigFlags 3>>/Type/Catalog/Pages 2 0 R>>
endobj
11 0 obj
<</Producer(AdES Tools https://www.turboirc.com)/ModDate(D:20190626125540+00'00')>>
endobj
xref
0 4
0000000000 65535 f 
0000061604 00000 n 
0000061529 00000 n 
0000061414 00000 n 
6 7
0000000804 00000 n 
0000000000 65535 f 
0000000679 00000 n 
0000060952 00000 n 
0000061050 00000 n 
0000061746 00000 n 
0000061127 00000 n 
trailer
<</Root 1 0 R/Prev 492/Info 11 0 R/Size 17/ID[<4BB225C2F629BB21464F66FBF2FED264><8E3C9AD8354C66931EAAC282088455EA>]>>
startxref
61846
%%EOF

因此 PDF 中有一个对象在第一页显示一些文本:

12 0 obj
<</Length 35>>stream
BT
1 15 TD
/Helv 6 Tf
(Yolo) Tj
ET

endstream
endobj

我现在的问题是,此对象在 adobe 中被视为普通文本对象 reader。我希望它在单击时转到数字签名,就像 Adob​​e Acrobat 签署文档的方式一样。

我想念什么?数字签名(6 位或 8 位数字对象)或我的应用放入新 PDF 的任何其他对象中是否有参数,将文本对象与签名链接起来?

非常感谢。

你的对象 8

8 0 obj
<</F 132/Type/Annot/Subtype/Widget/Rect[0 0 0 0]/FT/Sig/DR<<>>/T(Signature1)/V 6 0 R/P 3 0 R/AP<</N 7 0 R>>>>
endobj

是签名的 AcroForm 表单域(正如 FT 条目的值 Sig 告诉我们的那样)。但同时,这个对象也是一个表单字段小部件注释(可以在 TypeSubtype 条目中看到)。表单域小部件注释是表单域的可视化表示,如果表单域只有一种表示,则小部件可以与表单域合并,就像在您的对象中一样。

在您的情况下,注释的大小为 0x0 (/Rect[0 0 0 0]),即不可见。要具有可见的表示,您需要一个不会消失的注释矩形。

显示的内容是在指向对象 7 的正常外观中定义的 /AP<</N 7 0 R>>

7 0 obj
<</Type/XObject/Resources<</ProcSet [/PDF /Text /ImageB /ImageC /ImageI]>>/Subtype/Form/BBox[0 0 0 0]/Matrix [1 0 0 1 0 0]/Length 8/FormType 1/Filter/FlateDecode>>stream
xœ    
endstream
endobj

乍一看这看起来很空,即使在解压后也是如此。

因此,你要做的是

  • 为您的签名表单字段注释选择一个 non-vanishing 矩形,
  • 将正常外观流的BBox适配到那个注解矩形,并且
  • 在该注释的正常外观流中创建 non-empty 内容,而不是添加页面内容。

此外,您应该修复 PDF 中的明显错误,例如

  • 对象 7,您的签名字段正常外观,在您的交叉引用中标记为免费
  • 您的预告片声称尺寸为 17

有关详细信息,请研究 PDF 规范 ISO 32000。第 1 部分由 Adob​​e 在 https://www.adobe.com/content/dam/acom/en/devnet/pdf/pdfs/PDF32000_2008.pdf

发布以供下载

在特定部分

  • 12.5 "Annotations"
  • 12.7 "Interactive Forms"
  • 12.8"Digital Signatures"