全国旗舰校区

不同学习城市 同样授课品质

北京

深圳

上海

广州

郑州

大连

武汉

成都

西安

杭州

青岛

重庆

长沙

哈尔滨

南京

太原

沈阳

合肥

贵阳

济南

下一个校区
就在你家门口
+
当前位置:首页  >  技术干货  >  详情

Golang中的加密与解密技术

来源:千锋教育
发布人:xqq
2023-12-23

推荐

在线提问>>

Golang中的加密与解密技术

在当今信息化时代,数据安全是一个非常重要的问题。为了保护敏感数据不被黑客和其他恶意用户访问,必须采取适当的加密和解密技术。Golang是现今最流行的编程语言之一,因此,本文将为您介绍Golang中的加密和解密技术。

1. 对称加密

对称加密是一种加密方法,它使用相同的密钥来加密和解密数据。Golang中的对称加密算法包括DES、3DES、AES等。下面是一个使用AES-256加密字符串的示例程序:

`go

package main

import (

"crypto/aes"

"crypto/cipher"

"crypto/rand"

"encoding/base64"

"io"

"log"

)

func encrypt(key byte, text byte) (string, error) {

block, err := aes.NewCipher(key)

if err != nil {

return "", err

}

b := base64.StdEncoding.EncodeToString(text)

ciphertext := make(byte, aes.BlockSize+len(b))

iv := ciphertext

if _, err := io.ReadFull(rand.Reader, iv); err != nil {

return "", err

}

cfb := cipher.NewCFBEncrypter(block, iv)

cfb.XORKeyStream(ciphertext, byte(b))

return base64.StdEncoding.EncodeToString(ciphertext), nil

}

func decrypt(key byte, text string) (string, error) {

block, err := aes.NewCipher(key)

if err != nil {

return "", err

}

ciphertext, err := base64.StdEncoding.DecodeString(text)

if err != nil {

return "", err

}

iv := ciphertext

ciphertext = ciphertext

cfb := cipher.NewCFBDecrypter(block, iv)

cfb.XORKeyStream(ciphertext, ciphertext)

data, err := base64.StdEncoding.DecodeString(string(ciphertext))

if err != nil {

return "", err

}

return string(data), nil

}

func main() {

key := byte("12345678901234567890123456789012")

text := byte("Hello, World!")

encrypted, err := encrypt(key, text)

if err != nil {

log.Fatal(err)

}

log.Println("Encrypted:", encrypted)

decrypted, err := decrypt(key, encrypted)

if err != nil {

log.Fatal(err)

}

log.Println("Decrypted:", decrypted)

}

2. 非对称加密非对称加密是一种加密方法,它使用一对密钥来加密和解密数据。其中一个密钥用于加密数据,另一个密钥用于解密数据。Golang中的非对称加密算法包括RSA、DSA等。下面是一个使用RSA加密文本文件的示例程序:`gopackage mainimport (    "bufio"    "crypto/rand"    "crypto/rsa"    "crypto/x509"    "encoding/pem"    "fmt"    "log"    "os")func generateKeys() (*rsa.PrivateKey, error) {    privateKey, err := rsa.GenerateKey(rand.Reader, 2048)    if err != nil {        return nil, err    }    return privateKey, nil}func encrypt(publicKey *rsa.PublicKey, message byte) (byte, error) {    ciphertext, err := rsa.EncryptPKCS1v15(rand.Reader, publicKey, message)    if err != nil {        return nil, err    }    return ciphertext, nil}func decrypt(privateKey *rsa.PrivateKey, ciphertext byte) (byte, error) {    message, err := rsa.DecryptPKCS1v15(rand.Reader, privateKey, ciphertext)    if err != nil {        return nil, err    }    return message, nil}func pemEncodePrivateKey(privateKey *rsa.PrivateKey) (byte, error) {    privateKeyBytes := x509.MarshalPKCS1PrivateKey(privateKey)    privateKeyPEMBlock := &pem.Block{        Type:  "RSA PRIVATE KEY",        Bytes: privateKeyBytes,    }    return pem.EncodeToMemory(privateKeyPEMBlock), nil}func pemEncodePublicKey(publicKey *rsa.PublicKey) (byte, error) {    publicKeyBytes, err := x509.MarshalPKIXPublicKey(publicKey)    if err != nil {        return nil, err    }    publicKeyPEMBlock := &pem.Block{        Type:  "RSA PUBLIC KEY",        Bytes: publicKeyBytes,    }    return pem.EncodeToMemory(publicKeyPEMBlock), nil}func main() {    privateKey, err := generateKeys()    if err != nil {        log.Fatal(err)    }    publicKey := &privateKey.PublicKey    privateKeyPEM, err := pemEncodePrivateKey(privateKey)    if err != nil {        log.Fatal(err)    }    publicKeyPEM, err := pemEncodePublicKey(publicKey)    if err != nil {        log.Fatal(err)    }    log.Println("*** Private Key ***")    log.Println(string(privateKeyPEM))    log.Println("*** Public Key ***")    log.Println(string(publicKeyPEM))    plaintextFile, err := os.Open("plaintext.txt")    if err != nil {        log.Fatal(err)    }    defer plaintextFile.Close()    ciphertextFile, err := os.Create("ciphertext.txt")    if err != nil {        log.Fatal(err)    }    defer ciphertextFile.Close()    scanner := bufio.NewScanner(plaintextFile)    for scanner.Scan() {        message := scanner.Bytes()        ciphertext, err := encrypt(publicKey, message)        if err != nil {            log.Fatal(err)        }        ciphertextFile.Write(ciphertext)        ciphertextFile.WriteString("\n")    }    if err := scanner.Err(); err != nil {        log.Fatal(err)    }}

总结

本文介绍了Golang中的加密和解密技术。对称加密使用相同的密钥来加密和解密数据,非对称加密使用一对密钥来加密和解密数据。我们还提供了使用AES和RSA加密和解密数据的示例程序。在使用加密和解密技术时,请务必小心处理密钥以及敏感数据,并确保加密和解密算法是安全和适当的。

相关文章

如何搭建防火墙提高网络安全性

网络钓鱼的新型攻击手法及对策

详解Golang的垃圾回收机制

Golang中的加密与解密技术

Golang实现的高性能数据库

开班信息 更多>>

课程名称
全部学科
咨询

HTML5大前端

Java分布式开发

Python数据分析

Linux运维+云计算

全栈软件测试

大数据+数据智能

智能物联网+嵌入式

网络安全

全链路UI/UE设计

Unity游戏开发

新媒体短视频直播电商

影视剪辑包装

游戏原画

    在线咨询 免费试学 教程领取