AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren

Wie prüfen ob PDF ZUGFeRD enthält?

Ein Thema von TurboMagic · begonnen am 8. Aug 2024 · letzter Beitrag vom 23. Okt 2024
Antwort Antwort
Rollo62

Registriert seit: 15. Mär 2007
4.166 Beiträge
 
Delphi 12 Athens
 
#1

AW: Wie prüfen ob PDF ZUGFeRD enthält?

  Alt 9. Aug 2024, 15:17
Es kommt
Zitat:
Hochgeladene Datei: MustangGnuaccountingBeispielRE-20190610_507.pdf

Keine E-Rechnungs-/ZUGFeRD-Daten gefunden.
Wenn die Datei OK ist, dann ist das keine sehr sinnvolle Meldung.

Ich habe es mal mit dem MustangProject MustangCLI überprüft: Zumindest sagt der schonmal Status "Valid"
Aber dann doch später "Invalid", gelistet ist es unter den Examples "Correct".

Delphi-Quellcode:
<?xml version="1.0" encoding="UTF-8"?>

<validation filename="invoice.pdf" datetime="2024-08-09 16:13:05">
  <pdf>ValidationResult [flavour=3u, totalAssertions=11261, assertions=[], isCompliant=true]
    <info>
      <signature>Mustang</signature>
      <duration unit="ms">1921</duration>
    </info>
    <summary status="valid"/>
  </pdf>
  <xml>
    <info>
      <version>2</version>
      <profile>urn:cen.eu:en16931:2017</profile>
      <validator version="2.12.0"/>
      <rules>
        <fired>130</fired>
        <failed>2</failed>
      </rules>
      <duration unit="ms">5532</duration>
    </info>
    <messages>
      <error type="18">schema validation fails:org.xml.sax.SAXParseException; lineNumber: 175; columnNumber: 37; cvc-complex-type.2.4.d: Ungültiger Content wurde beginnend mit Element 'ram:GermanBankleitzahlID' gefunden. An dieser Stelle wird kein untergeordnetes Element erwartet.</error>
      <error type="4" location="/*[local-name()='CrossIndustryInvoice']/*[local-name()='SupplyChainTradeTransaction']/*[local-name()='ApplicableHeaderTradeAgreement']/*[local-name()='SellerTradeParty']/*[local-name()='SpecifiedLegalOrganization']/*[local-name()='ID']" criterion="document('FACTUR-X_EN16931_codedb.xml')//cl[@id=11]/enumeration[@value=$codeValue11]">Value of '@schemeID' is not allowed. from /xslt/ZF_221/FACTUR-X_EN16931.xslt)</error>
      <error type="24" location="/*:CrossIndustryInvoice[namespace-uri()='urn:un:unece:uncefact:data:standard:CrossIndustryInvoice:100'][1]/*:SupplyChainTradeTransaction[namespace-uri()='urn:un:unece:uncefact:data:standard:CrossIndustryInvoice:100'][1]/*:ApplicableHeaderTradeAgreement[namespace-uri()='urn:un:unece:uncefact:data:standard:ReusableAggregateBusinessInformationEntity:100'][1]/*:SellerTradeParty[namespace-uri()='urn:un:unece:uncefact:data:standard:ReusableAggregateBusinessInformationEntity:100'][1]/*:SpecifiedLegalOrganization[namespace-uri()='urn:un:unece:uncefact:data:standard:ReusableAggregateBusinessInformationEntity:100'][1]/*:ID[namespace-uri()='urn:un:unece:uncefact:data:standard:ReusableAggregateBusinessInformationEntity:100'][1]" criterion="((not(contains(normalize-space(@schemeID), ' ')) and contains(' 0002 0003 0004 0005 0006 0007 0008 0009 0010 0011 0012 0013 0014 0015 0016 0017 0018 0019 0020 0021 0022 0023 0024 0025 0026 0027 0028 0029 0030 0031 0032 0033 0034 0035 0036 0037 0038 0039 0040 0041 0042 0043 0044 0045 0046 0047 0048 0049 0050 0051 0052 0053 0054 0055 0056 0057 0058 0059 0060 0061 0062 0063 0064 0065 0066 0067 0068 0069 0070 0071 0072 0073 0074 0075 0076 0077 0078 0079 0080 0081 0082 0083 0084 0085 0086 0087 0088 0089 0090 0091 0093 0094 0095 0096 0097 0098 0099 0100 0101 0102 0104 0105 0106 0107 0108 0109 0110 0111 0112 0113 0114 0115 0116 0117 0118 0119 0120 0121 0122 0123 0124 0125 0126 0127 0128 0129 0130 0131 0132 0133 0134 0135 0136 0137 0138 0139 0140 0141 0142 0143 0144 0145 0146 0147 0148 0149 0150 0151 0152 0153 0154 0155 0156 0157 0158 0159 0160 0161 0162 0163 0164 0165 0166 0167 0168 0169 0170 0171 0172 0173 0174 0175 0176 0177 0178 0179 0180 0183 0184 0185 0186 0187 0188 0189 0190 0191 0192 0193 0194 0195 0196 0197 0198 0199 0200 0201 0202 0203 0204 0205 0206 0207 0208 0209 0210 0211 0212 0213 0214 0215 0216 0217 0218 0219 0220 0221 0222 0223 0224 0225 0226 0227 0228 0229 0230 ', concat(' ', normalize-space(@schemeID), ' '))))">[BR-CL-11]-Any registration identifier identification scheme identifier MUST be coded using one of the ISO 6523 ICD list. [ID BR-CL-11] from /xslt/cii16931schematron/EN16931-CII-validation.xslt)</error>
    </messages>
    <summary status="invalid"/>
  </xml>
  <messages></messages>
  <summary status="invalid"/>
