BouncyCastle - Java加密与安全
生活随笔
收集整理的這篇文章主要介紹了
BouncyCastle - Java加密与安全
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
BouncyCastle什么是BouncyCastle?1. 它是第三方提供的一組加密提供方2. 他提供了JDK沒有提供的算法,例如RipeMD160哈希算法3. 他的官方網站是: http://www.bouncycastle.org/
我們如何使用第三方提供的算法呢?例如我們要使用RipeMD160算法1. 首先我們要把第三方jar包添加到classpath,然后我們通過Security.addProvider,提供BouncyCastleProvider這個實例,這樣我們就可以注冊一個第三方提供方,緊接著我們就可以使用JDK提供的使用接口,來使用各種算法,例如我們只要使用MessageDigest.getInstance,然后傳入RipeMD160,我們就可以使用BouncyCastle提供的摘要算法
package com.learn.securl;import java.security.MessageDigest;
import java.security.NoSuchAlgorithmException;
import java.security.Security;import org.bouncycastle.jce.provider.BouncyCastleProvider;public class DigestDemo {public static byte[] digest(String hashAlgorithm, byte[] input) {MessageDigest md = null;try {md = MessageDigest.getInstance(hashAlgorithm);} catch (NoSuchAlgorithmException e) {e.printStackTrace();}md.update(input);return md.digest();}public static String bytesToHexString(byte... src) {StringBuilder stringBuilder = new StringBuilder();if (src == null || src.length <= 0) {return null;}for (int i = 0; i < src.length; i++) {int v = src[i] & 0xFF;String hv = Integer.toHexString(v);if (hv.length() < 2) {stringBuilder.append(0);}stringBuilder.append(hv);}return stringBuilder.toString();}/*** MD5,SHA1,SHA-256都是JDK自帶的摘要算法* 而RipeMD160不是JDK自帶的* 所以他會報錯* NoSuchAlgorithmException: RipeMD160 MessageDigest not available* BouncyCastle他提供了RipeMD160的算法* 如果我們要使用BouncyCastle的話* 首先我們要把BouncyCastle的jar包bcprov-jdk15on-1.55.jar放到classpath中* <dependency>* <groupId>org.bouncycastle</groupId>* <artifactId>bcprov-jdk15on</artifactId>* <version>1.56</version>* </dependency>* @param args* @throws Exception*/public static void main(String[] args) throws Exception {/*** 把BouncyCastle作為Provider添加到java.security* 我們在Security.addProvider中把BouncyCastle添加為Provider* 20: 31a78b8a9aa93f70dd225e52eaaf67d942e44ce9* 這個時候我們就可以看到RipeMD160摘要可以被正確的計算出來*/Security.addProvider(new BouncyCastleProvider());String s = "Java摘要算法測試";byte[] input = s.getBytes("UTF-8");byte[] r1 = digest("MD5",input);System.out.println(r1.length + ": " + bytesToHexString(r1));byte[] r2 = digest("SHA-1",input);System.out.println(r2.length + ": " + bytesToHexString(r2));byte[] r3 = digest("SHA-256",input);System.out.println(r3.length + ": " + bytesToHexString(r3));byte[] r4 = digest("RipeMD160",input);System.out.println(r4.length + ": " + bytesToHexString(r4));}
}
最后我們總結一下:1. BouncyCastle是第三方算法提供商2. 他提供了JDK沒有提供的算法3. 我們在使用第三方算法前,需要通過Security.setProvider進行注冊
?
總結
以上是生活随笔為你收集整理的BouncyCastle - Java加密与安全的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: SHA1 - Java加密与安全
- 下一篇: Hmac - Java加密与安全