blob: 498371ad483c393cf925d36f286cf8a38f61ae9d (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
|
package org.spongycastle.crypto.params;
public class DESedeParameters
extends DESParameters
{
/*
* DES-EDE Key length in bytes.
*/
static public final int DES_EDE_KEY_LENGTH = 24;
public DESedeParameters(
byte[] key)
{
super(key);
if (isWeakKey(key, 0, key.length))
{
throw new IllegalArgumentException("attempt to create weak DESede key");
}
}
/**
* return true if the passed in key is a DES-EDE weak key.
*
* @param key bytes making up the key
* @param offset offset into the byte array the key starts at
* @param length number of bytes making up the key
*/
public static boolean isWeakKey(
byte[] key,
int offset,
int length)
{
for (int i = offset; i < length; i += DES_KEY_LENGTH)
{
if (DESParameters.isWeakKey(key, i))
{
return true;
}
}
return false;
}
/**
* return true if the passed in key is a DES-EDE weak key.
*
* @param key bytes making up the key
* @param offset offset into the byte array the key starts at
*/
public static boolean isWeakKey(
byte[] key,
int offset)
{
return isWeakKey(key, offset, key.length - offset);
}
}
|