</validation>

Geändert von Rollo62 ( 9. Aug 2024 um 15:23 Uhr)
  Mit Zitat antworten Zitat
Rollo62

Registriert seit: 15. Mär 2007
4.166 Beiträge
 
Delphi 12 Athens
 
#2

AW: Wie prüfen ob PDF ZUGFeRD enthält?

  Alt 9. Aug 2024, 15:22
Ich lade mal die entsprechende Datei hier hoch.

MustangGnuaccountingBeispielRE-20190610_507.pdf

Ist die jetzt Valid, oder nicht?
  Mit Zitat antworten Zitat
Rollo62

Registriert seit: 15. Mär 2007
4.166 Beiträge
 
Delphi 12 Athens
 
#3

AW: Wie prüfen ob PDF ZUGFeRD enthält?

  Alt 9. Aug 2024, 15:38
Nochmal mit anderen Settings:
%java_exe% -Xmx1G -Dfile.encoding=UTF-8 -jar "%mustangCLI_jar%" --action validate --source invoice.pdf > invoice_out.xml

Sorry, das rendert hier nicht wirklich.
invoice_out.xml

Delphi-Quellcode:
<?xml version="1.0" encoding="UTF-8"?>

<validation filename="invoice.pdf" datetime="2024-08-09 16:32:57">
  <pdf>ValidationResult [flavour=3u, totalAssertions=11261, assertions=[], isCompliant=true]
    <info>
      <signature>Mustang</signature>
      <duration unit="ms">1984</duration>
    </info>
    <summary status="valid"/>
  </pdf>
  <xml>
    <info>
      <version>2</version>
      <profile>urn:cen.eu:en16931:2017</profile>
      <validator version="2.12.0"/>
      <rules>
        <fired>33</fired>
        <failed>12</failed>
      </rules>
      <duration unit="ms">6125</duration>
    </info>
    <messages>
      <error type="18">schema validation fails:org.xml.sax.SAXParseException; lineNumber: 175; columnNumber: 37; cvc-complex-type.2.4.d: Ungültiger Content wurde beginnend mit Element 'ram:GermanBankleitzahlID' gefunden. An dieser Stelle wird kein untergeordnetes Element erwartet.</error>
      <error type="4" location="/*[local-name()='CrossIndustryInvoice']/*[local-name()='SupplyChainTradeTransaction']/*[local-name()='ApplicableHeaderTradeAgreement']/*[local-name()='SellerTradeParty']/*[local-name()='SpecifiedLegalOrganization']/*[local-name()='ID']" criterion="document('FACTUR-X_EN16931_codedb.xml')//cl[@id=11]/enumeration[@value=$codeValue11]">Value of '@schemeID' is not allowed. from /xslt/ZF_221/FACTUR-X_EN16931.xslt)</error>
      <error type="24" location="/*:CrossIndustryInvoice[namespace-uri()='urn:un:unece:uncefact:data:standard:CrossIndustryInvoice:100'][1]/*:SupplyChainTradeTransaction[namespace-uri()='urn:un:unece:uncefact:data:standard:CrossIndustryInvoice:100'][1]/*:ApplicableHeaderTradeAgreement[namespace-uri()='urn:un:unece:uncefact:data:standard:ReusableAggregateBusinessInformationEntity:100'][1]/*:SellerTradeParty[namespace-uri()='urn:un:unece:uncefact:data:standard:ReusableAggregateBusinessInformationEntity:100'][1]/*:SpecifiedLegalOrganization[namespace-uri()='urn:un:unece:uncefact:data:standard:ReusableAggregateBusinessInformationEntity:100'][1]/*:ID[namespace-uri()='urn:un:unece:uncefact:data:standard:ReusableAggregateBusinessInformationEntity:100'][1]" criterion="((not(contains(normalize-space(@schemeID), ' ')) and contains(' 0002 0003 0004 0005 0006 0007 0008 0009 0010 0011 0012 0013 0014 0015 0016 0017 0018 0019 0020 0021 0022 0023 0024 0025 0026 0027 0028 0029 0030 0031 0032 0033 0034 0035 0036 0037 0038 0039 0040 0041 0042 0043 0044 0045 0046 0047 0048 0049 0050 0051 0052 0053 0054 0055 0056 0057 0058 0059 0060 0061 0062 0063 0064 0065 0066 0067 0068 0069 0070 0071 0072 0073 0074 0075 0076 0077 0078 0079 0080 0081 0082 0083 0084 0085 0086 0087 0088 0089 0090 0091 0093 0094 0095 0096 0097 0098 0099 0100 0101 0102 0104 0105 0106 0107 0108 0109 0110 0111 0112 0113 0114 0115 0116 0117 0118 0119 0120 0121 0122 0123 0124 0125 0126 0127 0128 0129 0130 0131 0132 0133 0134 0135 0136 0137 0138 0139 0140 0141 0142 0143 0144 0145 0146 0147 0148 0149 0150 0151 0152 0153 0154 0155 0156 0157 0158 0159 0160 0161 0162 0163 0164 0165 0166 0167 0168 0169 0170 0171 0172 0173 0174 0175 0176 0177 0178 0179 0180 0183 0184 0185 0186 0187 0188 0189 0190 0191 0192 0193 0194 0195 0196 0197 0198 0199 0200 0201 0202 0203 0204 0205 0206 0207 0208 0209 0210 0211 0212 0213 0214 0215 0216 0217 0218 0219 0220 0221 0222 0223 0224 0225 0226 0227 0228 0229 0230 ', concat(' ', normalize-space(@schemeID), ' '))))">[BR-CL-11]-Any registration identifier identification scheme identifier MUST be coded using one of the ISO 6523 ICD list. [ID BR-CL-11] from /xslt/cii16931schematron/EN16931-CII-validation.xslt)</error>
      <notice type="27" location="/rsm:CrossIndustryInvoice/rsm:ExchangedDocumentContext[1]" criterion="ram:BusinessProcessSpecifiedDocumentContextParameter/ram:ID">Business process MUST be provided. [ID PEPPOL-EN16931-R001] from /xslt/XR_30/XRechnung-CII-validation.xslt)</notice>
      <notice type="27" location="/rsm:CrossIndustryInvoice/rsm:SupplyChainTradeTransaction[1]/ram:ApplicableHeaderTradeAgreement[1]/ram:SellerTradeParty[1]" criterion="ram:URIUniversalCommunication/ram:URIID">Seller electronic address MUST be provided [ID PEPPOL-EN16931-R020] from /xslt/XR_30/XRechnung-CII-validation.xslt)</notice>
      <notice type="27" location="/rsm:CrossIndustryInvoice/rsm:SupplyChainTradeTransaction[1]/ram:ApplicableHeaderTradeAgreement[1]/ram:BuyerTradeParty[1]" criterion="ram:URIUniversalCommunication/ram:URIID">Buyer electronic address MUST be provided [ID PEPPOL-EN16931-R010] from /xslt/XR_30/XRechnung-CII-validation.xslt)</notice>
      <notice type="27" location="/rsm:CrossIndustryInvoice/rsm:SupplyChainTradeTransaction[1]/ram:IncludedSupplyChainTradeLineItem[1]/ram:SpecifiedTradeProduct[1]/ram:Description[1]" criterion="false()">Document MUST not contain empty elements. [ID PEPPOL-EN16931-R008] from /xslt/XR_30/XRechnung-CII-validation.xslt)</notice>
      <notice type="27" location="/rsm:CrossIndustryInvoice/rsm:SupplyChainTradeTransaction[1]/ram:IncludedSupplyChainTradeLineItem[2]/ram:SpecifiedTradeProduct[1]/ram:Description[1]" criterion="false()">Document MUST not contain empty elements. [ID PEPPOL-EN16931-R008] from /xslt/XR_30/XRechnung-CII-validation.xslt)</notice>
      <notice type="27" location="/rsm:CrossIndustryInvoice/rsm:SupplyChainTradeTransaction[1]/ram:IncludedSupplyChainTradeLineItem[3]/ram:SpecifiedTradeProduct[1]/ram:Description[1]" criterion="false()">Document MUST not contain empty elements. [ID PEPPOL-EN16931-R008] from /xslt/XR_30/XRechnung-CII-validation.xslt)</notice>
      <notice type="27" location="/rsm:CrossIndustryInvoice/rsm:SupplyChainTradeTransaction[1]/ram:IncludedSupplyChainTradeLineItem[1]/ram:SpecifiedLineTradeAgreement[1]/ram:GrossPriceProductTradePrice[1]" criterion="not(ram:ChargeAmount) or xs:decimal(../ram:NetPriceProductTradePrice/ram:ChargeAmount) = xs:decimal(ram:ChargeAmount) - xs:decimal(ram:AppliedTradeAllowanceCharge/ram:ActualAmount)">Item net price MUST equal (Gross price - Allowance amount) when gross price is provided. [ID PEPPOL-EN16931-R046] from /xslt/XR_30/XRechnung-CII-validation.xslt)</notice>
      <notice type="27" location="/rsm:CrossIndustryInvoice/rsm:SupplyChainTradeTransaction[1]/ram:IncludedSupplyChainTradeLineItem[2]/ram:SpecifiedLineTradeAgreement[1]/ram:GrossPriceProductTradePrice[1]" criterion="not(ram:ChargeAmount) or xs:decimal(../ram:NetPriceProductTradePrice/ram:ChargeAmount) = xs:decimal(ram:ChargeAmount) - xs:decimal(ram:AppliedTradeAllowanceCharge/ram:ActualAmount)">Item net price MUST equal (Gross price - Allowance amount) when gross price is provided. [ID PEPPOL-EN16931-R046] from /xslt/XR_30/XRechnung-CII-validation.xslt)</notice>
      <notice type="27" location="/rsm:CrossIndustryInvoice/rsm:SupplyChainTradeTransaction[1]/ram:IncludedSupplyChainTradeLineItem[3]/ram:SpecifiedLineTradeAgreement[1]/ram:GrossPriceProductTradePrice[1]" criterion="not(ram:ChargeAmount) or xs:decimal(../ram:NetPriceProductTradePrice/ram:ChargeAmount) = xs:decimal(ram:ChargeAmount) - xs:decimal(ram:AppliedTradeAllowanceCharge/ram:ActualAmount)">Item net price MUST equal (Gross price - Allowance amount) when gross price is provided. [ID PEPPOL-EN16931-R046] from /xslt/XR_30/XRechnung-CII-validation.xslt)</notice>
      <notice type="27" location="/rsm:CrossIndustryInvoice/rsm:ExchangedDocumentContext[1]" criterion="ram:GuidelineSpecifiedDocumentContextParameter/ram:ID = $XR-CIUS-ID or ram:GuidelineSpecifiedDocumentContextParameter/ram:ID = $XR-EXTENSION-ID">[BR-DE-21] Das Element "Specification identifier" (BT-24) soll syntaktisch der Kennung des Standards XRechnung entsprechen. [ID BR-DE-21] from /xslt/XR_30/XRechnung-CII-validation.xslt)</notice>
    </messages>
    <summary status="invalid"/>
  </xml>
  <messages></messages>
  <summary status="invalid"/>
