在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是一种对称加密算法,加密和解密使用相同的密钥。