golang crypto aes 加密,解密示例

https://cyberspy.io/articles/crypto101/

加密:

package main

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

func main() {
        // The key argument should be the AES key, either 16 or 32 bytes
        // to select AES-128 or AES-256.
        key := []byte("0123456789ABCDEF")
        plaintext := []byte("Apple")

        block, err := aes.NewCipher(key)
        if err != nil {
                panic(err.Error())
        }

        nonce := make([]byte, 12)
        if false {
                if _, err := io.ReadFull(rand.Reader, nonce); err != nil {
                        panic(err.Error())
                }
        }

        fmt.Printf("nonce: %x\n", nonce)

        aesgcm, err := cipher.NewGCM(block)
        if err != nil {
                panic(err.Error())
        }

        ciphertext := aesgcm.Seal(nil, nonce, plaintext, nil)
        fmt.Printf("cipher:%x\n", ciphertext)
}

解密:

package main

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


func main (){

    key := []byte("0123456789ABCDEF")

        ciphertext, _ := hex.DecodeString("08f24c28f0fc9aef5812a35ce66235bc2488d6c29b")  //加密生成的結(jié)果

        nonce, _ := hex.DecodeString("000000000000000000000000") //加密用的nonce

        block, err := aes.NewCipher(key)
        if err != nil {
                panic(err.Error())
        }

        aesgcm, err := cipher.NewGCM(block)
        if err != nil {
                panic(err.Error())
        }

        plaintext, err := aesgcm.Open(nil, nonce, ciphertext, nil)
        if err != nil {
                panic(err.Error())
        }
    fmt.Println(string(plaintext))
}

跟蹤 tls(https) 代碼里面空执, server 和client 走的 就是 aes GCM奶栖。
nonce 應(yīng)該就是隨機(jī)數(shù)(random)

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末宣鄙,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子绸吸,更是在濱河造成了極大的恐慌设江,老刑警劉巖绣硝,帶你破解...
    沈念sama閱讀 212,222評論 6 493
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異甫菠,居然都是意外死亡寂诱,警方通過查閱死者的電腦和手機(jī)痰洒,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,455評論 3 385
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來泉粉,“玉大人榴芳,你說我怎么就攤上這事√直耍” “怎么了点骑?”我有些...
    開封第一講書人閱讀 157,720評論 0 348
  • 文/不壞的土叔 我叫張陵紧索,是天一觀的道長珠漂。 經(jīng)常有香客問我媳危,道長待笑,這世上最難降的妖魔是什么暮蹂? 我笑而不...
    開封第一講書人閱讀 56,568評論 1 284
  • 正文 為了忘掉前任荆陆,我火速辦了婚禮,結(jié)果婚禮上棠枉,老公的妹妹穿的比我還像新娘汹碱。我一直安慰自己荞估,他們只是感情好勘伺,可當(dāng)我...
    茶點故事閱讀 65,696評論 6 386
  • 文/花漫 我一把揭開白布冲茸。 她就那樣靜靜地躺著轴术,像睡著了一般。 火紅的嫁衣襯著肌膚如雪彼宠。 梳的紋絲不亂的頭發(fā)上凭峡,一...
    開封第一講書人閱讀 49,879評論 1 290
  • 那天,我揣著相機(jī)與錄音惭适,去河邊找鬼癞志。 笑死框产,一個胖子當(dāng)著我的面吹牛秉宿,可吹牛的內(nèi)容都是我干的描睦。 我是一名探鬼主播,決...
    沈念sama閱讀 39,028評論 3 409
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼爵卒!你這毒婦竟也來了钓株?” 一聲冷哼從身側(cè)響起轴合,我...
    開封第一講書人閱讀 37,773評論 0 268
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎奔坟,沒想到半個月后咳秉,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 44,220評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡炕舵,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,550評論 2 327
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了奸攻。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 38,697評論 1 341
  • 序言:一個原本活蹦亂跳的男人離奇死亡新思,死狀恐怖窄绒,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情位谋,我是刑警寧澤,帶...
    沈念sama閱讀 34,360評論 4 332
  • 正文 年R本政府宣布,位于F島的核電站钾挟,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏汤锨。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 40,002評論 3 315
  • 文/蒙蒙 一方椎、第九天 我趴在偏房一處隱蔽的房頂上張望琳疏。 院中可真熱鬧,春花似錦揽趾、人聲如沸篱瞎。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,782評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至测蘑,卻和暖如春勇蝙,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背翁锡。 一陣腳步聲響...
    開封第一講書人閱讀 32,010評論 1 266
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點兒被人妖公主榨干…… 1. 我叫王不留减细,地道東北人。 一個月前我還...
    沈念sama閱讀 46,433評論 2 360
  • 正文 我出身青樓怎憋,卻偏偏與公主長得像,于是被迫代替她去往敵國和親皂岔。 傳聞我的和親對象是個殘疾皇子躁垛,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 43,587評論 2 350

推薦閱讀更多精彩內(nèi)容