</validation>
  Mit Zitat antworten Zitat
DerMondistunsereSonne

Registriert seit: 9. Apr 2024
47 Beiträge
 
Delphi 12 Athens
 
#4

AW: Wie prüfen ob PDF ZUGFeRD enthält?

  Alt 14. Aug 2024, 12:56
Also wenn du es von Hand wissen möchtest, dann kannst du das in der PDF ansehen, siehe Bild. Und ich gehe mal davon aus, dass auch jemand da eine Variante für Delphi hat.

Die XML zu Validieren ist leider nicht einfach. Dafür gibt es allerdings genügend Seiten, die so etwas anbieten. Wie gut das Ergebnis ist, kann ich nicht beurteilen.
Angehängte Grafiken
Dateityp: jpg 2024-08-14 13_50_13-Window.jpg (22,3 KB, 40x aufgerufen)
  Mit Zitat antworten Zitat
Rollo62

Registriert seit: 15. Mär 2007
4.166 Beiträge
 
Delphi 12 Athens
 
#5

AW: Wie prüfen ob PDF ZUGFeRD enthält?

  Alt 14. Aug 2024, 13:51
Es geht doch darum ein einfaches, verlässliches Format zu haben.
Wie eben PDF, das ist sowas von Standard, dass es mittlerweile überall problemlos läuft.
Das sollte doch mit genauso einem verlässlichem XML gepaart werden, wofür es dann auch auf tausenden System in gleicher Weise einen Viewer gewen sollte um das zu checken.

