当前位置:   article > 正文

Android AES加解密工具类_android aes解密,iv取加密之后的前16we

android aes解密,iv取加密之后的前16we

AES对称加密算法

  • 高级加密标准(英语:Advanced Encryption Standard,缩写:AES),在密码学中又称Rijndael加密法,是美国联邦政府采用的一种区块加密标准。这个标准用来替代原先的DES,已经被多方分析且广为全世界所使用

 

AES加密工具类参考,需要根据项目的实际情况改动配置。

code注释完美,请慢用 O(∩_∩)O

  1. import java.util.Base64;
  2. import java.util.Locale;
  3. import javax.crypto.Cipher;
  4. import javax.crypto.spec.IvParameterSpec;
  5. import javax.crypto.spec.SecretKeySpec;
  6. /**
  7. * AES加密解密字符串工具类
  8. *
  9. * 背景:MD5加密不可逆的特性决定了在很多场景下并不适用。如在某些需要对加密后的密文进行解密使之可读的场景下,就需要使用可逆加密算法实现!
  10. * 常用的可逆加密算法有:AES对称加密算法与RSA非对称加密算法
  11. *
  12. * 概述:
  13. * 高级加密标准(英语:Advanced Encryption Standard,缩写:AES),在密码学中又称Rijndael加密法,是美国联邦政府采用的一种区块加密标准。
  14. * 这个标准用来替代原先的DES,已经被多方分析且广为全世界所使用,是对称密钥加密中最流行的算法之一;
  15. * 工作模式包括:ECB、CBC、CTR、OFB、CFB;
  16. * 使用范围:该工具类仅支持CBC模式下的:
  17. * 填充:PKCS7PADDING
  18. * 数据块:128位
  19. * 密码(key):32字节长度(例如:12345678901234567890123456789012)
  20. * 偏移量(iv):16字节长度(例如:1234567890123456)
  21. * 输出:hex
  22. * 字符集:UTF-8
  23. * 使用方式:String encrypt = AESCBCUtil.encrypt("wy");
  24. * String decrypt = AESCBCUtil.decrypt(encrypt);
  25. * 验证方式:http://tool.chacuo.net/cryptaes(在线AES加密解密)
  26. */
  27. public class AESUtil {
  28. //示例:密码
  29. private static final String key = "12345678901234567890123456789012";
  30. //示例:iv偏移量
  31. private static final String iv = "1234567890123456";
  32. /**
  33. * 算法/模式/填充
  34. */
  35. private final static String CIPHER_MODE_PADDING = "AES/CBC/PKCS7PADDING";
  36. /**
  37. * 服务端约定的盐值
  38. */
  39. private static final String AES_SALT = "请向后端开发人员要";
  40. /**
  41. * 获取密钥信息
  42. * 每个场景需求不一样,此处规则可由你们自己设计
  43. *
  44. * @param timestamp 时间戳
  45. * AES密钥:md5(timestamp+salt),取前16位做为AES密钥
  46. * Iv:md5后16位做为AES偏移量
  47. * @return MD5加密后的密钥信息,32位小写
  48. */
  49. public static String getSecretKeyInfo(String timestamp) {
  50. return MD5Utils.MD5(timestamp + AES_SALT);
  51. }
  52. /**
  53. * 加密:对字符串进行加密
  54. *
  55. * @param encryptStr 需要加密的字符串
  56. * @param secretKey 密钥
  57. * @param iv iv偏移量
  58. * @return 加密后的字符串
  59. */
  60. public static String encrypt(String encryptStr, String secretKey, String iv) {
  61. String encryptedPassword = "";
  62. try {
  63. //创建AES秘钥
  64. SecretKeySpec skeySpec = new SecretKeySpec(secretKey.getBytes("UTF-8"), "AES");
  65. // 创建密码器
  66. Cipher cipher = Cipher.getInstance(CIPHER_MODE_PADDING);
  67. IvParameterSpec ivParameterSpec = new IvParameterSpec(iv.getBytes("UTF-8"));
  68. cipher.init(Cipher.ENCRYPT_MODE, skeySpec, ivParameterSpec);
  69. // 加密
  70. byte[] encrypted = cipher.doFinal(encryptStr.getBytes());
  71. encryptedPassword = Base64Encoder.encode(encrypted);
  72. return encryptedPassword;
  73. } catch (Exception ex) {
  74. ex.printStackTrace();
  75. }
  76. return encryptedPassword;
  77. }
  78. /**
  79. * 解密:对加密后的字符串进行解密,并返回字符串
  80. *
  81. * @param encryptedStr 需要解密的字符串
  82. * @return 解密后的字符串
  83. */
  84. public static String decrypt(String encryptedStr) {
  85. try {
  86. //创建AES秘钥
  87. SecretKeySpec skeySpec = new SecretKeySpec(key.getBytes("UTF-8"), "AES");
  88. // 创建密码器
  89. Cipher cipher = Cipher.getInstance(CIPHER_MODE_PADDING);
  90. IvParameterSpec ivParameterSpec = new IvParameterSpec(iv.getBytes("UTF-8"));
  91. cipher.init(Cipher.DECRYPT_MODE, skeySpec, ivParameterSpec);
  92. // 解密
  93. // byte[] bytes = hexStr2Bytes(encryptedStr);
  94. byte[] bytes = Base64Decoder.decodeToBytes(encryptedStr);
  95. byte[] original = cipher.doFinal(bytes);
  96. return new String(original);
  97. } catch (Exception ex) {
  98. ex.printStackTrace();
  99. }
  100. return null;
  101. }
  102. }

 

注意事项:

1,移动端和服务端的加解密需保持一致

2,秘钥和iv偏移量的生成规则前后端约定一致

3,加密需要的盐值可直接由服务端开发人员设计好,提供给移动端开发人员

4,ASE加密规则设计后端人员定好,

     比如这样定:【AES加密模式:CBC  填充:PKCS7    偏移量:Iv  数据块:128位  输出:base64  字符集:UTF-8】

 

 

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/盐析白兔/article/detail/203016
推荐阅读
相关标签
  

闽ICP备14008679号