(Go) RSASSA-PSS Algorithm with SHA256 Hashing
RSA encrypt a SHA256 hash with OAEP padding. Note: This example requires Chilkat v11.0.0 or greater.
success := false
// This example requires the Chilkat API to have been previously unlocked.
// See Global Unlock Sample for sample code.
privkey := PrivateKey_Ref.html">chilkat.NewPrivateKey()
// Load the private key object from a PEM file.
// (To load from a PEM string, call LoadPem instead.)
success = privkey.LoadPemFile("somePath/myPrivateKey.pem")
if success == false {
fmt.Println(privkey.LastErrorText())
privkey.DisposePrivateKey()
return
}
rsa := Rsa_Ref.html">chilkat.NewRsa()
// Use RSA-PSS by setting PkcsPadding = false
rsa.SetPkcsPadding(false)
// Use SHA256
rsa.SetOaepHash("SHA-256")
rsa.UsePrivateKey(privkey)
// Generate a base64 signature.
rsa.SetEncodingMode("base64")
sigStr := rsa.SignStringENC("String to be signed","SHA-256")
if rsa.LastMethodSuccess() == false {
fmt.Println(rsa.LastErrorText())
privkey.DisposePrivateKey()
rsa.DisposeRsa()
return
}
fmt.Println("Signature: ", *sigStr)
privkey.DisposePrivateKey()
rsa.DisposeRsa()
|