You are viewing a plain text version of this content. The canonical link for it is here.
Posted to commits@pdfbox.apache.org by ti...@apache.org on 2016/02/29 19:53:00 UTC

svn commit: r1732933 - /pdfbox/branches/1.8/xmpbox/src/main/java/org/apache/xmpbox/xml/DomXmpParser.java

Author: tilman
Date: Mon Feb 29 18:53:00 2016
New Revision: 1732933

URL: http://svn.apache.org/viewvc?rev=1732933&view=rev
Log:
PDFBOX-3254: avoid StringIndexOutOfBoundsException, improve msg

Modified:
    pdfbox/branches/1.8/xmpbox/src/main/java/org/apache/xmpbox/xml/DomXmpParser.java

Modified: pdfbox/branches/1.8/xmpbox/src/main/java/org/apache/xmpbox/xml/DomXmpParser.java
URL: http://svn.apache.org/viewvc/pdfbox/branches/1.8/xmpbox/src/main/java/org/apache/xmpbox/xml/DomXmpParser.java?rev=1732933&r1=1732932&r2=1732933&view=diff
==============================================================================
--- pdfbox/branches/1.8/xmpbox/src/main/java/org/apache/xmpbox/xml/DomXmpParser.java (original)
+++ pdfbox/branches/1.8/xmpbox/src/main/java/org/apache/xmpbox/xml/DomXmpParser.java Mon Feb 29 18:53:00 2016
@@ -605,16 +605,21 @@ public class DomXmpParser
             if (!token.endsWith("\"") && !token.endsWith("\'"))
             {
                 throw new XmpParsingException(ErrorType.XpacketBadStart, "Cannot understand PI data part : '" + token
-                        + "'");
+                        + "' in '" + data + "'");
             }
             String quote = token.substring(token.length() - 1);
             int pos = token.indexOf("=" + quote);
             if (pos <= 0)
             {
                 throw new XmpParsingException(ErrorType.XpacketBadStart, "Cannot understand PI data part : '" + token
-                        + "'");
+                        + "' in '" + data + "'");
             }
             String name = token.substring(0, pos);
+            if (token.length() - 1 < pos + 2)
+            {
+                throw new XmpParsingException(ErrorType.XpacketBadStart, "Cannot understand PI data part : '" + token
+                        + "' in '" + data + "'");
+            }
             String value = token.substring(pos + 2, token.length() - 1);
             if ("id".equals(name))
             {