Ketahui fungsi penyulitan dan penyahsulitan dalam bahasa Go dan laksanakan algoritma penyulitan simetri

王林
Lepaskan: 2023-07-30 13:46:55
asal
1322 orang telah melayarinya

Ketahui fungsi penyulitan dan penyahsulitan dalam bahasa Go dan laksanakan algoritma penyulitan simetri

Dalam era Internet moden, keselamatan data amat penting. Untuk memastikan penghantaran dan penyimpanan data sensitif yang selamat, penyulitan dan penyahsulitan adalah operasi teras yang penting. Sebagai bahasa pengaturcaraan moden, bahasa Go menyediakan pelbagai fungsi penyulitan dan penyahsulitan Artikel ini akan memperkenalkan fungsi penyulitan dan penyahsulitan biasa dalam bahasa Go dan melaksanakan algoritma penyulitan simetri melalui kod sampel.

Algoritma penyulitan simetri merujuk kepada algoritma penyulitan yang menggunakan kunci yang sama untuk penyulitan dan penyahsulitan. Algoritma penyulitan simetri biasa termasuk DES, 3DES, AES, dsb. Dalam bahasa Go, pakej crypto menyediakan pelaksanaan algoritma penyulitan simetri.

Pertama, kita perlu menjana kunci. Dalam bahasa Go, anda boleh menggunakan pakej crypto/rand untuk menjana kunci rawak. Kod sampel adalah seperti berikut:

package main

import (
    "crypto/rand"
    "fmt"
)

func generateKey() ([]byte, error) {
    key := make([]byte, 16) // 128位密钥
    _, err := rand.Read(key)
    if err != nil {
        return nil, err
    }
    return key, nil
}

func main() {
    key, err := generateKey()
    if err != nil {
        fmt.Println("密钥生成失败:", err)
        return
    }
    fmt.Println("生成的密钥:", key)
}
Salin selepas log masuk

Kod di atas menghasilkan kunci 16-bait dengan memanggil fungsi Baca pakej crypto/rand dan mencetaknya.

Seterusnya, kami menggunakan kunci yang dijana untuk melaksanakan operasi penyulitan dan penyahsulitan data. Pakej kripto/sifir disediakan dalam bahasa Go, yang mentakrifkan antara muka standard untuk pelbagai sifir blok simetri.

Kod sampel adalah seperti berikut:

package main

import (
    "crypto/aes"
    "crypto/cipher"
    "fmt"
)

func encrypt(key, plaintext []byte) ([]byte, error) {
    block, err := aes.NewCipher(key)
    if err != nil {
        return nil, err
    }
    iv := make([]byte, aes.BlockSize)
    stream := cipher.NewCTR(block, iv)
    ciphertext := make([]byte, len(plaintext))
    stream.XORKeyStream(ciphertext, plaintext)
    return ciphertext, nil
}

func decrypt(key, ciphertext []byte) ([]byte, error) {
    block, err := aes.NewCipher(key)
    if err != nil {
        return nil, err
    }
    iv := make([]byte, aes.BlockSize)
    stream := cipher.NewCTR(block, iv)
    plaintext := make([]byte, len(ciphertext))
    stream.XORKeyStream(plaintext, ciphertext)
    return plaintext, nil
}

func main() {
    key := []byte("1234567812345678") // 替换为之前生成的密钥
    plaintext := []byte("Hello, World!")

    ciphertext, err := encrypt(key, plaintext)
    if err != nil {
        fmt.Println("加密失败:", err)
        return
    }
    fmt.Println("加密后的数据:", ciphertext)

    decrypted, err := decrypt(key, ciphertext)
    if err != nil {
        fmt.Println("解密失败:", err)
        return
    }
    fmt.Println("解密后的数据:", string(decrypted))
}
Salin selepas log masuk

Dalam kod di atas, kami mentakrifkan fungsi penyulitan dan fungsi menyahsulit untuk menyulitkan dan menyahsulit data masing-masing. Antaranya, fungsi penyulitan menerima kunci dan teks biasa sebagai parameter dan mengembalikan teks sifir;

Dalam fungsi utama, kami menggunakan kunci yang dijana sebelum ini dan rentetan untuk menyulitkan dan mencetak hasilnya. Kemudian, gunakan kekunci dan teks sifir untuk menyahsulit, dan juga mencetak hasilnya.

Melalui kod sampel ini, kita boleh memahami prinsip pelaksanaan asas dan penggunaan algoritma penyulitan simetri dalam bahasa Go. Sudah tentu, dalam aplikasi praktikal, perlu juga mempertimbangkan penghantaran dan penyimpanan kunci yang selamat, serta senario penyulitan dan penyahsulitan yang lebih kompleks.

Atas ialah kandungan terperinci Ketahui fungsi penyulitan dan penyahsulitan dalam bahasa Go dan laksanakan algoritma penyulitan simetri. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

sumber:php.cn
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan