aes 解密出现 java.lang.NumberFormatException: Invalid int: "ch"
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了aes 解密出现 java.lang.NumberFormatException: Invalid int: "ch",小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含3022字,纯文字阅读大概需要5分钟。
内容图文
原因:
将加密/解密的seed 和 加密内容顺序放反. decrypt(String seed, String encrypted)
附上AES解密/加密代码(android开发):
package com.carspeak.client.util; import java.io.UnsupportedEncodingException; import java.security.InvalidKeyException; import java.security.NoSuchAlgorithmException; import java.security.SecureRandom; import javax.crypto.BadPaddingException; import javax.crypto.Cipher; import javax.crypto.IllegalBlockSizeException; import javax.crypto.KeyGenerator; import javax.crypto.NoSuchPaddingException; import javax.crypto.SecretKey; import javax.crypto.spec.IvParameterSpec; import javax.crypto.spec.SecretKeySpec; /** * AES 加密解密 * * @author huqiang * */ public class AESUtil { public static String encrypt(String seed, String cleartext) throws Exception { byte[] rawKey = getRawKey(seed.getBytes()); byte[] result = encrypt(rawKey, cleartext.getBytes()); return toHex(result); } publicstatic String decrypt(String seed, String encrypted) throws Exception { byte[] rawKey = getRawKey(seed.getBytes()); byte[] enc = toByte(encrypted); byte[] result = decrypt(rawKey, enc); returnnew String(result); } privatestaticbyte[] getRawKey(byte[] seed) throws Exception { KeyGenerator kgen = KeyGenerator.getInstance("AES"); SecureRandom sr = SecureRandom.getInstance("SHA1PRNG", "Crypto"); sr.setSeed(seed); kgen.init(128, sr); // 192 and 256 bits may not be available SecretKey skey = kgen.generateKey(); byte[] raw = skey.getEncoded(); return raw; } privatestaticbyte[] encrypt(byte[] raw, byte[] clear) throws Exception { SecretKeySpec skeySpec = new SecretKeySpec(raw, "AES"); Cipher cipher = Cipher.getInstance("AES"); cipher.init(Cipher.ENCRYPT_MODE, skeySpec, new IvParameterSpec( newbyte[cipher.getBlockSize()])); byte[] encrypted = cipher.doFinal(clear); return encrypted; } privatestaticbyte[] decrypt(byte[] raw, byte[] encrypted) throws Exception { SecretKeySpec skeySpec = new SecretKeySpec(raw, "AES"); Cipher cipher = Cipher.getInstance("AES"); cipher.init(Cipher.DECRYPT_MODE, skeySpec, new IvParameterSpec( newbyte[cipher.getBlockSize()])); byte[] decrypted = cipher.doFinal(encrypted); return decrypted; } privatestatic String toHex(String txt) { return toHex(txt.getBytes()); } privatestatic String fromHex(String hex) { returnnew String(toByte(hex)); } privatestaticbyte[] toByte(String hexString) { int len = hexString.length() / 2; byte[] result = newbyte[len]; for (int i = 0; i < len; i++) result[i] = Integer.valueOf(hexString.substring(2 * i, 2 * i + 2), 16).byteValue(); return result; } privatestatic 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(); } privatefinalstatic String HEX = "0123456789ABCDEF"; privatestaticvoid appendHex(StringBuffer sb, byte b) { sb.append(HEX.charAt((b >> 4) & 0x0f)).append(HEX.charAt(b & 0x0f)); } }
aes 解密出现 java.lang.NumberFormatException: Invalid int: "ch"
原文:http://www.cnblogs.com/feijian/p/4479446.html
内容总结
以上是互联网集市为您收集整理的aes 解密出现 java.lang.NumberFormatException: Invalid int: "ch"全部内容,希望文章能够帮你解决aes 解密出现 java.lang.NumberFormatException: Invalid int: "ch"所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。