1. Home
  2. /
  3. Download
  4. /
  5. Download Bouncy Castle Java FIPS

Download Bouncy Castle for Java FIPS

Welcome to the download page for the FIPS-certified editions of Bouncy Castle Java. In addition to the available access options, including Maven Central and direct download, you will find searchable release notes and links to API and other documentation.

Bouncy Castle Java
hero-sub-2

Documentation

Check out the Bouncy Castle for Java documentation, including the Java FIPS documentation for clear guidance and examples.

Join the Discussion

You can ask questions and learn from specialists in the Bouncy Castle Java forum on GitHub Discussions. We highly appreciate and value your input.

Report an issue

If you encounter any issues that require attention, feel free to report them in our GitHub repository. 

Release notes

Find out detailed information about the latest release and search in older release notes.

Roadmap

Details about our current plans and versions in progress for Java FIPS can be found on the Java FIPS Roadmap.

Donate to support the Bouncy Castle APIs

Supporting Bouncy Castle is now a substantial effort, the Java API is now over 300,000 lines, the C# one well past 140,000.

Bouncy Castle Java FIPS Downloads

Except where otherwise stated, this software is distributed under the regular Bouncy Castle license. For full details of other licenses involved, see Third party licenses

Distribution Files (JAR format)

The 2.1.0 release, BC-FJA 2.1.0 (Certificate #4943) , is certified for use on Java 8, Java 11, Java 17 and Java 21. The 2.1.1 release is a patch release on 2.1.0, going into submission. For differences see the release notes.

Note: as with the regular Java BC release, this distribution now has a bcutil jar containing classes that do not need to be in the certified provider jar. For most purposes you will need to include the bcutil jar in your application. Please see the release notes for details on this release.

The 2.0.0 release, BC-FJA 2.0.0 (Certificate #4743) , is certified for use on Java 8, Java 11, Java 17 and Java 21.

Note: as with the regular Java BC release, this distribution now has a bcutil jar containing classes that do not need to be in the certified provider jar. For most purposes you will need to include the bcutil jar in your application though. Other details on differences between the 1.0.2 series and the 2.0.0 can be found in the porting guide.

Checksums

To confirm the integrity of the distributions, checksums are available:

Download BC-FJA 1.0.2.4 Checksums

Download BC-FJA 2.0.0 Checksums

Download BC-FJA 2.1.0 Checksums

Maven Central Signing Key

If you are trying to confirm the signatures for artifacts from Maven Central, you can use the public key linked below.

Download bc_maven_public_key.asc

Release notes

Find out detailed information about the latest Bouncy Castle Java FIPS releases and search in older release notes.  

Release BC-FJA 2.0.1
21 August, 2025
Name: bc-fips-2.0.1.jar Defects Fixed CVE-2025-8885 Possible DOS in processing specially formed ASN.1 Object Identifiers – a size limit of 4096 bytes...

Name: bc-fips-2.0.1.jar

Defects Fixed

  • CVE-2025-8885 Possible DOS in processing specially formed ASN.1 Object Identifiers – a size limit of 4096 bytes has been placed on encoded ASN.1 OIDs. See the details in the NVD record: CVE-2025-8885.
  • PKCS#12 implementation now coded to always use the BCFIPS provider. This prevents occassional NoSuchAlgorithmExceptions where KeyStore.getInstance() is used to set the provider object to use.
  • The jar now contains OSGI details in the MANIFEST including multi-release information.
  • A potential compatibility issue around OCSP CertID using NULL or absent parameters has been addressed in order to prevent OCSP cache issues.
  • The module-info now includes the org.bouncycastle.asn1.cryptlib package.
  • The CipherInputStream class would sometimes fail on finalization for AEAD ciphers used in MAC-only mode due to not priming the cipher if there was no attempt to read. This has been fixed.
  • The BCFKS implementation will now recognise HMAC-SHA-3 and KMAC secret keys.
  • The jar now contains multiple checksums which will allow it to be used with jlink providing the JVM involved does not require signed providers. Note: this feature is not cleared as FIPS compliant (yet).