Java王子 发表于 2022-7-19 18:12:13

Java加密与安全-BouncyCastle

  我们知道,Java标准库提供了一系列常用的哈希算法。

  但如果我们要用的某种算法,Java标准库没有提供怎么办?

  方法一:自己写一个,难度很大;

  方法二:找一个现成的第三方库,直接使用。

  BouncyCastle就是一个提供了很多哈希算法和加密算法的第三方库。它提供了Java标准库没有的一些算法,例如,RipeMD160哈希算法。

  我们来看一下如何使用BouncyCastle这个第三方提供的算法。

  首先,我们必须把BouncyCastle提供的jar包放到classpath中。这个jar包就是bcprov-jdk18on-xxx.jar,可以从官方网站下载。

  Java标准库的java.security包提供了一种标准机制,允许第三方提供商无缝接入。我们要使用BouncyCastle提供的RipeMD160算法,需要先把BouncyCastle注册一下:

  publicclassMain{

  publicstaticvoidmain(String[]args)throwsException{

  //注册BouncyCastle:

  Security.addProvider(newBouncyCastleProvider());

  //按名称正常调用:

  MessageDigestmd=MessageDigest.getInstance("RipeMD160");

  md.update("HelloWorld".getBytes("UTF-8"));

  byte[]result=md.digest();

  System.out.println(newBigInteger(1,result).toString(16));

  }

  }

  其中,注册BouncyCastle是通过下面的语句实现的:

  Security.addProvider(newBouncyCastleProvider());

  注册只需要在启动时进行一次,后续就可以使用BouncyCastle提供的所有哈希算法和加密算法。
页: [1]
查看完整版本: Java加密与安全-BouncyCastle