forked from dnsjava/dnsjava
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathDNSSECWithProviderTest.java
More file actions
46 lines (33 loc) · 1.21 KB
/
DNSSECWithProviderTest.java
File metadata and controls
46 lines (33 loc) · 1.21 KB
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
package org.xbill.DNS;
import java.security.KeyPair;
import java.security.KeyPairGenerator;
import java.security.Security;
import java.security.Signature;
import junit.framework.TestCase;
import org.xbill.DNS.DNSSEC.Algorithm;
public class DNSSECWithProviderTest extends TestCase {
private static final String SIGNATURE_ALGORITHM = "SHA1withRSA";
private static final String KEY_ALGORITHM = "RSA";
int algorithm = Algorithm.RSASHA1;
byte[] toSign = "The quick brown fox jumped over the lazy dog.".getBytes();
public void setUp() {
}
public void tearDown() {
}
public void testSignSoftware() throws Exception {
KeyPairGenerator keyPairGenerator = KeyPairGenerator.getInstance(KEY_ALGORITHM);
keyPairGenerator.initialize(512);
KeyPair keyPair = keyPairGenerator.generateKeyPair();
Signature signer = Signature.getInstance(SIGNATURE_ALGORITHM);
signer.initSign(keyPair.getPrivate());
signer.update(toSign);
byte[] signature = signer.sign();
assertNotNull(signature);
// verify the signature
Signature verifier = Signature.getInstance(SIGNATURE_ALGORITHM);
verifier.initVerify(keyPair.getPublic());
verifier.update(toSign);
boolean verify = verifier.verify(signature);
assertTrue(verify);
}
}