Skip to content

Latest commit

 

History

History
38 lines (29 loc) · 1.05 KB

README.md

File metadata and controls

38 lines (29 loc) · 1.05 KB

PBEWithMD5AndDES implementation using golang

Golang implementation:

func main() {
	salt := []byte{0xFF, 0x2B, 0x38, 0x30, 0xF8, 0x61, 0xEF, 0x99}
	password := "my_secret_password"
	iterations := 222
	originalText := "mythings"

	res, err := Encrypt(password, iterations, originalText, salt)
	fmt.Println("encrypted", res, err)
	res, err = Decrypt(password, iterations, res, salt)
	fmt.Println("decrypted", res, err)
}

Java equivalence:

keySpec = new PBEKeySpec(password.toCharArray(), salt, iterations);
key = SecretKeyFactory.getInstance("PBEWithMD5AndDES").generateSecret(keySpec);
ecipher = Cipher.getInstance(key.getAlgorithm());
dcipher = Cipher.getInstance(key.getAlgorithm());
ecipher.init(Cipher.ENCRYPT_MODE, key, paramSpec);
dcipher.init(Cipher.DECRYPT_MODE, key, paramSpec);

byte[] enc = ecipher.doFinal(originalText);
String res = Base64.getEncoder().encodeToString(enc);
System.out.println("encrypted " + res);

byte[] dec = Base64.getDecoder().decode(res);
dec = dcipher.doFinal(dec);
System.out.println("decrypted " + dec);