Commit 973ebe7b authored by God Ly's avatar God Ly Committed by it2000

Fix to avoid throwing multiple exceptions.

git-svn-id: http://svn.igniterealtime.org/svn/repos/openfire/trunk@13997 b35dd754-fafc-0310-a699-88a17e54d16e
parent ad8fe4b5
...@@ -159,6 +159,7 @@ class XMLLightweightParser { ...@@ -159,6 +159,7 @@ class XMLLightweightParser {
// Add message to the complete message list // Add message to the complete message list
if (msg != null) { if (msg != null) {
if (hasIllegalCharacterReferences(msg)) { if (hasIllegalCharacterReferences(msg)) {
buffer = null;
throw new XMLNotWellFormedException("Illegal character reference found in: " + msg); throw new XMLNotWellFormedException("Illegal character reference found in: " + msg);
} }
msgs.add(msg); msgs.add(msg);
...@@ -177,17 +178,27 @@ class XMLLightweightParser { ...@@ -177,17 +178,27 @@ class XMLLightweightParser {
* Main reading method * Main reading method
*/ */
public void read(ByteBuffer byteBuffer) throws Exception { public void read(ByteBuffer byteBuffer) throws Exception {
if (buffer == null) {
// exception was thrown before, avoid duplicate exception(s)
// "read" and discard remaining data
byteBuffer.position(byteBuffer.limit());
return;
}
invalidateBuffer(); invalidateBuffer();
// Check that the buffer is not bigger than 1 Megabyte. For security reasons // Check that the buffer is not bigger than 1 Megabyte. For security reasons
// we will abort parsing when 1 Mega of queued chars was found. // we will abort parsing when 1 Mega of queued chars was found.
if (buffer.length() > maxBufferSize) { if (buffer.length() > maxBufferSize) {
// purge the local buffer / free memory
buffer = null;
// processing the exception takes quite long
throw new Exception("Stopped parsing never ending stanza"); throw new Exception("Stopped parsing never ending stanza");
} }
CharBuffer charBuffer = CharBuffer.allocate(byteBuffer.capacity()); CharBuffer charBuffer = CharBuffer.allocate(byteBuffer.capacity());
encoder.reset(); encoder.reset();
encoder.decode(byteBuffer.buf(), charBuffer, false); encoder.decode(byteBuffer.buf(), charBuffer, false);
char[] buf = new char[charBuffer.position()]; char[] buf = new char[charBuffer.position()];
charBuffer.flip();charBuffer.get(buf); charBuffer.flip();
charBuffer.get(buf);
int readChar = buf.length; int readChar = buf.length;
// Just return if nothing was read // Just return if nothing was read
...@@ -205,6 +216,7 @@ class XMLLightweightParser { ...@@ -205,6 +216,7 @@ class XMLLightweightParser {
if (ch < 0x20 && ch != 0x9 && ch != 0xA && ch != 0xD && ch != 0x0) { if (ch < 0x20 && ch != 0x9 && ch != 0xA && ch != 0xD && ch != 0x0) {
//Unicode characters in the range 0x0000-0x001F other than 9, A, and D are not allowed in XML //Unicode characters in the range 0x0000-0x001F other than 9, A, and D are not allowed in XML
//We need to allow the NULL character, however, for Flash XMLSocket clients to work. //We need to allow the NULL character, however, for Flash XMLSocket clients to work.
buffer = null;
throw new XMLNotWellFormedException("Character is invalid in: " + ch); throw new XMLNotWellFormedException("Character is invalid in: " + ch);
} }
if (isHighSurrogate) { if (isHighSurrogate) {
...@@ -214,6 +226,7 @@ class XMLLightweightParser { ...@@ -214,6 +226,7 @@ class XMLLightweightParser {
} }
else { else {
// Trigger error. Found high surrogate not followed by low surrogate // Trigger error. Found high surrogate not followed by low surrogate
buffer = null;
throw new Exception("Found high surrogate not followed by low surrogate"); throw new Exception("Found high surrogate not followed by low surrogate");
} }
} }
...@@ -222,6 +235,7 @@ class XMLLightweightParser { ...@@ -222,6 +235,7 @@ class XMLLightweightParser {
} }
else if (Character.isLowSurrogate(ch)) { else if (Character.isLowSurrogate(ch)) {
// Trigger error. Found low surrogate char without a preceding high surrogate // Trigger error. Found low surrogate char without a preceding high surrogate
buffer = null;
throw new Exception("Found low surrogate char without a preceding high surrogate"); throw new Exception("Found low surrogate char without a preceding high surrogate");
} }
if (status == XMLLightweightParser.TAIL) { if (status == XMLLightweightParser.TAIL) {
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment