forked from kasundezoysa/javacrypto
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathSignatureExample.java
40 lines (29 loc) · 1.05 KB
/
SignatureExample.java
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
/*
Kasun De Zoysa @ UCSC
*/
import java.security.KeyPair;
import java.security.KeyPairGenerator;
import java.security.SecureRandom;
import java.security.Signature;
public class SignatureExample {
public static void main(String[] args)throws Exception {
KeyPairGenerator keyGen = KeyPairGenerator.getInstance("RSA");
keyGen.initialize(4048,new SecureRandom());
KeyPair keyPair = keyGen.generateKeyPair();
Signature signature = Signature.getInstance("SHA1withRSA");
// generate a signature
signature.initSign(keyPair.getPrivate());
String msg1="Hello Kasun How are you?";
signature.update(msg1.getBytes());
byte[] sigBytes = signature.sign();
// verify a signature
signature.initVerify(keyPair.getPublic());
String msg2="Hello Kasun How are you?";
signature.update(msg2.getBytes());
if (signature.verify(sigBytes)){
System.out.println("Signature verification succeeded.");
} else {
System.out.println("Signature verification failed.");
}
}
}