PDF / A已通过预检正确验证,但在线pdf工具未对其进行验证

时间:2019-06-27 12:50:45

标签: java pdfbox pdfa

Preflight(版本2.0.15)工具已正确验证了生成的pdf(使用pdfbox版本2.0.15创建)文件,但在线pdf工具(例如https://www.pdf-online.com/osa/validate.aspx)未正确验证它。我遇到以下错误:

合规性pdfa-1b 结果文档不符合PDF / A。 细节 验证文件“ file.pdf”是否符合pdfa-1b级别

XMP元数据中不允许使用匿名RDF资源(无rdf:about属性的rdf:Description)。

外观字典不包含条目。

外观字典不包含条目。

外观字典不包含条目。

外观字典不包含条目。

外观字典不包含条目。

该文档不符合所要求的标准。

该文档包含注释或表单字段,这些注释或表单字段模棱两可或外观不合适。

文档的元数据丢失,不一致或损坏。 该文档不符合PDF / A-1b标准。

完成。

为了生成元数据,我使用以下代码:

private void addMetadata(PDDocument pdDocument,final String zzz,final String yyy) {

    PDDocumentCatalog catalog = pdDocument.getDocumentCatalog();
    PDDocumentInformation info = pdDocument.getDocumentInformation();
    info.setCreationDate(Calendar.getInstance());
    info.setModificationDate(Calendar.getInstance());
    info.setAuthor(metadataAuthor);
    info.setProducer(metadataProducer);
    info.setTitle(zzz + "_" + yyy);
    info.setKeywords("aaa");
    info.setCreator("aaa");
    info.setSubject("aaa");

    PDMarkInfo markInfo = new PDMarkInfo();
    markInfo.setMarked(true);
    catalog.setMarkInfo(markInfo);

    try {
        PDMetadata metadataStream = new PDMetadata(pdDocument);
        catalog.setMetadata( metadataStream );

        XMPMetadata xmp = new XMPMetadata();
        XMPSchemaPDFAId pdfaid = new XMPSchemaPDFAId(xmp);
        xmp.addSchema(pdfaid);
        pdfaid.setConformance("B");
        pdfaid.setPart(1);
        pdfaid.setAbout("");

        XMPSchemaDublinCore dcSchema = xmp.addDublinCoreSchema();
        dcSchema.setTitle( info.getTitle() );
        dcSchema.addCreator("aaa");
        dcSchema.setDescription( info.getSubject() );

        XMPSchemaPDF pdfSchema = xmp.addPDFSchema();
        pdfSchema.setKeywords( info.getKeywords() );
        pdfSchema.setProducer( info.getProducer() );

        XMPSchemaBasic basicSchema = xmp.addBasicSchema();
        basicSchema.setModifyDate( info.getModificationDate() );
        basicSchema.setCreateDate( info.getCreationDate() );
        basicSchema.setCreatorTool( info.getCreator() );

        metadataStream.importXMPMetadata(xmp.asByteArray());

        InputStream colorProfile = getClass().getClassLoader().getResourceAsStream("icm/sRGB Color Space Profile.icm");
        // create output intent

        PDOutputIntent oi = new PDOutputIntent(pdDocument, colorProfile); 
        String value = "sRGB IEC61966-2.1";
        oi.setInfo(value); 
        oi.setOutputCondition(value); 
        oi.setOutputConditionIdentifier(value); 
        oi.setRegistryName("http://www.color.org"); 
        catalog.addOutputIntent(oi);

    } catch (Exception e) {
        e.printStackTrace()
    }

}

有什么建议吗?

1 个答案:

答案 0 :(得分:0)

如评论中所述:

1)无法报告“外观字典不包含条目”是PDFBox预检中的错误,将在2.0.17中修复,请参见PDFBOX-4586。根据{{​​3}}:

  

ISO 19005-1验证程序应失败,否则会通过   哪个小部件注释缺少外观字典

2)“没有rdf:about属性的rdf:Description”可能是错误,也可能不是错误。 this document不认为它是一个。您的代码使用的是1.8。*版本。对于这些,您可以致电dcSchema.setAbout("")来解决。在2.0。*版本中,如果使用metadata.createAndAddDublinCoreSchema()创建架构,则不会发生此问题。

我在VeraPDF中创建了一个问题,他们将把这个问题带到验证技术工作组的下一次会议上讨论。

3)小部件不包含条目是因为在调用setValue()时,没有足够的信息(例如矩形)。这就是为什么收到消息widget of field aa has no rectangle, no appearance stream created的原因