PDF läuft perfekt, XML anscheinend noch nicht.
Dabei hätte ich eigentlich bei dem strukturierten XML weniger Probleme erwartet einen Viewer zu finden,
als bei der proprietären PDF.

Das Argument kann ja nicht sein, dass ich solange einen passenden Viewer suchen muss, bis die Daten stimmen.
Das ZugFErD XML sollte in "irgendeinen" Viewer geworfen werden können, und BÄM ... fertig.

Vielleicht denke ich mal wieder zu einfach ... aber ist es nicht genau das, was Millionen Firmen und Kunden demnächst machen müssten, um die Validität einer Rechnung prüfen zu können?

Das kann doch nicht sein, dass dies nur innerhalb von komplexen B2B System funktionieren mag, aber der einfache Bürger mit seiner Telekom, 1&1 und Handwerkerrechnung dies nicht auf simpelste Weise prüfen kann.
Seltsam, ich hatte mal wieder mehr erwartet
  Mit Zitat antworten Zitat
DerMondistunsereSonne

Registriert seit: 9. Apr 2024
47 Beiträge
 
Delphi 12 Athens
 
#6

AW: Wie prüfen ob PDF ZUGFeRD enthält?

  Alt 14. Aug 2024, 13:59
Du kannst auch die XML in irgendeinen Viewer werfen und es dir ansehen. Das ist dann so, als ob du dir Autos auf der Strasse anschaust, die Farbe und Marke etc kannst du erkennen.

