Java加解密学习
来源:互联网 发布:udid后台管理系统源码 编辑:程序博客网 时间:2024/04/29 04:21
柯克霍夫原则:数据的安全基于密钥而不是算法的保密。即系统的安全取决于密钥,对密钥保密,对算法公开。——现代密码学设计的基本原则。
算法实现分为3类:jdk,Common Codes(CC),Bouncy Castle(BC),后两者使用需要引入jar包。
1.Base64
1.jdk实现
BASE64Encoder encoder = new BASE64Encoder();String encode = encoder.encode(src.getBytes());System.out.println("jdk encode:"+encode);BASE64Decoder decoder = new BASE64Decoder();System.out.println("jdk decode:"+new String(decoder.decodeBuffer(encode)));
2.CC实现:
byte[] encodeBytes = Base64.encodeBase64(src.getBytes());System.out.println("cc encode:"+new String(encodeBytes));System.out.println("cc decode:"+new String(Base64.decodeBase64(encodeBytes)));
3.BC实现
byte[] encodeBytes = org.bouncycastle.util.encoders.Base64.encode(src.getBytes());byte[] decodeBytes = org.bouncycastle.util.encoders.Base64.decode(encodeBytes);
2.MD算法
1.jdk实现:
MessageDigest md = MessageDigest.getInstance("MD5");byte[] mdBytes = md.digest(src.getBytes());System.out.println("jdk md5:"+Hex.encodeHexString(mdBytes));
其中Hex是引入的第三包cc中的类。
2.CC实现
System.out.println("cc md5:"+DigestUtils.md5Hex(src.getBytes()));
3.BC实现
Digest digest = new MD5Digest();digest.update(src.getBytes(),0,src.getBytes().length);byte[] mdBytes = new byte[digest.getDigestSize()];digest.doFinal(mdBytes,0);System.out.println("bc md5:"+org.bouncycastle.util.encoders.Base64.Hex.toHexString(myBytes));
其中的Hex是封装在BC包中的。
3.SHA算法
SHA算法实现与MD实现很相似
1.jdk实现
MessageDigest md = MessageDigest.getInstance("SHA");byte[] mdBytes = md.digest(src.getBytes());System.out.println("jdk sha1:"+Hex.encodeHexString(mdBytes));
2.cc实现
System.out.println("cc sha1:"+DigestUtils.sha1Hex(src.getBytes()));
3.bc实现
Digest digest = new SHA1Digest();digest.update(src.getBytes(),0,src.getBytes().length);byte[] mdBytes = new byte[digest.getDigestSize()];digest.doFinal(mdBytes,0);System.out.println("bc SHA1:"+org.bouncycastle.util.encoders.Base64.Hex.toHexString(myBytes));
4.MAC算法
MAC分为mac与hmac,是MD与SHA的融合。
KeyGennerator kg = KeyGenerator.getInstance("HmacMD5");SecretKey sk = kg.generateKey();//产生密钥//byte[]key = sk.getEncoded(); //获得密钥,随机byte[]key = Hex.decodeHex(new char[]{'a','a','a','a','a','a','a','a'});//获得密钥,自定义SecretKey rsk = new SecretKeySpec(key, "HmacMD5");//还原密钥Mac mac = Mac.getInstance(rsk.getAlgorithm());//实例化macmac.init(rsk);byte[] hmacMD5Bytes = mac.doFinal(src.getBytes());//执行摘要System.out.println("jdk hamcMD5:"+Hex.encodeHexString(hmacMD5Bytes));
0 0
- Java加解密学习
- Java学习之3DES加解密
- JAVA加解密 -- Base64加解密
- JAVA加解密 -- Base64加解密
- java加解密-数字证书
- java RSA 加解密
- java 加解密
- DES加解密(Java)
- java加解密相关
- java RSA 加解密
- java加解密算法
- java RSA 加解密
- java加解密
- Java简单加解密
- Java加解密
- java加解密
- Java Des加解密
- java RC4加解密
- hibernate 5.2.6新特性
- 遇到的小问题
- 最全面的安卓编码规范
- 【蓝桥杯】试题集入门训练第一题
- java string与unicode互转
- Java加解密学习
- Qt编写OpenMP程序--循环测试
- 对象字段与json下划线字段的相互转换
- Qt Createor error writing to -: Invalid argument
- memcached在项目中的应用
- 内存溢出和内存泄漏的区别、产生原因以及解决方案
- 回调函数(CALLBACK)学习总结
- JNI:使用RegisterNatives方法传递和使用Java自定义类
- 安卓各版本主要的特性