- 浏览: 443870 次
- 性别:
- 来自: 北京
文章分类
最新评论
-
zhengch00:
这个文档不是你自己写的吧
informatica连接ftp -
ctcwri:
于我心有慽慽焉,java的web就像陷入了泥坑。
Java 的纯真年代已经离我们越来越远了 -
bestxiaok:
Glorin 写道这个应该是你的安装目录tomcat文件夹下面 ...
Value must be an existing directory配置tomcat问题? -
Glorin:
这个应该是你的安装目录tomcat文件夹下面少了一个temp文 ...
Value must be an existing directory配置tomcat问题? -
bestxiaok:
sheep3600 写道bestxiaok 写道sheep36 ...
AES加密解密
由于刚才的方法不好使,算出来的东西不知道是什么进制,整迷糊了,就用如下的算法。
谢谢了,我都报好了,发现个问题,在加密和解密的时候,CPU利用率比较高。。。
我觉得这个正常吧,一般这种东西都比较累CPU。
那就放在前台吧,这个可能还比较好搞点。
谢谢了,我都报好了,发现个问题,在加密和解密的时候,CPU利用率比较高。。。
我觉得这个正常吧,一般这种东西都比较累CPU。
谢谢了,我都报好了,发现个问题,在加密和解密的时候,CPU利用率比较高。。。
/** * 加密 * * @param content 需要加密的内容 * @param password 加密密码 * @return */ public static byte[] encrypt(String content, String password) { try { KeyGenerator kgen = KeyGenerator.getInstance("AES"); kgen.init(128, new SecureRandom(password.getBytes())); SecretKey secretKey = kgen.generateKey(); byte[] enCodeFormat = secretKey.getEncoded(); SecretKeySpec key = new SecretKeySpec(enCodeFormat, "AES"); Cipher cipher = Cipher.getInstance("AES");// 创建密码器 byte[] byteContent = content.getBytes("utf-8"); cipher.init(Cipher.ENCRYPT_MODE, key);// 初始化 byte[] result = cipher.doFinal(byteContent); return result; // 加密 } catch (NoSuchAlgorithmException e) { e.printStackTrace(); } catch (NoSuchPaddingException e) { e.printStackTrace(); } catch (InvalidKeyException e) { e.printStackTrace(); } catch (UnsupportedEncodingException e) { e.printStackTrace(); } catch (IllegalBlockSizeException e) { e.printStackTrace(); } catch (BadPaddingException e) { e.printStackTrace(); } return null; } /**解密 * @param content 待解密内容 * @param password 解密密钥 * @return */ public static byte[] decrypt(byte[] content, String password) { try { KeyGenerator kgen = KeyGenerator.getInstance("AES"); kgen.init(128, new SecureRandom(password.getBytes())); SecretKey secretKey = kgen.generateKey(); byte[] enCodeFormat = secretKey.getEncoded(); SecretKeySpec key = new SecretKeySpec(enCodeFormat, "AES"); Cipher cipher = Cipher.getInstance("AES");// 创建密码器 cipher.init(Cipher.DECRYPT_MODE, key);// 初始化 byte[] result = cipher.doFinal(content); return result; // 加密 } catch (NoSuchAlgorithmException e) { e.printStackTrace(); } catch (NoSuchPaddingException e) { e.printStackTrace(); } catch (InvalidKeyException e) { e.printStackTrace(); } catch (IllegalBlockSizeException e) { e.printStackTrace(); } catch (BadPaddingException e) { e.printStackTrace(); } return null; } /**将二进制转换成16进制 * @param buf * @return */ public static String parseByte2HexStr(byte buf[]) { StringBuffer sb = new StringBuffer(); for (int i = 0; i < buf.length; i++) { String hex = Integer.toHexString(buf[i] & 0xFF); if (hex.length() == 1) { hex = '0' + hex; } sb.append(hex.toUpperCase()); } return sb.toString(); } /**将16进制转换为二进制 * @param hexStr * @return */ public static byte[] parseHexStr2Byte(String hexStr) { if (hexStr.length() < 1) return null; byte[] result = new byte[hexStr.length()/2]; for (int i = 0;i< hexStr.length()/2; i++) { int high = Integer.parseInt(hexStr.substring(i*2, i*2+1), 16); int low = Integer.parseInt(hexStr.substring(i*2+1, i*2+2), 16); result[i] = (byte) (high * 16 + low); } return result; } public static void main(String[] args) throws UnsupportedEncodingException { // String content = "test"; // String password = "12345678123456"; // //加密 // System.out.println("加密前:" + content); // byte[] encryptResult = encrypt(content, password); //// System.out.println(new String(encryptResult,"UTF8")); // //解密 // byte[] decryptResult = decrypt(encryptResult,password); // System.out.println("解密后:" + new String(decryptResult)); String content = "test"; String password = "12345676789"; //加密 System.out.println("加密前:" + content); byte[] encryptResult = encrypt(content, password); String encryptResultStr = parseByte2HexStr(encryptResult); System.out.println("加密后:" + encryptResultStr); //解密 byte[] decryptFrom = parseHexStr2Byte(encryptResultStr); byte[] decryptResult = decrypt(decryptFrom,password); System.out.println("解密后:" + new String(decryptResult)); }
评论
5 楼
bestxiaok
2012-01-16
sheep3600 写道
bestxiaok 写道
sheep3600 写道
对了,另外建议你把进制转换封装进去,用起来方便,string进,string出。
谢谢了,我都报好了,发现个问题,在加密和解密的时候,CPU利用率比较高。。。
我觉得这个正常吧,一般这种东西都比较累CPU。
那就放在前台吧,这个可能还比较好搞点。
4 楼
sheep3600
2012-01-12
bestxiaok 写道
sheep3600 写道
对了,另外建议你把进制转换封装进去,用起来方便,string进,string出。
谢谢了,我都报好了,发现个问题,在加密和解密的时候,CPU利用率比较高。。。
我觉得这个正常吧,一般这种东西都比较累CPU。
3 楼
bestxiaok
2012-01-10
sheep3600 写道
对了,另外建议你把进制转换封装进去,用起来方便,string进,string出。
谢谢了,我都报好了,发现个问题,在加密和解密的时候,CPU利用率比较高。。。
2 楼
sheep3600
2012-01-09
对了,另外建议你把进制转换封装进去,用起来方便,string进,string出。
1 楼
sheep3600
2012-01-09
看你回复我,我就来转转。
看到这个AES加密,顺便提个醒,这个只适合java之间的加密解密,跨语言就搞不通了
这一部分闹的,而且
这一部分需要再详细的指明一下
呵呵。
看到这个AES加密,顺便提个醒,这个只适合java之间的加密解密,跨语言就搞不通了
KeyGenerator kgen = KeyGenerator.getInstance("AES"); kgen.init(128, new SecureRandom(password.getBytes())); SecretKey secretKey = kgen.generateKey(); byte[] enCodeFormat = secretKey.getEncoded();
这一部分闹的,而且
Cipher cipher = Cipher.getInstance("AES");// 创建密码器
这一部分需要再详细的指明一下
Cipher cipher = Cipher.getInstance("AES/ECB/PKCS5Padding")
呵呵。
发表评论
文章已被作者锁定,不允许评论。
-
JAVA 程序中使用ORACLE 绑定变量( bind variable )
2012-08-17 10:45 28481、为什么要使用绑定变量 (1)SQL语 句硬分 ... -
ArrayList的性能优化
2012-06-13 19:56 2052size、isEmpty、get、set、iterat ... -
java支持的最大内存
2012-06-13 11:14 17511、jdk各个版本在不同操作系统中支持的最大内存是不一样的,但 ... -
Java 的纯真年代已经离我们越来越远了
2012-03-07 15:05 1465[size=medium]用Java 去写跨 ... -
unable to access jarfile ***.jar
2012-02-28 10:52 2296相信有不少朋友遇到过这样的问题——如题,我今天也遇到了,后来发 ... -
java 加密解密 算法1
2012-01-06 15:44 1784采用对称的加密的算法 ... -
UNION替换OR效率测试及总结
2011-11-09 17:11 1033大家在做SQL优化的过程中,可能都知道一个事实:某些情况下使用 ... -
update 多表更新
2011-11-09 15:35 977在开发中,数据库来回换,而有些关键性的语法又各不相同,这是一件 ... -
ora-00957:duplicate column name
2011-11-07 16:49 2356ora-00957:duplicate column name ... -
ResultSet获取行数
2011-11-06 11:21 1453网上有人说用这种方式获取: ResultSet里面有,你先把r ... -
java.lang.ArrayIndexOutOfBoundsException: 6
2011-11-06 11:11 4397java.lang.ArrayIndexOutOfBounds ... -
Oracle: ORA-01000: 超出打开游标的最大数问题
2011-11-02 09:53 1730java.sql.SQLException: ORA-0100 ... -
几种常用的数据库分页
2011-11-01 22:33 11651.oracle数据库分页 select * from (se ... -
邮件发送 java mail
2011-05-10 21:51 1006根据需要写了一个java发送邮件的程序 Propert ... -
java定时启动跑批
2011-04-23 14:48 2124要做一个自动的跑批的流程,需要定点启动一个进程,比如说每天7点 ... -
关于@SuppressWarnings
2010-11-14 16:56 888最近做程序碰到了个@Sup ... -
cvs工作原理及对cvs的理解
2010-11-09 08:50 2370cvs是一个不错的软件版本管理工具。 cvs分为客户端和服 ... -
GridBagLayout布局管理器
2010-09-17 15:41 1101GridBagLayout 类是一个灵活的布局管理器,它不要求 ... -
ButtonGroup在swing中的应用
2010-09-17 15:31 1716swing中使用ButtonGroup: public ... -
javaGUI应用程序发布&&数字签名
2010-09-15 16:14 1002JavaGUI应用程序部署 JavaGUI程序发布分类1) A ...
相关推荐
用C语言实现的AES加密解密算法,用C语言实现的AES加密解密算法
VB.NET实现AES加密解密代码,可直接使用
' 功能: AES加密解密 password<==>hwWpiegaWDeE8kTlb/5BQg== , 8705a989e81a583784f244e56ffe4142 ' [Str] 预备转换的byte ' [StrKey] 16位的密钥 ' [StrIv] 16位的偏移 ' [Encrypt] 加密(缺省值)还是解密 ' ...
本文实例为大家分享了python实现AES加密解密的具体代码,供大家参考,具体内容如下 (1)对于AES加密解密相关知识 (2)实现的功能就是输入0-16个字符,然后经过AES的加密解密最后可以得到原先的输入,运行的结果...
AES加密解密轮转算法工具,最大支持256bit长度的密钥,明文支持HEX和字串。可供学习设计参考。
1. 在深入理解AES加密/解密算法理论的基础上,设计一个AES加密/解密软件系统; 2. 完成CBC和ECB模式加密解密
主要介绍了java使用Hex编码解码实现Aes加密解密功能,结合完整实例形式分析了Aes加密解密功能的定义与使用方法,需要的朋友可以参考下
AES加密解密验证工具(支持各种加密模式)
本地图片AES加密解密,利用AES加密的方式将图片保存于本地,其他App获取该图片无法显示,信息安全可靠加密速度高且十分有效,最好是保存的图片源文件在500KB以下为最佳!
aes加密解密js
详细演示AES加密解密过程.AES是分组密钥,算法输入128位数据,密钥长度也是128位。用Nr表示对一个数据分组加密的轮数(加密轮数与密钥长度的关系如表1所列)。每一轮都需要一个与输入分组具有相同长度的扩展密钥...
php+uni-app AES加密解密
支持密码长度AES_128/AES_192/AES_256,支持工作模式 ECB/CBC,支持填充模式 ZERO/PKCS7/ISO。已通过测试。内附使用方法。
高级加密标准(英语:Advanced Encryption Standard,缩写:AES),在密码学中又称Rijndael加密法,是美国联邦政府采用的一种区块加密标准。 该压缩包中包括aes加密算法的c++实现代码。
AES加密解密算法的Java实现.doc
java代码-java使用AES加密解密 AES-128-ECB加密 ——学习参考资料:仅用于个人学习使用
实现的AES加密解密算法,高级加密标准(AES,Advanced Encryption Standard)为最常见的对称加密算法(微信小程序加密传输就是用这个加密算法的)。对称加密算法也就是加密和解密用相同的密钥
C# JAVA nodejs通用的AES加密解密算法,考虑到实际使用过程中由于客户端和服务端使用的语言不一样而又需要对数据进行加密和解密的情况,特此总结了C# JAVA nodejs通用的AES加密解密算法,供需要者参考。
这是一套有关于aes加密解密的资源,包含java端及其对应的js端
实现C语言的AES加密解密。包含各种加密模式,ECB、CBC