Die Validierung ob die Reifen eingetragen sind, muss man schon mit dem Fahrzeugschein und so weiter machen. Und das ist bei der ERechnung genauso, die XRechnung ist sogar noch aufwändiger.
  Mit Zitat antworten Zitat
Rollo62

Registriert seit: 15. Mär 2007
4.166 Beiträge
 
Delphi 12 Athens
 
#7

AW: Wie prüfen ob PDF ZUGFeRD enthält?

  Alt 14. Aug 2024, 14:14
Was ich meine ist, dass so eine Standard-XML doch in einem Standard-Viewer für Normalsterbliche lesbar gemacht werden sollte.
Die meisten Rechnungen haben halt keine Super-Sonder-Verknüppelung, sondern Lieferant, Kunde, Produktliste/Anzahl, Rechnungsdatum/Id, Summe, VAT, Endbetrag, Zahlungsziel, usw.

Das ist doch überschaubar genug für einen Standardviewer, um zumindest die Basics auszulesen, oder sehe ich das zu einfach?

Bei komplexerem Zeugs kann er sich ja ausklinken, es sollte aber mit den einfachen Muster-PDF der ZugFeRD Leute selber funktionieren.
  Mit Zitat antworten Zitat
Antwort Antwort

Themen-Optionen Thema durchsuchen
Thema durchsuchen:

Erweiterte Suche
Ansicht

Forumregeln

Es ist dir nicht erlaubt, neue Themen zu verfassen.
Es ist dir nicht erlaubt, auf Beiträge zu antworten.
Es ist dir nicht erlaubt, Anhänge hochzuladen.
Es ist dir nicht erlaubt, deine Beiträge zu bearbeiten.

BB-Code ist an.
Smileys sind an.
[IMG] Code ist an.
HTML-Code ist aus.
Trackbacks are an
Pingbacks are an
Refbacks are aus

Gehe zu:

Impressum · AGB · Datenschutz · Nach oben
Alle Zeitangaben in WEZ +1. Es ist jetzt 00:19 Uhr.
Powered by vBulletin® Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024-2025 by Thomas Breitkreuz