服务端给过来的加密解密在工具在Android上竟然不能通用,查了下说有的不支持,nngx
//it's the key point
SecureRandom sr = SecureRandom.getInstance("SHA1PRNG","Crypto");
package com.meizu.app.test; import java.security.SecureRandom; import javax.crypto.Cipher; import javax.crypto.KeyGenerator; import javax.crypto.SecretKey; import javax.crypto.spec.IvParameterSpec; import javax.crypto.spec.SecretKeySpec; /** * AES 加密/解密 * @author nicai * @time 16-3-10 上午11:19 */ public class AESUtils { public static final String TAG = "AESUtils"; /** * 加密 * @param key 加密要使用key,解密时要用 * @param originalText 要加密的内容 * @return 加密后的内容 */ public static String encrypt(String key, String originalText) { byte[] result = null; try { byte[] rawkey = getRawKey(key.getBytes()); result = encrypt(rawkey, originalText.getBytes()); } catch (Exception e) { e.printStackTrace(); } String content = toHex(result); return content; } /** * 解密 * @param key 加密时使用的key * @param encryptedText 被加密过的内容 * @return 解密后的内容 */ public static String decrypt(String key, String encryptedText) { byte[] rawKey; try { rawKey = getRawKey(key.getBytes()); byte[] enc = toByte(encryptedText); byte[] result = decrypt(rawKey, enc); String coentn = new String(result); return coentn; } catch (Exception e) { e.printStackTrace(); return null; } } private static byte[] getRawKey(byte[] seed) throws Exception { KeyGenerator kgen = KeyGenerator.getInstance("AES"); SecureRandom sr = SecureRandom.getInstance("SHA1PRNG","Crypto"); //it's the key point sr.setSeed(seed); kgen.init(128, sr); SecretKey sKey = kgen.generateKey(); byte[] raw = sKey.getEncoded(); return raw; } private static byte[] encrypt(byte[] raw, byte[] clear) throws Exception { SecretKeySpec skeySpec = new SecretKeySpec(raw, "AES"); Cipher cipher = Cipher.getInstance("AES/CBC/PKCS5Padding"); cipher.init(Cipher.ENCRYPT_MODE, skeySpec, new IvParameterSpec( new byte[cipher.getBlockSize()])); 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/CBC/PKCS5Padding"); cipher.init(Cipher.DECRYPT_MODE, skeySpec, new IvParameterSpec( new byte[cipher.getBlockSize()])); byte[] decrypted = cipher.doFinal(encrypted); return decrypted; } private static byte[] toByte(String hexString) { int len = hexString.length() / 2; byte[] result = new byte[len]; for (int i = 0; i < len; i++) result[i] = Integer.valueOf(hexString.substring(2 * i, 2 * i + 2), 16).byteValue(); return result; } private static String toHex(byte[] buf) { if (buf == null) return ""; StringBuffer result = new StringBuffer(2 * buf.length); for (int i = 0; i < buf.length; i++) { appendHex(result, buf[i]); } return result.toString(); } private static void appendHex(StringBuffer sb, byte b) { final String HEX = "0123456789ABCDEF"; sb.append(HEX.charAt((b >> 4) & 0x0f)).append(HEX.charAt(b & 0x0f)); } }
OK!