日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > java >内容正文

java

BouncyCastle - Java加密与安全

發(fā)布時間:2024/4/13 java 35 豆豆
生活随笔 收集整理的這篇文章主要介紹了 BouncyCastle - Java加密与安全 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

BouncyCastle什么是BouncyCastle?1. 它是第三方提供的一組加密提供方2. 他提供了JDK沒有提供的算法,例如RipeMD160哈希算法3. 他的官方網(wǎng)站是: 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加密与安全的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內容還不錯,歡迎將生活随笔推薦給好友。