OpenSSL RSA Encryption, Decryption, and Key Generation. Java, Php GoLang Support, Large Data Support.
Make sure openssl
extension is enabled.
Just copy php/src/XRsa.php
and php/src/helpers.php
to your project. Alternatively, you can use composer to install:
composer require liamylian/x-rsa
Make sure your golang version is greater than 1.10.3
.
Just Copy golang/xrsa/xrsa.go
to your project, or use command:
go get github.com/liamylian/x-rsa
Just Copy XRsa.java
to your project
$keys = XRsa::createKeys(2048);
$rsa = new XRsa($keys['publicKey'], $keys['privateKey']);
$data = "Hello, World";
$encrypted = $rsa->publicEncrypt($data);
$decrypted = $rsa->privateDecrypt($encrypted);
$sign = $rsa->sign($data);
$is_valid = $rsa->verify($data, $sign);
var publicKey *bytes.Buffer = bytes.NewBufferString("")
var privateKey *bytes.Buffer = bytes.NewBufferString("")
var xrsa *XRsa
err := CreateKeys(publicKey, privateKey, 2048)
if err != nil {
return
}
xrsa, err = NewXRsa(publicKey.Bytes(), privateKey.Bytes())
if err != nil {
return
}
data := "Hello, World"
encrypted, _ := xrsa.PublicEncrypt(data)
decrypted, _ := xrsa.PrivateDecrypt(encrypted)
$sign = $rsa->Sign(data);
$is_valid = $rsa->Verify(data, sign);
Map<String, String> keys = XRsa.createKeys(2048);
XRsa rsa = new XRsa(keys.get("publicKey"), keys.get("privateKey"));
String data = "hello world";
String encrypted = rsa.publicEncrypt(data);
String decrypted = rsa.privateDecrypt(encrypted);
String sign = rsa.sign(data);
Boolean isValid = rsa.verify(data, sign);