Java加解密学习

本文介绍了Java中加解密的基础知识,遵循柯克霍夫原则,重点关注Base64、MD、SHA以及MAC算法的实现。详细讲解了使用JDK、Common Codes (CC) 和 Bouncy Castle (BC) 库的不同实现方式,并提及了引入第三方包的必要性。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

柯克霍夫原则:数据的安全基于密钥而不是算法的保密。即系统的安全取决于密钥,对密钥保密,对算法公开。——现代密码学设计的基本原则。
算法实现分为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());//实例化mac
mac.init(rsk);
byte[] hmacMD5Bytes = mac.doFinal(src.getBytes());//执行摘要
System.out.println("jdk hamcMD5:"+Hex.encodeHexString(hmacMD5Bytes));
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值