AES加密在linux上的问题
来源:互联网 发布:淘宝刷手小号 编辑:程序博客网 时间:2024/06/05 01:06
AES加密在Linux上加密和解密都必须加上
KeyGenerator kgen = KeyGenerator.getInstance("AES"); SecureRandom random = SecureRandom.getInstance("SHA1PRNG"); random.setSeed(encryptKey.getBytes()); kgen.init(128,random); Cipher cipher = Cipher.getInstance("AES"); cipher.init(Cipher.ENCRYPT_MODE,new SecretKeySpec(kgen.generateKey().getEncoded(),"AES"));
否则,因为持有的random对象不一样,导致每次密钥不一致。
加密工具类:
public class DESUtil { /** * base 64 encode * @param bytes 待编码的byte[] * @return 编码后的base 64 code */ public static String base64Encode(byte[] bytes){ return new BASE64Encoder().encode(bytes); } /** * base 64 decode * @param base64Code 待解码的base 64 code * @return 解码后的byte[] * @throws Exception */ public static byte[] base64Decode(String base64Code) throws IOException { return StringUtils.isNullOrEmpty(base64Code)? null : new BASE64Decoder().decodeBuffer(base64Code); } /** * 获取byte[]的md5值 * @param bytes byte[] * @return md5 * @throws Exception */ public static byte[] md5(byte[] bytes) throws NoSuchAlgorithmException { MessageDigest md = MessageDigest.getInstance("MD5"); md.update(bytes); return md.digest(); } /** * 获取字符串md5值 * @param msg * @return md5 * @throws Exception */ public static byte[] md5(String msg) throws NoSuchAlgorithmException { return StringUtils.isNullOrEmpty(msg) ? null : md5(msg.getBytes()); } /** * 结合base64实现md5加密 * @param msg 待加密字符串 * @return 获取md5后转为base64 * @throws Exception */ public static String md5Encrypt(String msg) throws NoSuchAlgorithmException { return StringUtils.isNullOrEmpty(msg) ? null : base64Encode(md5(msg)); } /** * AES加密 * @param content 待加密的内容 * @param encryptKey 加密密钥 * @return 加密后的byte[] * @throws Exception */ public static byte[] aesEncryptToBytes(String content,String encryptKey) throws Exception { KeyGenerator kgen = KeyGenerator.getInstance("AES"); SecureRandom random = SecureRandom.getInstance("SHA1PRNG"); random.setSeed(encryptKey.getBytes()); kgen.init(128,random); Cipher cipher = Cipher.getInstance("AES"); cipher.init(Cipher.ENCRYPT_MODE,new SecretKeySpec(kgen.generateKey().getEncoded(),"AES")); return cipher.doFinal(content.getBytes("UTF-8")); } /** * AES加密为base 64 code * @param content 待加密的内容 * @param encryptKey 加密密钥 * @return 加密后的base 64 code * @throws Exception */ public static String aesEncrypt(String content,String encryptKey) throws Exception { return base64Encode(aesEncryptToBytes(content,encryptKey)); } /** * AES解密 * @param encryptBytes 待解密的byte[] * @param decryptKey 解密密钥 * @return 解密后的String * @throws Exception */ public static String aesDecryptByBytes(byte[] encryptBytes, String decryptKey) throws Exception { KeyGenerator kgen = KeyGenerator.getInstance("AES"); SecureRandom random = SecureRandom.getInstance("SHA1PRNG"); random.setSeed(decryptKey.getBytes()); kgen.init(128, random); Cipher cipher = Cipher.getInstance("AES"); cipher.init(Cipher.DECRYPT_MODE, new SecretKeySpec(kgen.generateKey().getEncoded(), "AES")); byte[] decryptBytes = cipher.doFinal(encryptBytes); return new String(decryptBytes); } /** * 将base 64 code AES解密 * @param encryptStr 待解密的base 64 code * @param decryptKey 解密密钥 * @return 解密后的string * @throws Exception */ public static String aesDecrypt(String encryptStr, String decryptKey) throws Exception { return StringUtils.isNullOrEmpty(encryptStr) ? null : aesDecryptByBytes(base64Decode(encryptStr), decryptKey); }}
0 0
- AES加密在linux上的问题
- JAVA aes加密在linux中的问题
- 使用AES加密解密在windows上使用没有问题,在Linux(Centos6.5)上出现解密失败的解决方法
- JAVA的AES加密解密在windows上测试正常,但Linux服务器上却有异常!
- AES加密技术在文件与字符串上的应用
- AES加密算法在linux下相同输入每次加密结果都不同的问题
- JAVA AES加解密windows上正常,但是在linux中不正常的问题
- android 上aes 加密的代码片段
- java AES加密遇到的一些问题
- 对称加密技AES 在手机上运行
- AES加密问题
- 在测试aes加密的时候,出现一个关于密钥的长度问题
- AES加密算法在Linux下出现随机加密结果
- 关于AES在Linux下加密解密出错问题解决方案
- 关于AES加密(上)
- AES加密算法在GPU上的实现
- JAVA的AES加密
- 简单的aes加密
- Apache Kafka 集群环境搭建
- 从零开始学习EasyDarwin之无锁队列
- phpexcel的使用
- SharePoint 2016 配置用户请求应用程序
- git学习笔记
- AES加密在linux上的问题
- 浅析Java中的访问权限控制
- Linux命令:touch
- Java中各进制之间的表示
- Leetcode_Combination Sum III
- C++中的类型转换
- 从零开始学习EasyDarwin之RTSP请求处理过程
- 对于js的报错处理
- 朴素贝叶斯算法