Skip to content
Open
Show file tree
Hide file tree
Changes from 1 commit
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
14 changes: 13 additions & 1 deletion src/main/java/org/owasp/html/HtmlLexer.java
Original file line number Diff line number Diff line change
Expand Up @@ -476,6 +476,7 @@ private static enum State {
COMMENT,
COMMENT_DASH,
COMMENT_DASH_DASH,
COMMENT_DASH_AFTER_BANG,
DIRECTIVE,
DONE,
BOGUS_COMMENT,
Expand Down Expand Up @@ -640,17 +641,28 @@ && canonicalElementName(start + 2, end)
case BANG:
if ('-' == ch) {
state = State.BANG_DASH;
} else if('>' == ch) { // <!> is a valid html comment
state = State.DONE;
type = HtmlTokenType.COMMENT;
} else {
state = State.DIRECTIVE;
}
break;
case BANG_DASH:
if ('-' == ch) {
state = State.COMMENT;
state = State.COMMENT_DASH_AFTER_BANG;
} else {
state = State.DIRECTIVE;
}
break;
case COMMENT_DASH_AFTER_BANG:
if ('>' == ch) { // <!--> is a valid html comment
state = State.DONE;
type = HtmlTokenType.COMMENT;
}else{
state = State.COMMENT;
}
break;
case COMMENT:
if ('-' == ch) {
state = State.COMMENT_DASH;
Expand Down
25 changes: 25 additions & 0 deletions src/test/java/org/owasp/html/HtmlLexerTest.java
Original file line number Diff line number Diff line change
Expand Up @@ -121,6 +121,31 @@ public static final void testShortTags() {
"TAGEND: >");
}

@Test
public static final void testCommentDeclarationWith0CommentsAndXss() throws Exception
{
//check https://datatracker.ietf.org/doc/html/rfc1866#section-3.2.5
assertTokens("<!><img src=1 onError=alert(\"nice\")>",
"COMMENT: <!>",
"TAGBEGIN: <img",
"ATTRNAME: src",
"ATTRVALUE: 1",
"ATTRNAME: onError",
"ATTRVALUE: alert(\"nice\")",
"TAGEND: >"
);
}

@Test
public static final void testCommentDeclarationWith0CommentsAndTag() throws Exception
{
assertTokens("<!--><img>",
"COMMENT: <!-->",
"TAGBEGIN: <img",
"TAGEND: >"
);
}

private static void lex(String input, Appendable out) throws Exception {
HtmlLexer lexer = new HtmlLexer(input);
int maxTypeLength = 0;
Expand Down