android平台下的aes加密和java平台下的运行结果不同的解决办法
来源:互联网 发布:linux安装codeblocks 编辑:程序博客网 时间:2024/06/01 07:52
实现Android和java互相加解密
完美支持中文
跨平台这种实现
还是一个原则
不要对参数采用默认实现
否则难以互通
核心函数如下,Android和java均如此(dataPassword长度为16)
- public static final String VIPARA = "0102030405060708";
- public static final String bm = "GBK";
- public static String encrypt(String dataPassword, String cleartext)
- throws Exception {
- IvParameterSpec zeroIv = new IvParameterSpec(VIPARA.getBytes());
- SecretKeySpec key = new SecretKeySpec(dataPassword.getBytes(), "AES");
- Cipher cipher = Cipher.getInstance("AES/CBC/PKCS5Padding");
- cipher.init(Cipher.ENCRYPT_MODE, key, zeroIv);
- byte[] encryptedData = cipher.doFinal(cleartext.getBytes(bm));
- return Base64.encode(encryptedData);
- }
- public static String decrypt(String dataPassword, String encrypted)
- throws Exception {
- byte[] byteMi = Base64.decode(encrypted);
- IvParameterSpec zeroIv = new IvParameterSpec(VIPARA.getBytes());
- SecretKeySpec key = new SecretKeySpec(dataPassword.getBytes(), "AES");
- Cipher cipher = Cipher.getInstance("AES/CBC/PKCS5Padding");
- cipher.init(Cipher.DECRYPT_MODE, key, zeroIv);
- byte[] decryptedData = cipher.doFinal(byteMi);
- return new String(decryptedData,bm);
- }
Base64从网上找的工具类
- package com.bao;
- import java.io.ByteArrayOutputStream;
- import java.io.IOException;
- import java.io.OutputStream;
- public class Base64 {
- private static final char[] legalChars = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/".toCharArray();
- /**
- * data[]进行编码
- * @param data
- * @return
- */
- public static String encode(byte[] data) {
- int start = 0;
- int len = data.length;
- StringBuffer buf = new StringBuffer(data.length * 3 / 2);
- int end = len - 3;
- int i = start;
- int n = 0;
- while (i <= end) {
- int d = ((((int) data[i]) & 0x0ff) << 16)
- | ((((int) data[i + 1]) & 0x0ff) << 8)
- | (((int) data[i + 2]) & 0x0ff);
- buf.append(legalChars[(d >> 18) & 63]);
- buf.append(legalChars[(d >> 12) & 63]);
- buf.append(legalChars[(d >> 6) & 63]);
- buf.append(legalChars[d & 63]);
- i += 3;
- if (n++ >= 14) {
- n = 0;
- buf.append(" ");
- }
- }
- if (i == start + len - 2) {
- int d = ((((int) data[i]) & 0x0ff) << 16)
- | ((((int) data[i + 1]) & 255) << 8);
- buf.append(legalChars[(d >> 18) & 63]);
- buf.append(legalChars[(d >> 12) & 63]);
- buf.append(legalChars[(d >> 6) & 63]);
- buf.append("=");
- } else if (i == start + len - 1) {
- int d = (((int) data[i]) & 0x0ff) << 16;
- buf.append(legalChars[(d >> 18) & 63]);
- buf.append(legalChars[(d >> 12) & 63]);
- buf.append("==");
- }
- return buf.toString();
- }
- private static int decode(char c) {
- if (c >= 'A' && c <= 'Z')
- return ((int) c) - 65;
- else if (c >= 'a' && c <= 'z')
- return ((int) c) - 97 + 26;
- else if (c >= '0' && c <= '9')
- return ((int) c) - 48 + 26 + 26;
- else
- switch (c) {
- case '+':
- return 62;
- case '/':
- return 63;
- case '=':
- return 0;
- default:
- throw new RuntimeException("unexpected code: " + c);
- }
- }
- /**
- * Decodes the given Base64 encoded String to a new byte array. The byte
- * array holding the decoded data is returned.
- */
- public static byte[] decode(String s) {
- ByteArrayOutputStream bos = new ByteArrayOutputStream();
- try {
- decode(s, bos);
- } catch (IOException e) {
- throw new RuntimeException();
- }
- byte[] decodedBytes = bos.toByteArray();
- try {
- bos.close();
- bos = null;
- } catch (IOException ex) {
- System.err.println("Error while decoding BASE64: " + ex.toString());
- }
- return decodedBytes;
- }
- private static void decode(String s, OutputStream os) throws IOException {
- int i = 0;
- int len = s.length();
- while (true) {
- while (i < len && s.charAt(i) <= ' ')
- i++;
- if (i == len)
- break;
- int tri = (decode(s.charAt(i)) << 18)
- + (decode(s.charAt(i + 1)) << 12)
- + (decode(s.charAt(i + 2)) << 6)
- + (decode(s.charAt(i + 3)));
- os.write((tri >> 16) & 255);
- if (s.charAt(i + 2) == '=')
- break;
- os.write((tri >> 8) & 255);
- if (s.charAt(i + 3) == '=')
- break;
- os.write(tri & 255);
- i += 4;
- }
- }
- }
对于具体参数的意义
AES 加密及兼容 参看 http://blog.csdn.net/ustcxjt/article/details/7440564
原文:http://blog.csdn.net/ustcxjt/article/details/7442830
0 0
- android平台下的aes加密和java平台下的运行结果不同的解决办法
- android平台下的aes加密和java平台下的运行结果不同的解决办法
- android平台下的aes加密和java平台下的运行结果不同的解决办法
- android平台下的aes加密和java平台…
- Android和java两平台AES的互相加密解密
- android 和java平台通用的AES加密解密
- AES加密解密Windows下跟linux下结果不同的解决方案
- AES加密解密Windows下跟linux下结果不同的解决方案
- Android平台下的加密算法之(RSA/DES/AES)
- AES加密算法在linux下相同输入每次加密结果都不同的问题
- iOS平台下的加密
- 关于Android DES加密算法在不同平台加密结果不同的问题的一个解决方法
- Linux操作系统下每次AES加密结果不一致的原因
- Android平台AES对称加密踩过的坑
- java转义符同样的代码在cmd下和eclipse下运行结果不同
- MTK平台下JAVA的J2ME运行平台实现和开发设计
- nodejs和java的AES加密结果保持一致
- Java平台AES加密
- App调试内存泄露之Context篇(上)
- hdu 3788 ZOJ问题 (字符串)
- 开通了!
- 调用http接口操作
- 各司其职,合理网站布局营造首页排名优势
- android平台下的aes加密和java平台下的运行结果不同的解决办法
- Could not inspect the application package.错误解决
- IntelliJ IDEA 14 配置Tomcat8
- handler知识整理
- C/S客户端的响应处理流程
- HDOJ The Hardest Problem Ever
- Android - 线程同步
- Win7系统安装虚拟机virtualbox,系统Ubuntu Kylin 14.04.1
- 判断特殊字符