parent
16113779c5
commit
79301c650c
@ -15,15 +15,19 @@
|
|||||||
*/
|
*/
|
||||||
package org.jboss.netty.handler.codec.http.multipart;
|
package org.jboss.netty.handler.codec.http.multipart;
|
||||||
|
|
||||||
import java.nio.charset.Charset;
|
|
||||||
|
|
||||||
import org.jboss.netty.handler.codec.http.HttpConstants;
|
import org.jboss.netty.handler.codec.http.HttpConstants;
|
||||||
|
|
||||||
|
import java.nio.charset.Charset;
|
||||||
|
import java.util.regex.Pattern;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Abstract HttpData implementation
|
* Abstract HttpData implementation
|
||||||
*/
|
*/
|
||||||
public abstract class AbstractHttpData implements HttpData {
|
public abstract class AbstractHttpData implements HttpData {
|
||||||
|
|
||||||
|
private static final Pattern STRIP_PATTERN = Pattern.compile("(?:^\\s+|\\s+$|\\n)");
|
||||||
|
private static final Pattern REPLACE_PATTERN = Pattern.compile("[\\r\\t]");
|
||||||
|
|
||||||
protected final String name;
|
protected final String name;
|
||||||
protected long definedSize;
|
protected long definedSize;
|
||||||
protected long size;
|
protected long size;
|
||||||
@ -34,34 +38,14 @@ public abstract class AbstractHttpData implements HttpData {
|
|||||||
if (name == null) {
|
if (name == null) {
|
||||||
throw new NullPointerException("name");
|
throw new NullPointerException("name");
|
||||||
}
|
}
|
||||||
name = name.trim();
|
|
||||||
|
name = REPLACE_PATTERN.matcher(name).replaceAll(" ");
|
||||||
|
name = STRIP_PATTERN.matcher(name).replaceAll("");
|
||||||
|
|
||||||
if (name.length() == 0) {
|
if (name.length() == 0) {
|
||||||
throw new IllegalArgumentException("empty name");
|
throw new IllegalArgumentException("empty name");
|
||||||
}
|
}
|
||||||
|
|
||||||
for (int i = 0; i < name.length(); i ++) {
|
|
||||||
char c = name.charAt(i);
|
|
||||||
if (c > 127) {
|
|
||||||
throw new IllegalArgumentException(
|
|
||||||
"name contains non-ascii character: " + name);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Check prohibited characters.
|
|
||||||
switch (c) {
|
|
||||||
case '=':
|
|
||||||
case ',':
|
|
||||||
case ';':
|
|
||||||
case ' ':
|
|
||||||
case '\t':
|
|
||||||
case '\r':
|
|
||||||
case '\n':
|
|
||||||
case '\f':
|
|
||||||
case 0x0b: // Vertical tab
|
|
||||||
throw new IllegalArgumentException(
|
|
||||||
"name contains one of the following prohibited characters: " +
|
|
||||||
"=,; \\t\\r\\n\\v\\f: " + name);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
this.name = name;
|
this.name = name;
|
||||||
if (charset != null) {
|
if (charset != null) {
|
||||||
setCharset(charset);
|
setCharset(charset);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user