java– 使用AES的Android加密解密

java– 使用AES的Android加密解密,第1张

概述在Android上如何使用AES加密解密图像和其他文件有一个很好的例子吗?解决方法:警告:此答案包含您不应使用的代码,因为它不安全(使用SHA1PRNG进行密钥派生并在ECB模式下使用AES)相反,在CBC或GCM模式下使用PBKDF2WithHmacSHA1进行密钥派生和AES(GCM提供隐私和完整性)您可以使用以下

在Android上如何使用AES加密和解密图像和其他文件有一个很好的例子吗?

解决方法:

警告:此答案包含您不应使用的代码,因为它不安全(使用SHA1PRNG进行密钥派生并在ECB模式下使用AES)

相反,在CBC或GCM模式下使用PBKDF2WithHmacSHA1进行密钥派生和AES(GCM提供隐私和完整性)

您可以使用以下函数:

private static byte[] encrypt(byte[] raw, byte[] clear) throws Exception {    SecretKeySpec skeySpec = new SecretKeySpec(raw, "AES");    Cipher cipher = Cipher.getInstance("AES");    cipher.init(Cipher.ENCRYPT_MODE, skeySpec);    byte[] encrypted = cipher.doFinal(clear);    return encrypted;}private static byte[] decrypt(byte[] raw, byte[] encrypted) throws Exception {    SecretKeySpec skeySpec = new SecretKeySpec(raw, "AES");    Cipher cipher = Cipher.getInstance("AES");    cipher.init(Cipher.DECRYPT_MODE, skeySpec);    byte[] decrypted = cipher.doFinal(encrypted);    return decrypted;}

并像这样调用它们:

ByteArrayOutputStream baos = new ByteArrayOutputStream();  bm.compress(Bitmap.CompressFormat.PNG, 100, baos); // bm is the bitmap object   byte[] b = baos.toByteArray();  byte[] keyStart = "this is a key".getBytes();KeyGenerator kgen = KeyGenerator.getInstance("AES");SecureRandom sr = SecureRandom.getInstance("SHA1PRNG");sr.setSeed(keyStart);kgen.init(128, sr); // 192 and 256 bits may not be availableSecretKey skey = kgen.generateKey();byte[] key = skey.getEncoded();    // encryptbyte[] encryptedData = encrypt(key,b);// decryptbyte[] decryptedData = decrypt(key,encryptedData);

这应该工作,我现在在项目中使用类似的代码.

总结

以上是内存溢出为你收集整理的java – 使用AES的Android加密/解密全部内容,希望文章能够帮你解决java – 使用AES的Android加密/解密所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/web/1104234.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2022-05-28
下一篇2022-05-28

发表评论

登录后才能评论

评论列表(0条)

    保存