public class sun.security.krb5.internal.crypto.DesMacCksumType extends sun.security.krb5.internal.crypto.CksumType
minor version: 0
major version: 59
flags: flags: (0x0021) ACC_PUBLIC, ACC_SUPER
this_class: sun.security.krb5.internal.crypto.DesMacCksumType
super_class: sun.security.krb5.internal.crypto.CksumType
{
public void <init>();
descriptor: ()V
flags: (0x0001) ACC_PUBLIC
Code:
stack=1, locals=1, args_size=1
start local 0 0: aload 0
invokespecial sun.security.krb5.internal.crypto.CksumType.<init>:()V
1: return
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 2 0 this Lsun/security/krb5/internal/crypto/DesMacCksumType;
public int confounderSize();
descriptor: ()I
flags: (0x0001) ACC_PUBLIC
Code:
stack=1, locals=1, args_size=1
start local 0 0: bipush 8
ireturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lsun/security/krb5/internal/crypto/DesMacCksumType;
public int cksumType();
descriptor: ()I
flags: (0x0001) ACC_PUBLIC
Code:
stack=1, locals=1, args_size=1
start local 0 0: iconst_4
ireturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lsun/security/krb5/internal/crypto/DesMacCksumType;
public boolean isKeyed();
descriptor: ()Z
flags: (0x0001) ACC_PUBLIC
Code:
stack=1, locals=1, args_size=1
start local 0 0: iconst_1
ireturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lsun/security/krb5/internal/crypto/DesMacCksumType;
public int cksumSize();
descriptor: ()I
flags: (0x0001) ACC_PUBLIC
Code:
stack=1, locals=1, args_size=1
start local 0 0: bipush 16
ireturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lsun/security/krb5/internal/crypto/DesMacCksumType;
public int keyType();
descriptor: ()I
flags: (0x0001) ACC_PUBLIC
Code:
stack=1, locals=1, args_size=1
start local 0 0: iconst_1
ireturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lsun/security/krb5/internal/crypto/DesMacCksumType;
public int keySize();
descriptor: ()I
flags: (0x0001) ACC_PUBLIC
Code:
stack=1, locals=1, args_size=1
start local 0 0: bipush 8
ireturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lsun/security/krb5/internal/crypto/DesMacCksumType;
public byte[] calculateChecksum(byte[], int, byte[], int);
descriptor: ([BI[BI)[B
flags: (0x0001) ACC_PUBLIC
Code:
stack=6, locals=13, args_size=5
start local 0 start local 1 start local 2 start local 3 start local 4 0: iload 2
aload 0
invokevirtual sun.security.krb5.internal.crypto.DesMacCksumType.confounderSize:()I
iadd
newarray 8
astore 5
start local 5 1: aload 0
invokevirtual sun.security.krb5.internal.crypto.DesMacCksumType.confounderSize:()I
invokestatic sun.security.krb5.Confounder.bytes:(I)[B
astore 6
start local 6 2: aload 6
iconst_0
aload 5
iconst_0
aload 0
invokevirtual sun.security.krb5.internal.crypto.DesMacCksumType.confounderSize:()I
invokestatic java.lang.System.arraycopy:(Ljava/lang/Object;ILjava/lang/Object;II)V
3: aload 1
iconst_0
aload 5
aload 0
invokevirtual sun.security.krb5.internal.crypto.DesMacCksumType.confounderSize:()I
iload 2
invokestatic java.lang.System.arraycopy:(Ljava/lang/Object;ILjava/lang/Object;II)V
4: aload 3
iconst_0
invokestatic javax.crypto.spec.DESKeySpec.isWeak:([BI)Z
ifeq 8
5: aload 3
bipush 7
aload 3
bipush 7
baload
sipush 240
ixor
i2b
bastore
6: goto 8
StackMap locals: sun.security.krb5.internal.crypto.DesMacCksumType byte[] int byte[] int byte[] byte[]
StackMap stack: java.security.InvalidKeyException
7: pop
8: StackMap locals:
StackMap stack:
aload 3
arraylength
newarray 8
astore 7
start local 7 9: aload 7
aload 5
aload 3
invokestatic sun.security.krb5.internal.crypto.Des.des_cksum:([B[B[B)[B
astore 8
start local 8 10: aload 0
invokevirtual sun.security.krb5.internal.crypto.DesMacCksumType.cksumSize:()I
newarray 8
astore 9
start local 9 11: aload 6
iconst_0
aload 9
iconst_0
aload 0
invokevirtual sun.security.krb5.internal.crypto.DesMacCksumType.confounderSize:()I
invokestatic java.lang.System.arraycopy:(Ljava/lang/Object;ILjava/lang/Object;II)V
12: aload 8
iconst_0
aload 9
aload 0
invokevirtual sun.security.krb5.internal.crypto.DesMacCksumType.confounderSize:()I
13: aload 0
invokevirtual sun.security.krb5.internal.crypto.DesMacCksumType.cksumSize:()I
aload 0
invokevirtual sun.security.krb5.internal.crypto.DesMacCksumType.confounderSize:()I
isub
14: invokestatic java.lang.System.arraycopy:(Ljava/lang/Object;ILjava/lang/Object;II)V
15: aload 0
invokevirtual sun.security.krb5.internal.crypto.DesMacCksumType.keySize:()I
newarray 8
astore 10
start local 10 16: aload 3
iconst_0
aload 10
iconst_0
aload 3
arraylength
invokestatic java.lang.System.arraycopy:(Ljava/lang/Object;ILjava/lang/Object;II)V
17: iconst_0
istore 11
start local 11 18: goto 21
19: StackMap locals: sun.security.krb5.internal.crypto.DesMacCksumType byte[] int byte[] int byte[] byte[] byte[] byte[] byte[] byte[] int
StackMap stack:
aload 10
iload 11
aload 10
iload 11
baload
sipush 240
ixor
i2b
bastore
20: iinc 11 1
StackMap locals:
StackMap stack:
21: iload 11
aload 10
arraylength
if_icmplt 19
end local 11 22: aload 10
iconst_0
invokestatic javax.crypto.spec.DESKeySpec.isWeak:([BI)Z
ifeq 26
23: aload 10
bipush 7
aload 10
bipush 7
baload
sipush 240
ixor
i2b
bastore
24: goto 26
StackMap locals: sun.security.krb5.internal.crypto.DesMacCksumType byte[] int byte[] int byte[] byte[] byte[] byte[] byte[] byte[]
StackMap stack: java.security.InvalidKeyException
25: pop
26: StackMap locals:
StackMap stack:
aload 10
arraylength
newarray 8
astore 11
start local 11 27: aload 9
arraylength
newarray 8
astore 12
start local 12 28: aload 9
aload 12
aload 10
aload 11
iconst_1
invokestatic sun.security.krb5.internal.crypto.Des.cbc_encrypt:([B[B[B[BZ)V
29: aload 12
areturn
end local 12 end local 11 end local 10 end local 9 end local 8 end local 7 end local 6 end local 5 end local 4 end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 30 0 this Lsun/security/krb5/internal/crypto/DesMacCksumType;
0 30 1 data [B
0 30 2 size I
0 30 3 key [B
0 30 4 usage I
1 30 5 new_data [B
2 30 6 conf [B
9 30 7 residue_ivec [B
10 30 8 residue [B
11 30 9 cksum [B
16 30 10 new_key [B
18 22 11 i I
27 30 11 ivec [B
28 30 12 enc_cksum [B
Exception table:
from to target type
4 6 7 Class java.security.InvalidKeyException
22 24 25 Class java.security.InvalidKeyException
Exceptions:
throws sun.security.krb5.KrbCryptoException
MethodParameters:
Name Flags
data
size
key
usage
public boolean verifyChecksum(byte[], int, byte[], byte[], int);
descriptor: ([BI[B[BI)Z
flags: (0x0001) ACC_PUBLIC
Code:
stack=6, locals=11, args_size=6
start local 0 start local 1 start local 2 start local 3 start local 4 start local 5 0: aload 0
aload 4
aload 3
invokevirtual sun.security.krb5.internal.crypto.DesMacCksumType.decryptKeyedChecksum:([B[B)[B
astore 6
start local 6 1: iload 2
aload 0
invokevirtual sun.security.krb5.internal.crypto.DesMacCksumType.confounderSize:()I
iadd
newarray 8
astore 7
start local 7 2: aload 6
iconst_0
aload 7
iconst_0
aload 0
invokevirtual sun.security.krb5.internal.crypto.DesMacCksumType.confounderSize:()I
invokestatic java.lang.System.arraycopy:(Ljava/lang/Object;ILjava/lang/Object;II)V
3: aload 1
iconst_0
aload 7
aload 0
invokevirtual sun.security.krb5.internal.crypto.DesMacCksumType.confounderSize:()I
iload 2
invokestatic java.lang.System.arraycopy:(Ljava/lang/Object;ILjava/lang/Object;II)V
4: aload 3
iconst_0
invokestatic javax.crypto.spec.DESKeySpec.isWeak:([BI)Z
ifeq 8
5: aload 3
bipush 7
aload 3
bipush 7
baload
sipush 240
ixor
i2b
bastore
6: goto 8
StackMap locals: sun.security.krb5.internal.crypto.DesMacCksumType byte[] int byte[] byte[] int byte[] byte[]
StackMap stack: java.security.InvalidKeyException
7: pop
8: StackMap locals:
StackMap stack:
aload 3
arraylength
newarray 8
astore 8
start local 8 9: aload 8
aload 7
aload 3
invokestatic sun.security.krb5.internal.crypto.Des.des_cksum:([B[B[B)[B
astore 9
start local 9 10: aload 0
invokevirtual sun.security.krb5.internal.crypto.DesMacCksumType.cksumSize:()I
aload 0
invokevirtual sun.security.krb5.internal.crypto.DesMacCksumType.confounderSize:()I
isub
newarray 8
astore 10
start local 10 11: aload 6
aload 0
invokevirtual sun.security.krb5.internal.crypto.DesMacCksumType.confounderSize:()I
aload 10
iconst_0
12: aload 0
invokevirtual sun.security.krb5.internal.crypto.DesMacCksumType.cksumSize:()I
aload 0
invokevirtual sun.security.krb5.internal.crypto.DesMacCksumType.confounderSize:()I
isub
13: invokestatic java.lang.System.arraycopy:(Ljava/lang/Object;ILjava/lang/Object;II)V
14: aload 10
aload 9
invokestatic sun.security.krb5.internal.crypto.DesMacCksumType.isChecksumEqual:([B[B)Z
ireturn
end local 10 end local 9 end local 8 end local 7 end local 6 end local 5 end local 4 end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 15 0 this Lsun/security/krb5/internal/crypto/DesMacCksumType;
0 15 1 data [B
0 15 2 size I
0 15 3 key [B
0 15 4 checksum [B
0 15 5 usage I
1 15 6 cksum [B
2 15 7 new_data [B
9 15 8 ivec [B
10 15 9 new_cksum [B
11 15 10 orig_cksum [B
Exception table:
from to target type
4 6 7 Class java.security.InvalidKeyException
Exceptions:
throws sun.security.krb5.KrbCryptoException
MethodParameters:
Name Flags
data
size
key
checksum
usage
private byte[] decryptKeyedChecksum(byte[], byte[]);
descriptor: ([B[B)[B
flags: (0x0002) ACC_PRIVATE
Code:
stack=5, locals=6, args_size=3
start local 0 start local 1 start local 2 0: aload 0
invokevirtual sun.security.krb5.internal.crypto.DesMacCksumType.keySize:()I
newarray 8
astore 3
start local 3 1: aload 2
iconst_0
aload 3
iconst_0
aload 2
arraylength
invokestatic java.lang.System.arraycopy:(Ljava/lang/Object;ILjava/lang/Object;II)V
2: iconst_0
istore 4
start local 4 3: goto 6
4: StackMap locals: byte[] int
StackMap stack:
aload 3
iload 4
aload 3
iload 4
baload
sipush 240
ixor
i2b
bastore
5: iinc 4 1
StackMap locals:
StackMap stack:
6: iload 4
aload 3
arraylength
if_icmplt 4
end local 4 7: aload 3
iconst_0
invokestatic javax.crypto.spec.DESKeySpec.isWeak:([BI)Z
ifeq 11
8: aload 3
bipush 7
aload 3
bipush 7
baload
sipush 240
ixor
i2b
bastore
9: goto 11
StackMap locals: sun.security.krb5.internal.crypto.DesMacCksumType byte[] byte[] byte[]
StackMap stack: java.security.InvalidKeyException
10: pop
11: StackMap locals:
StackMap stack:
aload 3
arraylength
newarray 8
astore 4
start local 4 12: aload 1
arraylength
newarray 8
astore 5
start local 5 13: aload 1
aload 5
aload 3
aload 4
iconst_0
invokestatic sun.security.krb5.internal.crypto.Des.cbc_encrypt:([B[B[B[BZ)V
14: aload 5
areturn
end local 5 end local 4 end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 15 0 this Lsun/security/krb5/internal/crypto/DesMacCksumType;
0 15 1 enc_cksum [B
0 15 2 key [B
1 15 3 new_key [B
3 7 4 i I
12 15 4 ivec [B
13 15 5 cksum [B
Exception table:
from to target type
7 9 10 Class java.security.InvalidKeyException
Exceptions:
throws sun.security.krb5.KrbCryptoException
MethodParameters:
Name Flags
enc_cksum
key
}
SourceFile: "DesMacCksumType.java"