Golang : Encrypt and decrypt data with x509 crypto
This is a simple tutorial demonstrating how to encrypt and decrypt string data with Golang's crypto/x509
package. We will use the EncryptPEMBlock and DecryptPEMBlock functions.
The source code :
package main
import (
"fmt"
"crypto/rand"
"crypto/x509"
"os"
)
func main() {
blockType := "RSA PRIVATE KEY"
password := []byte("password")
// see http://golang.org/pkg/crypto/x509/#pkg-constants
cipherType := x509.PEMCipherAES256
EncryptedPEMBlock, err := x509.EncryptPEMBlock(rand.Reader,
blockType,
[]byte("secret message"),
password,
cipherType)
if err != nil {
fmt.Println(err)
os.Exit(1)
}
// check if encryption is successful or not
if !x509.IsEncryptedPEMBlock(EncryptedPEMBlock) {
fmt.Println("PEM Block is not encrypted!")
os.Exit(1)
}
if EncryptedPEMBlock.Type != blockType {
fmt.Println("Block type is wrong!")
os.Exit(1)
}
fmt.Printf("Encrypted block \n%v\n", EncryptedPEMBlock)
fmt.Printf("Encrypted Block Headers Info : %v\n", EncryptedPEMBlock.Headers)
DecryptedPEMBlock, err := x509.DecryptPEMBlock(EncryptedPEMBlock, password)
if err != nil {
fmt.Println(err)
os.Exit(1)
}
fmt.Printf("Decrypted block message is : \n%s\n", DecryptedPEMBlock)
}
Sample output :
Encrypted block &{RSA PRIVATE KEY map[Proc-Type:4,ENCRYPTED DEK-Info:AES-256-CBC,9f08b2afcf44a3115f8eacc78600a108] [133 90 249 15 68 167 149 212 114 250 51 248 47 5 137 144]}
Encrypted Block Headers Info : map[Proc-Type:4,ENCRYPTED DEK-Info:AES-256-CBC,9f08b2afcf44a3115f8eacc78600a108]
Decrypted block message is : secret message
See also : Golang : Create x509 certificate, private and public keys
By Adam Ng
IF you gain some knowledge or the information here solved your programming problem. Please consider donating to the less fortunate or some charities that you like. Apart from donation, planting trees, volunteering or reducing your carbon footprint will be great too.
Advertisement
Tutorials
+14.1k Golang : Get uploaded file name or access uploaded files
+14.4k Golang : Convert(cast) int to float example
+22.8k Golang : Calculate time different
+13.3k Facebook PHP getUser() returns 0
+33.9k Golang : Create x509 certificate, private and public keys
+7.3k Golang : Process json data with Jason package
+22k Golang : Match strings by wildcard patterns with filepath.Match() function
+5k Golang : Customize scanner.Scanner to treat dash as part of identifier
+20.4k Golang : Secure(TLS) connection between server and client
+14.2k Golang : How to pass map to html template and access the map's elements
+6.8k Golang : How to setup a disk space used monitoring service with Telegram bot
+10.4k RPM : error: db3 error(-30974) from dbenv->failchk: DB_RUNRECOVERY: Fatal error, run database recovery