在Scala中使用AES加密/解密可以通过javax.crypto库来实现。下面是一个示例代码:
import javax.crypto.Cipher
import javax.crypto.spec.SecretKeySpec
import java.util.Base64
object AESExample extends App {
val secretKey = "mySecretKey"
val plainText = "Hello, World!"
def encrypt(text: String, secret: String): String = {
val secretKeySpec = new SecretKeySpec(secret.getBytes("UTF-8"), "AES")
val cipher = Cipher.getInstance("AES/ECB/PKCS5Padding")
cipher.init(Cipher.ENCRYPT_MODE, secretKeySpec)
val encryptedBytes = cipher.doFinal(text.getBytes("UTF-8"))
Base64.getEncoder.encodeToString(encryptedBytes)
}
def decrypt(encryptedText: String, secret: String): String = {
val secretKeySpec = new SecretKeySpec(secret.getBytes("UTF-8"), "AES")
val cipher = Cipher.getInstance("AES/ECB/PKCS5Padding")
cipher.init(Cipher.DECRYPT_MODE, secretKeySpec)
val encryptedBytes = Base64.getDecoder.decode(encryptedText)
new String(cipher.doFinal(encryptedBytes))
}
val encryptedText = encrypt(plainText, secretKey)
println(s"Encrypted text: $encryptedText")
val decryptedText = decrypt(encryptedText, secretKey)
println(s"Decrypted text: $decryptedText")
}
上述代码中,我们定义了两个函数encrypt
和decrypt
,分别用于加密和解密。encrypt
函数接受明文文本和密钥作为输入,返回加密后的Base64编码字符串。decrypt
函数接受加密后的文本和密钥作为输入,返回解密后的明文字符串。
在示例中,我们使用了AES算法和ECB模式进行加密和解密,并使用PKCS5Padding填充。密钥长度为128位。你可以根据需要修改这些参数。
注意:AES是一种对称加密算法,加密和解密使用相同的密钥。