Home Backend Development Golang Learn the encryption and decryption functions in Go language and implement asymmetric encryption algorithms

Learn the encryption and decryption functions in Go language and implement asymmetric encryption algorithms

Aug 01, 2023 pm 01:15 PM
go language Encryption and decryption functions asymmetric encryption algorithm

Learn the encryption and decryption functions in Go language and implement asymmetric encryption algorithms

In the modern information age, data security has become particularly important. To protect sensitive data from hackers and illegal visitors, encryption algorithms are widely used. Among them, asymmetric encryption algorithms are popular because of their high security. Go language is a powerful and concise programming language that provides us with a wealth of encryption and decryption functions to ensure data security.

This article will introduce the encryption and decryption functions in Go language and demonstrate how to implement asymmetric encryption algorithms through examples. We will use the RSA algorithm as an example to show how to generate public and private keys and how to use them for encryption and decryption.

First, we need to install the Go language and RSA library. After installing the Go language, you can use the following command to install the RSA library:

go get -u github.com/golang/crypto
Copy after login

After the installation is complete, we can start writing code. First, we will generate a public and private key pair. Note that the private key is used to decrypt data, while the public key is used to encrypt data. The following is a sample code to generate public and private keys:

package main

import (
    "crypto/rand"
    "crypto/rsa"
    "crypto/x509"
    "encoding/pem"
    "fmt"
    "os"
)

func main() {
    // 生成 RSA 密钥对
    privateKey, err := rsa.GenerateKey(rand.Reader, 2048)
    if err != nil {
        fmt.Println("Failed to generate private key:", err)
        return
    }

    // 将私钥保存到文件中
    privateKeyFile, err := os.Create("private.key")
    if err != nil {
        fmt.Println("Failed to create private key file:", err)
        return
    }
    defer privateKeyFile.Close()

    privateKeyBlock := &pem.Block{
        Type:  "RSA PRIVATE KEY",
        Bytes: x509.MarshalPKCS1PrivateKey(privateKey),
    }

    err = pem.Encode(privateKeyFile, privateKeyBlock)
    if err != nil {
        fmt.Println("Failed to encode private key:", err)
        return
    }

    // 将公钥保存到文件中
    publicKey := &privateKey.PublicKey
    publicKeyFile, err := os.Create("public.key")
    if err != nil {
        fmt.Println("Failed to create public key file:", err)
        return
    }
    defer publicKeyFile.Close()

    publicKeyBlock := &pem.Block{
        Type:  "RSA PUBLIC KEY",
        Bytes: x509.MarshalPKCS1PublicKey(publicKey),
    }

    err = pem.Encode(publicKeyFile, publicKeyBlock)
    if err != nil {
        fmt.Println("Failed to encode public key:", err)
        return
    }

    fmt.Println("Keys generated successfully!")
}
Copy after login

After running the above code, two files will be generated: "private.key" and "public.key". These two files save the private key and the public key respectively. It is very important to ensure the security of the private key, so the private key file needs to be properly kept in practical applications.

Next, we will write sample code for encryption and decryption. The following is an example of encryption using the generated public key:

package main

import (
    "crypto/rand"
    "crypto/rsa"
    "crypto/x509"
    "encoding/pem"
    "fmt"
    "io/ioutil"
    "os"
)

