ホームページ バックエンド開発 Golang Go 言語の暗号化関数と復号化関数を学習し、対称暗号化アルゴリズムを実装します。

Go 言語の暗号化関数と復号化関数を学習し、対称暗号化アルゴリズムを実装します。

Jul 30, 2023 pm 01:46 PM
言語を移動 暗号化および復号化機能 対称暗号化アルゴリズム

Go 言語の暗号化および復号化関数を学習し、対称暗号化アルゴリズムを実装します

現代のインターネット時代では、データ セキュリティが特に重要です。機密データの安全な送信と保存を保証するために、暗号化と復号化は不可欠なコア操作です。 Go 言語は最新のプログラミング言語として、さまざまな暗号化および復号化関数を提供します。この記事では、Go 言語の一般的な暗号化および復号化関数を紹介し、サンプル コードを通じて対称暗号化アルゴリズムを実装します。

対称暗号化アルゴリズムとは、暗号化と復号化に同じキーを使用する暗号化アルゴリズムを指します。一般的な対称暗号化アルゴリズムには、DES、3DES、AES などが含まれます。 Go 言語では、crypto パッケージは対称暗号化アルゴリズムの実装を提供します。

まず、キーを生成する必要があります。 Go 言語では、crypto/rand パッケージを使用してランダムキーを生成できます。サンプル コードは次のとおりです。

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)
}
ログイン後にコピー

上記のコードは、crypto/rand パッケージの Read 関数を呼び出して 16 バイトのキーを生成し、出力します。

次に、生成されたキーを使用して、データの暗号化と復号化の操作を実行します。 crypto/cipher パッケージは Go 言語で提供され、さまざまな対称ブロック暗号の標準インターフェイスを定義します。

サンプル コードは次のとおりです。

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))
}
ログイン後にコピー

上記のコードでは、データを暗号化および復号化するための encrypt 関数と decrypt 関数を定義します。このうち、encrypt 関数はキーと平文をパラメータとして受け入れて暗号文を返し、decrypt 関数はキーと暗号文をパラメータとして受け入れて平文を返します。

main 関数では、以前に生成したキーと文字列を使用して暗号化し、結果を出力します。次に、キーと暗号文を使用して復号化し、結果を出力します。

このサンプル コードを通じて、Go 言語での対称暗号化アルゴリズムの基本的な実装原理と使用法を理解できます。もちろん、実際のアプリケーションでは、キーの安全な送信と保管、さらに複雑な暗号化と復号化のシナリオも考慮する必要があります。

以上がGo 言語の暗号化関数と復号化関数を学習し、対称暗号化アルゴリズムを実装します。の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

AI Hentai Generator

AI Hentai Generator

AIヘンタイを無料で生成します。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

GOの浮動小数点番号操作に使用されるライブラリは何ですか? GOの浮動小数点番号操作に使用されるライブラリは何ですか? Apr 02, 2025 pm 02:06 PM

GO言語の浮動小数点数操作に使用されるライブラリは、精度を確保する方法を紹介します...

Go's Crawler Collyのキュースレッドの問題は何ですか? Go's Crawler Collyのキュースレッドの問題は何ですか? Apr 02, 2025 pm 02:09 PM

Go Crawler Collyのキュースレッドの問題は、Go言語でColly Crawler Libraryを使用する問題を調査します。 �...

GO言語の「VAR」と「タイプ」キーワード定義構造の違いは何ですか? GO言語の「VAR」と「タイプ」キーワード定義構造の違いは何ですか? Apr 02, 2025 pm 12:57 PM

GO言語で構造を定義する2つの方法:VARとタイプのキーワードの違い。構造を定義するとき、GO言語はしばしば2つの異なる執筆方法を見ます:最初...

Goでは、Printlnとstring()関数を備えた文字列を印刷すると、なぜ異なる効果があるのですか? Goでは、Printlnとstring()関数を備えた文字列を印刷すると、なぜ異なる効果があるのですか? Apr 02, 2025 pm 02:03 PM

Go言語での文字列印刷の違い:printlnとstring()関数を使用する効果の違いはGOにあります...

GOのどのライブラリが大企業によって開発されていますか、それとも有名なオープンソースプロジェクトによって提供されていますか? GOのどのライブラリが大企業によって開発されていますか、それとも有名なオープンソースプロジェクトによって提供されていますか? Apr 02, 2025 pm 04:12 PM

大企業または有名なオープンソースプロジェクトによって開発されたGOのどのライブラリが開発されていますか? GOでプログラミングするとき、開発者はしばしばいくつかの一般的なニーズに遭遇します...

Redisストリームを使用してGO言語でメッセージキューを実装する場合、user_idタイプの変換の問題を解決する方法は? Redisストリームを使用してGO言語でメッセージキューを実装する場合、user_idタイプの変換の問題を解決する方法は? Apr 02, 2025 pm 04:54 PM

redisstreamを使用してGo言語でメッセージキューを実装する問題は、GO言語とRedisを使用することです...

Golandのカスタム構造ラベルが表示されない場合はどうすればよいですか? Golandのカスタム構造ラベルが表示されない場合はどうすればよいですか? Apr 02, 2025 pm 05:09 PM

Golandのカスタム構造ラベルが表示されない場合はどうすればよいですか?ゴーランドを使用するためにGolandを使用する場合、多くの開発者はカスタム構造タグに遭遇します...

GoおよびViperライブラリを使用するときにポインターを渡す必要があるのはなぜですか? GoおよびViperライブラリを使用するときにポインターを渡す必要があるのはなぜですか? Apr 02, 2025 pm 04:00 PM

ポインター構文とviperライブラリの使用における問題への取り組みGO言語でプログラミングするとき、特にポインターの構文と使用を理解することが重要です...

See all articles