https://github.com/dragonwell-project/alibaba-dragonwell-security-provider
Dragonwell Security Provider is a High Performance Java Security Provider (JSP) that implements parts of the Java JCE and JSSE. It uses Tongsuo to provide cryptographic primitives and Transport Layer Security (TLS) for Java applications on OpenJDK.
https://github.com/dragonwell-project/alibaba-dragonwell-security-provider
conscrypt high-performance rfc8998 sm2 sm3 sm4 tongsuo
Last synced: about 2 months ago
JSON representation
Dragonwell Security Provider is a High Performance Java Security Provider (JSP) that implements parts of the Java JCE and JSSE. It uses Tongsuo to provide cryptographic primitives and Transport Layer Security (TLS) for Java applications on OpenJDK.
- Host: GitHub
- URL: https://github.com/dragonwell-project/alibaba-dragonwell-security-provider
- Owner: dragonwell-project
- License: apache-2.0
- Created: 2023-02-21T09:10:36.000Z (over 2 years ago)
- Default Branch: main
- Last Pushed: 2023-09-20T06:22:30.000Z (about 2 years ago)
- Last Synced: 2025-07-02T17:45:17.093Z (4 months ago)
- Topics: conscrypt, high-performance, rfc8998, sm2, sm3, sm4, tongsuo
- Language: Java
- Homepage:
- Size: 22.7 MB
- Stars: 14
- Watchers: 4
- Forks: 8
- Open Issues: 8
-
Metadata Files:
- Readme: README.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
Awesome Lists containing this project
- awesome-java - Dragonwell Security Provider
README
Dragonwell Security Provider - A High Performance Java Security Provider
========================================Dragonwell Security Provider is a Java Security Provider (JSP) that implements parts of the Java
Cryptography Extension (JCE) and Java Secure Socket Extension (JSSE). It uses
[Tongsuo](https://github.com/Tongsuo-Project/Tongsuo) to provide cryptographic primitives and Transport Layer Security (TLS)
for Java applications on OpenJDK. See [the capabilities
documentation](CAPABILITIES.md) for detailed information on what is provided.Dragonwell Security Provider inherits from Google's project [Conscrypt](https://github.com/google/conscrypt). The core SSL engine has borrowed liberally from the [Netty](http://netty.io/) project and their
work on [netty-tcnative](http://netty.io/wiki/forked-tomcat-native.html), giving `Dragonwell Security Provider`
similar performance.In addition to supporting international mainstream en-decryption Algorithms and SSL/TLS protocols, Dragonwell Security Provider also provides support for China's ShangMi Algorithms [SM2](https://github.com/alipay/tls13-sm-spec/tree/master/sm-en-pdfs/sm2)/[SM3](https://github.com/alipay/tls13-sm-spec/tree/master/sm-en-pdfs/sm3)/[SM4](https://github.com/alipay/tls13-sm-spec/tree/master/sm-en-pdfs/sm4) and [RFC8998](https://datatracker.ietf.org/doc/html/rfc8998) TLS protocol.
Homepage:
github.com/dragonwell-project/alibaba-dragonwell-security-provider
Mailing List:
jeffery.wsj@alibaba-inc.com
Download
-------------
Dragonwell Security Provider supports **Java 8/11** OpenJDK. The build artifacts are available on Maven Central.### Download JARs
You can download
[the JARs](https://repo.maven.apache.org/maven2/com/alibaba/dragonwell/)
directly from the Maven repositories.### OpenJDK
#### Native Classifiers
The OpenJDK artifacts are platform-dependent since each embeds a native library for a particular
platform. We publish artifacts to Maven Central for the following platforms:Classifier | OS | Architecture
-----------| ------- | ---------------- |
linux-x86_64 | Linux | x86_64 (64-bit)
linux-aarch_64 | Linux | aarch_64 (64-bit)
osx-x86_64 | Mac | x86_64 (64-bit)
osx-aarch_64(M1) | Mac | aarch_64 (64-bit)#### Maven
Use the [os-maven-plugin](https://github.com/trustin/os-maven-plugin) to add the dependency:
```xml
kr.motd.maven
os-maven-plugin
1.4.1.Final
com.alibaba.dragonwell
security-native
1.0.0
${os.detected.classifier}```
#### Gradle
Use the [osdetector-gradle-plugin](https://github.com/google/osdetector-gradle-plugin)
(which is a wrapper around the os-maven-plugin) to add the dependency:```gradle
buildscript {
repositories {
mavenCentral()
}
dependencies {
classpath 'com.google.gradle:osdetector-gradle-plugin:1.4.0'
}
}// Use the osdetector-gradle-plugin
apply plugin: "com.google.osdetector"dependencies {
compile 'com.alibaba.dragonwell:security-native:1.0.0:' + osdetector.classifier
}
```#### Uber JAR
For convenience, we also publish an Uber JAR to Maven Central that contains the shared
libraries for all of the published platforms. While the overall size of the JAR is
larger than depending on a platform-specific artifact, it greatly simplifies the task of
dependency management for most platforms.To depend on the uber jar, simply use the `security-native-uber` artifacts.
##### Maven
```xmlcom.alibaba.dragonwell
security-native-uber
1.0.0```
##### Gradle
```gradle
dependencies {
compile 'com.alibaba.dragonwell:security-native-uber:1.0.0'
}
```How to Build
------------If you are making changes to Dragonwell Security Provider, see the [building
instructions](BUILDING.md).