-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathWeakCryptographicImpl.java
More file actions
58 lines (47 loc) · 2.2 KB
/
WeakCryptographicImpl.java
File metadata and controls
58 lines (47 loc) · 2.2 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
47
48
49
50
51
52
53
54
55
56
57
58
package random;
import java.security.*;
import java.security.spec.ECGenParameterSpec;
public class WeakCryptographicImpl {
// Weakness: No validation of the algorithm's usage context or key management
private static final String SIGNING_ALGORITHM = "SHA256withECDSA";
public static void main(String[] args) {
try {
// Generate an ECDSA key pair
KeyPairGenerator keyPairGenerator = KeyPairGenerator.getInstance("EC");
keyPairGenerator.initialize(new ECGenParameterSpec("secp256r1")); // Using standard curve
KeyPair keyPair = keyPairGenerator.generateKeyPair();
// Sample data to sign
String data = "Sensitive data to be signed";
// Generate a signature
byte[] signature = generateSignature(data, keyPair.getPrivate());
System.out.println("Generated Signature: " + bytesToHex(signature));
// Verify the signature
boolean isVerified = verifySignature(data, signature, keyPair.getPublic());
System.out.println("Signature Verified: " + isVerified);
} catch (Exception e) {
e.printStackTrace();
}
}
public static byte[] generateSignature(String data, PrivateKey privateKey) throws Exception {
Signature signature = Signature.getInstance(SIGNING_ALGORITHM);
// Potential Issue: Missing secure random or other customizations
signature.initSign(privateKey);
signature.update(data.getBytes());
return signature.sign();
}
public static boolean verifySignature(String data, byte[] signatureBytes, PublicKey publicKey) throws Exception {
Signature verifier = Signature.getInstance(SIGNING_ALGORITHM);
// Verification of algorithm left to default implementation
verifier.initVerify(publicKey);
verifier.update(data.getBytes());
return verifier.verify(signatureBytes);
}
// Utility function to convert bytes to hex (for printing)
public static String bytesToHex(byte[] bytes) {
StringBuilder sb = new StringBuilder();
for (byte b : bytes) {
sb.append(String.format("%02x", b));
}
return sb.toString();
}
}