Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/rtyley/spongycastle
Spongy Castle - a repackage of Bouncy Castle for Android (which ships a crippled version of BC)
https://github.com/rtyley/spongycastle
android cryptography
Last synced: 3 months ago
JSON representation
Spongy Castle - a repackage of Bouncy Castle for Android (which ships a crippled version of BC)
- Host: GitHub
- URL: https://github.com/rtyley/spongycastle
- Owner: rtyley
- License: mit
- Fork: true (bcgit/bc-java)
- Created: 2013-12-07T18:15:13.000Z (almost 11 years ago)
- Default Branch: spongy-master
- Last Pushed: 2022-09-14T09:54:01.000Z (about 2 years ago)
- Last Synced: 2024-07-01T10:51:57.344Z (4 months ago)
- Topics: android, cryptography
- Language: Java
- Homepage: https://rtyley.github.io/spongycastle/
- Size: 41.8 MB
- Stars: 685
- Watchers: 54
- Forks: 142
- Open Issues: 38
-
Metadata Files:
- Readme: README.md
- Contributing: .github/contributing.md
- License: LICENSE.html
Awesome Lists containing this project
README
# The Bouncy Castle Crypto Package For Java
The Bouncy Castle Crypto package is a Java implementation of cryptographic algorithms, it was developed by the Legion of the Bouncy Castle, a registered Australian Charity, with a little help! The Legion, and the latest goings on with this package, can be found at [http://www.bouncycastle.org](http://www.bouncycastle.org).
The Legion also gratefully acknowledges the contributions made to this package by others (see [here](http://www.bouncycastle.org/contributors.html) for the current list). If you would like to contribute to our efforts please feel free to get in touch with us or visit our [donations page](https://www.bouncycastle.org/donate), sponsor some specific work, or purchase a support contract through [Crypto Workshop](http://www.cryptoworkshop.com).
The package is organised so that it contains a light-weight API suitable for use in any environment (including the newly released J2ME) with the additional infrastructure to conform the algorithms to the JCE framework.
Except where otherwise stated, this software is distributed under a license based on the MIT X Consortium license. To view the license, [see here](http://www.bouncycastle.org/licence.html). The OpenPGP library also includes a modified BZIP2 library which is licensed under the [Apache Software License, Version 2.0](http://www.apache.org/licenses/).
**Note**: this source tree is not the FIPS version of the APIs - if you are interested in our FIPS version please contact us directly at [[email protected]](mailto:[email protected]).
## Code Organisation
The clean room JCE, for use with JDK 1.1 to JDK 1.3 is in the jce/src/main/java directory.
The **core** module provides all the functionality in the ligthweight APIs.
The **prov** module provides all the JCA/JCE provider functionality.
The **pkix** module is the home for code for X.509 certificate generation and the APIs for standards that rely on ASN.1 such
as CMS, TSP, PKCS#12, OCSP, CRMF, and CMP.The **mail** module provides an S/MIME API built on top of CMS.
The **pg** module is the home for code used to support OpenPGP.
The **tls** module is the home for code used to a general TLS API and JSSE Provider (as at 1.56 this should be considered a beta).
The build scripts that come with the full distribution allow creation of the different releases by using the different source trees while excluding classes that are not appropriate and copying in the required compatibility classes from the directories containing compatibility classes appropriate for the distribution.
If you want to try create a build for yourself, using your own environment, the best way to do it is to start with the build for the distribution you are interested in, make sure that builds, and then modify your build scripts to do the required exclusions and file copies for your setup, otherwise you are likely to get class not found exceptions. The final caveat to this is that as the j2me distribution includes some compatibility classes starting in the java package, you need to use an obfuscator to change the package names before attempting to import a midlet using the BC API.
## Examples and Tests
To view some examples, look at the test programs in the packages:
* **org.bouncycastle.crypto.test**
* **org.bouncycastle.jce.provider.test**
* **org.bouncycastle.cms.test**
* **org.bouncycastle.mail.smime.test**
* **org.bouncycastle.openpgp.test**
* **org.bouncycastle.tsp.test**
There are also some specific example programs for dealing with SMIME and OpenPGP. They can be found in:
* **org.bouncycastle.mail.smime.examples**
* **org.bouncycastle.openpgp.examples**
## Mailing Lists
For those who are interested, there are 2 mailing lists for participation in this project. To subscribe use the links below and include the word subscribe in the message body. (To unsubscribe, replace **subscribe** with **unsubscribe** in the message body)
* [[email protected]](mailto:[email protected])
This mailing list is for new release announcements only, general subscribers cannot post to it.
* [[email protected]](mailto:[email protected])
This mailing list is for discussion of development of the package. This includes bugs, comments, requests for enhancements, questions about use or operation.**NOTE:**You need to be subscribed to send mail to the above mailing list.
## Feedback
If you want to provide feedback directly to the members of **The Legion** then please use [[email protected]](mailto:[email protected]), if you want to help this project survive please consider [donating](https://www.bouncycastle.org/donate).
For bug reporting/requests you can report issues here on github, via feedback-crypto if required, and we also have a [Jira issue tracker](http://www.bouncycastle.org/jira). We will accept pull requests based on this repository as well.
## Finally
Enjoy!