You are viewing a plain text version of this content. The canonical link for it is here.
Posted to dev@poi.apache.org by "Daniel Hengst (Jira)" <ji...@apache.org> on 2022/02/10 11:01:00 UTC

[jira] [Created] (XMLBEANS-599) Line breaks in base64binary cause a validation error

Daniel Hengst created XMLBEANS-599:
--------------------------------------

             Summary: Line breaks in base64binary cause a validation error
                 Key: XMLBEANS-599
                 URL: https://issues.apache.org/jira/browse/XMLBEANS-599
             Project: XMLBeans
          Issue Type: Bug
    Affects Versions: Version 5.0.3
            Reporter: Daniel Hengst


When trying to migrate from XmlBeans 3.1.0 to 5.0.3 the following issue caused some unit tests to fail:
 
The XML data contains elements of type base64binary which have line breaks.
Validation via XmlObject.validate() now returns an error:
"error: base64Binary: Invalid value: not encoded properly".

The error originates from the class org.apache.xmlbeans.impl.values.JavaBase64Holder:
{code:java}
    public static byte[] lex(String v, ValidationContext c) {
        try {
            return Base64.getDecoder().decode(v);
        } catch (IllegalArgumentException var3) {
            c.invalid("base64Binary", new Object[]{"not encoded properly"});
            return null;
        }
    }
{code}
The decode call fails with an IllegalArgumentException "Illegal base64 character 20".
(It's character 20 because XmlBeans converts the line break to a space in XmlWhitespace.collapse().)

The definition of the base64binary type allows for the presence of whitespace
[https://www.w3.org/TR/xmlschema-2/#base64Binary]

Therefore I'd suggest to change the Base64 call as follows:
{code:java}
Base64.getMimeDecoder().decode(v);
{code}



--
This message was sent by Atlassian Jira
(v8.20.1#820001)

---------------------------------------------------------------------
To unsubscribe, e-mail: dev-unsubscribe@poi.apache.org
For additional commands, e-mail: dev-help@poi.apache.org