public class com.coverity.security.Filter
minor version: 0
major version: 59
flags: flags: (0x0021) ACC_PUBLIC, ACC_SUPER
this_class: com.coverity.security.Filter
super_class: java.lang.Object
{
private static final java.util.regex.Pattern OCTAL_REGEX;
descriptor: Ljava/util/regex/Pattern;
flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
private static final java.util.regex.Pattern NUMBER_REGEX;
descriptor: Ljava/util/regex/Pattern;
flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
private static final java.util.regex.Pattern HEX_REGEX;
descriptor: Ljava/util/regex/Pattern;
flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
private static final java.util.regex.Pattern CSS_HEX_COLOR_REGEX;
descriptor: Ljava/util/regex/Pattern;
flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
private static final java.util.regex.Pattern CSS_NAMED_COLOR_REGEX;
descriptor: Ljava/util/regex/Pattern;
flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
private static final java.util.regex.Pattern URL_REGEX;
descriptor: Ljava/util/regex/Pattern;
flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
private static final java.util.regex.Pattern SCHEME_REGEX;
descriptor: Ljava/util/regex/Pattern;
flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
static void <clinit>();
descriptor: ()V
flags: (0x0008) ACC_STATIC
Code:
stack=2, locals=0, args_size=0
0: ldc "(0+)([0-7]*)"
invokestatic java.util.regex.Pattern.compile:(Ljava/lang/String;)Ljava/util/regex/Pattern;
putstatic com.coverity.security.Filter.OCTAL_REGEX:Ljava/util/regex/Pattern;
1: ldc "[-+]?((\\.[0-9]+)|([0-9]+\\.?[0-9]*))"
invokestatic java.util.regex.Pattern.compile:(Ljava/lang/String;)Ljava/util/regex/Pattern;
putstatic com.coverity.security.Filter.NUMBER_REGEX:Ljava/util/regex/Pattern;
2: ldc "0x[0-9a-fA-F]+"
invokestatic java.util.regex.Pattern.compile:(Ljava/lang/String;)Ljava/util/regex/Pattern;
putstatic com.coverity.security.Filter.HEX_REGEX:Ljava/util/regex/Pattern;
3: ldc "#[0-9a-fA-F]{3}([0-9a-fA-F]{3})?"
invokestatic java.util.regex.Pattern.compile:(Ljava/lang/String;)Ljava/util/regex/Pattern;
putstatic com.coverity.security.Filter.CSS_HEX_COLOR_REGEX:Ljava/util/regex/Pattern;
4: ldc "[a-zA-Z]{1,20}"
invokestatic java.util.regex.Pattern.compile:(Ljava/lang/String;)Ljava/util/regex/Pattern;
putstatic com.coverity.security.Filter.CSS_NAMED_COLOR_REGEX:Ljava/util/regex/Pattern;
5: ldc "(/|\\\\\\\\|https?:|ftp:|mailto:).*"
iconst_2
invokestatic java.util.regex.Pattern.compile:(Ljava/lang/String;I)Ljava/util/regex/Pattern;
putstatic com.coverity.security.Filter.URL_REGEX:Ljava/util/regex/Pattern;
6: ldc "(javascript|vbscript|data|about)"
invokestatic java.util.regex.Pattern.compile:(Ljava/lang/String;)Ljava/util/regex/Pattern;
putstatic com.coverity.security.Filter.SCHEME_REGEX:Ljava/util/regex/Pattern;
return
LocalVariableTable:
Start End Slot Name Signature
public void <init>();
descriptor: ()V
flags: (0x0001) ACC_PUBLIC
Code:
stack=1, locals=1, args_size=1
start local 0 0: aload 0
invokespecial java.lang.Object.<init>:()V
return
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lcom/coverity/security/Filter;
public static java.lang.String asNumber(java.lang.String);
descriptor: (Ljava/lang/String;)Ljava/lang/String;
flags: (0x0009) ACC_PUBLIC, ACC_STATIC
Code:
stack=2, locals=1, args_size=1
start local 0 0: aload 0
ldc "0"
invokestatic com.coverity.security.Filter.asNumber:(Ljava/lang/String;Ljava/lang/String;)Ljava/lang/String;
areturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 number Ljava/lang/String;
MethodParameters:
Name Flags
number
public static java.lang.String asNumber(java.lang.String, java.lang.String);
descriptor: (Ljava/lang/String;Ljava/lang/String;)Ljava/lang/String;
flags: (0x0009) ACC_PUBLIC, ACC_STATIC
Code:
stack=2, locals=4, args_size=2
start local 0 start local 1 0: aload 0
ifnonnull 2
1: aconst_null
areturn
2: StackMap locals:
StackMap stack:
aload 0
invokevirtual java.lang.String.trim:()Ljava/lang/String;
astore 2
start local 2 3: getstatic com.coverity.security.Filter.OCTAL_REGEX:Ljava/util/regex/Pattern;
aload 2
invokevirtual java.util.regex.Pattern.matcher:(Ljava/lang/CharSequence;)Ljava/util/regex/Matcher;
astore 3
start local 3 4: aload 3
invokevirtual java.util.regex.Matcher.matches:()Z
ifeq 6
5: aload 3
iconst_2
invokevirtual java.util.regex.Matcher.group:(I)Ljava/lang/String;
areturn
6: StackMap locals: java.lang.String java.util.regex.Matcher
StackMap stack:
getstatic com.coverity.security.Filter.NUMBER_REGEX:Ljava/util/regex/Pattern;
aload 2
invokevirtual java.util.regex.Pattern.matcher:(Ljava/lang/CharSequence;)Ljava/util/regex/Matcher;
invokevirtual java.util.regex.Matcher.matches:()Z
ifeq 8
7: aload 2
areturn
8: StackMap locals:
StackMap stack:
getstatic com.coverity.security.Filter.HEX_REGEX:Ljava/util/regex/Pattern;
aload 2
invokevirtual java.util.regex.Pattern.matcher:(Ljava/lang/CharSequence;)Ljava/util/regex/Matcher;
invokevirtual java.util.regex.Matcher.matches:()Z
ifeq 10
9: aload 2
areturn
10: StackMap locals:
StackMap stack:
aload 1
areturn
end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 11 0 number Ljava/lang/String;
0 11 1 defaultNumber Ljava/lang/String;
3 11 2 trimNumber Ljava/lang/String;
4 11 3 octal Ljava/util/regex/Matcher;
MethodParameters:
Name Flags
number
defaultNumber
public static java.lang.String asCssColor(java.lang.String);
descriptor: (Ljava/lang/String;)Ljava/lang/String;
flags: (0x0009) ACC_PUBLIC, ACC_STATIC
Code:
stack=2, locals=1, args_size=1
start local 0 0: aload 0
ldc "invalid"
invokestatic com.coverity.security.Filter.asCssColor:(Ljava/lang/String;Ljava/lang/String;)Ljava/lang/String;
areturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 color Ljava/lang/String;
MethodParameters:
Name Flags
color
public static java.lang.String asCssColor(java.lang.String, java.lang.String);
descriptor: (Ljava/lang/String;Ljava/lang/String;)Ljava/lang/String;
flags: (0x0009) ACC_PUBLIC, ACC_STATIC
Code:
stack=2, locals=2, args_size=2
start local 0 start local 1 0: aload 0
ifnonnull 2
1: aconst_null
areturn
2: StackMap locals:
StackMap stack:
getstatic com.coverity.security.Filter.CSS_HEX_COLOR_REGEX:Ljava/util/regex/Pattern;
aload 0
invokevirtual java.util.regex.Pattern.matcher:(Ljava/lang/CharSequence;)Ljava/util/regex/Matcher;
invokevirtual java.util.regex.Matcher.matches:()Z
ifeq 4
3: aload 0
areturn
4: StackMap locals:
StackMap stack:
getstatic com.coverity.security.Filter.CSS_NAMED_COLOR_REGEX:Ljava/util/regex/Pattern;
aload 0
invokevirtual java.util.regex.Pattern.matcher:(Ljava/lang/CharSequence;)Ljava/util/regex/Matcher;
invokevirtual java.util.regex.Matcher.matches:()Z
ifeq 6
5: aload 0
areturn
6: StackMap locals:
StackMap stack:
aload 1
areturn
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 7 0 color Ljava/lang/String;
0 7 1 defaultColor Ljava/lang/String;
MethodParameters:
Name Flags
color
defaultColor
public static java.lang.String asURL(java.lang.String);
descriptor: (Ljava/lang/String;)Ljava/lang/String;
flags: (0x0009) ACC_PUBLIC, ACC_STATIC
Code:
stack=3, locals=1, args_size=1
start local 0 0: aload 0
ifnonnull 2
1: aconst_null
areturn
2: StackMap locals:
StackMap stack:
aload 0
invokevirtual java.lang.String.length:()I
ifne 4
3: aload 0
areturn
4: StackMap locals:
StackMap stack:
getstatic com.coverity.security.Filter.URL_REGEX:Ljava/util/regex/Pattern;
aload 0
invokevirtual java.util.regex.Pattern.matcher:(Ljava/lang/CharSequence;)Ljava/util/regex/Matcher;
invokevirtual java.util.regex.Matcher.matches:()Z
ifeq 6
5: aload 0
areturn
6: StackMap locals:
StackMap stack:
new java.lang.StringBuilder
dup
ldc "./"
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
aload 0
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
areturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 7 0 url Ljava/lang/String;
MethodParameters:
Name Flags
url
public static java.lang.String asFlexibleURL(java.lang.String);
descriptor: (Ljava/lang/String;)Ljava/lang/String;
flags: (0x0009) ACC_PUBLIC, ACC_STATIC
Code:
stack=3, locals=4, args_size=1
start local 0 0: aload 0
ifnonnull 2
1: aconst_null
areturn
2: StackMap locals:
StackMap stack:
iconst_0
istore 1
start local 1 3: aload 0
invokevirtual java.lang.String.length:()I
istore 2
start local 2 4: aload 0
ldc "/"
invokevirtual java.lang.String.startsWith:(Ljava/lang/String;)Z
ifeq 6
5: aload 0
areturn
6: StackMap locals: int int
StackMap stack:
aload 0
ldc "\\\\"
invokevirtual java.lang.String.startsWith:(Ljava/lang/String;)Z
ifeq 16
7: aload 0
areturn
8: StackMap locals:
StackMap stack:
aload 0
iload 1
invokevirtual java.lang.String.charAt:(I)C
istore 3
start local 3 9: iload 3
bipush 97
if_icmplt 10
iload 3
bipush 122
if_icmple 15
StackMap locals: int
StackMap stack:
10: iload 3
bipush 65
if_icmplt 11
iload 3
bipush 90
if_icmple 15
11: StackMap locals:
StackMap stack:
iload 3
bipush 48
if_icmplt 12
iload 3
bipush 57
if_icmple 15
StackMap locals:
StackMap stack:
12: iload 3
bipush 46
if_icmpeq 15
iload 3
bipush 43
if_icmpeq 15
13: iload 3
bipush 45
if_icmpeq 15
14: goto 17
end local 3 15: StackMap locals:
StackMap stack:
iinc 1 1
StackMap locals:
StackMap stack:
16: iload 1
iload 2
if_icmplt 8
17: StackMap locals:
StackMap stack:
iload 1
iload 2
if_icmpne 19
18: aload 0
areturn
19: StackMap locals:
StackMap stack:
aload 0
iload 1
invokevirtual java.lang.String.charAt:(I)C
bipush 58
if_icmpne 21
aload 0
iconst_0
iload 1
invokevirtual java.lang.String.substring:(II)Ljava/lang/String;
invokevirtual java.lang.String.toLowerCase:()Ljava/lang/String;
invokestatic com.coverity.security.Filter.validateScheme:(Ljava/lang/String;)Z
ifeq 21
20: aload 0
areturn
21: StackMap locals:
StackMap stack:
new java.lang.StringBuilder
dup
ldc "./"
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
aload 0
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
areturn
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 22 0 url Ljava/lang/String;
3 22 1 i I
4 22 2 length I
9 15 3 c C
MethodParameters:
Name Flags
url
private static boolean validateScheme(java.lang.String);
descriptor: (Ljava/lang/String;)Z
flags: (0x000a) ACC_PRIVATE, ACC_STATIC
Code:
stack=2, locals=1, args_size=1
start local 0 0: getstatic com.coverity.security.Filter.SCHEME_REGEX:Ljava/util/regex/Pattern;
aload 0
invokevirtual java.util.regex.Pattern.matcher:(Ljava/lang/CharSequence;)Ljava/util/regex/Matcher;
invokevirtual java.util.regex.Matcher.matches:()Z
ifeq 1
iconst_0
goto 2
StackMap locals:
StackMap stack:
1: iconst_1
StackMap locals:
StackMap stack: int
2: ireturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 3 0 scheme Ljava/lang/String;
MethodParameters:
Name Flags
scheme
}
SourceFile: "Filter.java"