func main() {
    // 加载公钥文件
    publicKeyFile, err := os.Open("public.key")
    if err != nil {
        fmt.Println("Failed to open public key file:", err)
        return
    }
    defer publicKeyFile.Close()

    publicKeyData, err := ioutil.ReadAll(publicKeyFile)
    if err != nil {
        fmt.Println("Failed to read public key file:", err)
        return
    }

    publicKeyBlock, _ := pem.Decode(publicKeyData)
    if publicKeyBlock == nil {
        fmt.Println("Failed to decode public key")
        return
    }

    publicKey, err := x509.ParsePKCS1PublicKey(publicKeyBlock.Bytes)
    if err != nil {
        fmt.Println("Failed to parse public key:", err)
        return
    }

    // 加密数据
    plaintext := []byte("Hello, World!")
    ciphertext, err := rsa.EncryptPKCS1v15(rand.Reader, publicKey, plaintext)
    if err != nil {
        fmt.Println("Failed to encrypt data:", err)
        return
    }

    fmt.Printf("Ciphertext: %x
", ciphertext)
}
Copy after login

After running the above code, the encrypted ciphertext will be output.

Finally, let’s write a decryption example. The following is the sample code to decrypt the ciphertext using the private key:

package main

import (
    "crypto/rand"
    "crypto/rsa"
    "crypto/x509"
    "encoding/pem"
    "fmt"
    "io/ioutil"
    "os"
)

func main() {
    // 加载私钥文件
    privateKeyFile, err := os.Open("private.key")
    if err != nil {
        fmt.Println("Failed to open private key file:", err)
        return
    }
    defer privateKeyFile.Close()

    privateKeyData, err := ioutil.ReadAll(privateKeyFile)
    if err != nil {
        fmt.Println("Failed to read private key file:", err)
        return
    }

    privateKeyBlock, _ := pem.Decode(privateKeyData)
    if privateKeyBlock == nil {
        fmt.Println("Failed to decode private key")
        return
    }

    privateKey, err := x509.ParsePKCS1PrivateKey(privateKeyBlock.Bytes)
    if err != nil {
        fmt.Println("Failed to parse private key:", err)
        return
    }

    // 解密数据
    ciphertext := []byte{...} // 输入待解密的密文
    plaintext, err := rsa.DecryptPKCS1v15(rand.Reader, privateKey, ciphertext)
    if err != nil {
        fmt.Println("Failed to decrypt data:", err)
        return
    }

    fmt.Printf("Plaintext: %s
", plaintext)
}
Copy after login

In the above code, we read the private key from the file and use that private key to decrypt the ciphertext. Finally, we will get the original plaintext data.

Through the above example code, we can learn the encryption and decryption functions in the Go language and successfully implement the asymmetric encryption algorithm. Protecting data security is the responsibility of every programmer. With the powerful functions and library functions of the Go language, we can easily implement data encryption and decryption, adding higher security to our applications. I hope this article will be helpful to you in learning encryption and decryption functions and asymmetric encryption algorithms.

The above is the detailed content of Learn the encryption and decryption functions in Go language and implement asymmetric encryption algorithms. For more information, please follow other related articles on the PHP Chinese website!

Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

AI Hentai Generator

AI Hentai Generator

Generate AI Hentai for free.

Hot Article

R.E.P.O. Energy Crystals Explained and What They Do (Yellow Crystal)
4 weeks ago By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Best Graphic Settings
3 weeks ago By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. How to Fix Audio if You Can't Hear Anyone
4 weeks ago By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: How To Unlock Everything In MyRise
1 months ago By 尊渡假赌尊渡假赌尊渡假赌

Hot Tools

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor

SublimeText3 Chinese version

SublimeText3 Chinese version

Chinese version, very easy to use

Zend Studio 13.0.1

Zend Studio 13.0.1

Powerful PHP integrated development environment

Dreamweaver CS6

Dreamweaver CS6

Visual web development tools

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

What libraries are used for floating point number operations in Go? What libraries are used for floating point number operations in Go? Apr 02, 2025 pm 02:06 PM

The library used for floating-point number operation in Go language introduces how to ensure the accuracy is...

What is the problem with Queue thread in Go's crawler Colly? What is the problem with Queue thread in Go's crawler Colly? Apr 02, 2025 pm 02:09 PM

Queue threading problem in Go crawler Colly explores the problem of using the Colly crawler library in Go language, developers often encounter problems with threads and request queues. �...

In Go, why does printing strings with Println and string() functions have different effects? In Go, why does printing strings with Println and string() functions have different effects? Apr 02, 2025 pm 02:03 PM

The difference between string printing in Go language: The difference in the effect of using Println and string() functions is in Go...

What is the difference between `var` and `type` keyword definition structure in Go language? What is the difference between `var` and `type` keyword definition structure in Go language? Apr 02, 2025 pm 12:57 PM

Two ways to define structures in Go language: the difference between var and type keywords. When defining structures, Go language often sees two different ways of writing: First...

Which libraries in Go are developed by large companies or provided by well-known open source projects? Which libraries in Go are developed by large companies or provided by well-known open source projects? Apr 02, 2025 pm 04:12 PM

Which libraries in Go are developed by large companies or well-known open source projects? When programming in Go, developers often encounter some common needs, ...

How to solve the user_id type conversion problem when using Redis Stream to implement message queues in Go language? How to solve the user_id type conversion problem when using Redis Stream to implement message queues in Go language? Apr 02, 2025 pm 04:54 PM

The problem of using RedisStream to implement message queues in Go language is using Go language and Redis...

What should I do if the custom structure labels in GoLand are not displayed? What should I do if the custom structure labels in GoLand are not displayed? Apr 02, 2025 pm 05:09 PM

What should I do if the custom structure labels in GoLand are not displayed? When using GoLand for Go language development, many developers will encounter custom structure tags...

Why is it necessary to pass pointers when using Go and viper libraries? Why is it necessary to pass pointers when using Go and viper libraries? Apr 02, 2025 pm 04:00 PM

Go pointer syntax and addressing problems in the use of viper library When programming in Go language, it is crucial to understand the syntax and usage of pointers, especially in...

See all articles