99精品伊人亚洲|最近国产中文炮友|九草在线视频支援|AV网站大全最新|美女黄片免费观看|国产精品资源视频|精彩无码视频一区|91大神在线后入|伊人终合在线播放|久草综合久久中文

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

DES加密原理和作用是什么

開關(guān)電源芯片 ? 來源:CSDN博客 ? 作者:benben_2015 ? 2021-08-23 10:06 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

【導(dǎo)讀】本文介紹了 DES 加密原理和作用,和 golang 中 DES 加密解密機制的相應(yīng)實現(xiàn)。

概念理解

DES是以64比特的明文為一個單位來進(jìn)行加密,并生成64比特的密文。由于它每次只能處理特定長度的一塊數(shù)據(jù),所以DES屬于分組密碼算法。cypto/des包提供了有關(guān)des加密的功能。

模式

由于分組密碼算法只能加密固定長度的分組,所以當(dāng)加密的明文超過分組密碼的長度時,就需要對分組密碼算法進(jìn)行迭代,而迭代的方法就稱為分組密碼的模式。模式主要有ECB(電子密碼本)、CBC(密碼分組鏈接模式)、CTR(計數(shù)器模式)、OFB(輸出反饋模式)、CFB(密碼反饋模式)五種。下面簡單介紹下前兩種:

ECB(electronic code book)是最簡單的方式,它將明文分組加密后的結(jié)果直接成為密文分組。

優(yōu)缺點:模式操作簡單;明文中的重復(fù)內(nèi)容將在密文中表現(xiàn)出來,特別對于圖像數(shù)據(jù)和明文變化較少的數(shù)據(jù);適于短報文的加密傳遞。

CBC(cipher block chaining)的原理是加密算法的輸入是當(dāng)前的明文分組和前一密文分組的異或,第一個明文分組和一個初始向量進(jìn)行異或,這樣同一個明文分組重復(fù)出現(xiàn)時會產(chǎn)生不同的密文分組。

特點:同一個明文分組重復(fù)出現(xiàn)時產(chǎn)生不同的密文分組;加密函數(shù)的輸入是當(dāng)前的明文分組和前一個密文分組的異或;每個明文分組的加密函數(shù)的輸入與明文分組之間不再有固定的關(guān)系;適合加密長消息。

填充方式

在按8個字節(jié)對DES進(jìn)行加密或解密時,如果最后一段字節(jié)不足8位,就需要對數(shù)據(jù)進(jìn)行補位。即使加密或解密的數(shù)據(jù)剛好是8的倍數(shù)時,也會再補8位。舉個栗子,如果末尾剛好出現(xiàn)1,這時你就無法判斷這個1是原來數(shù)據(jù),還是經(jīng)過補位得到的1。因此,可以再補8位進(jìn)行標(biāo)識。填充方式主要有以下幾種:pkcs7padding、pkcs5padding、zeropadding、iso10126、ansix923。

pkcs7padding和pkcs5padding的填充方式相同,填充字節(jié)的值都等于填充字節(jié)的個數(shù)。例如需要填充4個字節(jié),則填充的值為“4 4 4 4”。

zeropadding填充字節(jié)的值都為0。

密碼

DES的密鑰長度是64比特,但由于每隔7個比特會設(shè)置一個用于錯誤檢測的比特,因此其實質(zhì)密鑰長度為56比特。

偏移量

上面模式中,例如CBC,再加密第一個明文分組時,由于不存在“前一個密文分組”,因此需要事先準(zhǔn)備一個長度為一個分組的比特序列來代替“前一個密文分組”,這個比特序列成為初始化向量,也稱偏移量,通常縮寫為IV。一般來說,每次加密時都會隨機產(chǎn)生一個不同的比特序列來作為初始化向量。偏移量的長度必須和塊的大小相同。

輸出

加密后的字節(jié)在顯示時可以進(jìn)行hex和base64編碼,hex是十六進(jìn)制編碼,base64是一種基于64個可打印字符來標(biāo)識二進(jìn)制數(shù)據(jù)的方法。

下面以上面提到的幾種模式和填充方式為例,進(jìn)行演示如何在代碼中使用。

加密模式采用ECB、填充方式采用pkcs5padding、密碼使用“12345678”,輸出時經(jīng)hex編碼。自己可以通過一些在線測試工具進(jìn)行測試,看結(jié)果是否一致。

package main

import (

“crypto/des”

“qiniupkg.com/x/errors.v7”

“bytes”

“fmt”

“encoding/hex”

func main() {

data:=[]byte(“hello world”)

key:=[]byte(“12345678”)

result,err:=DesECBEncrypt(data,key)

if err != nil {

fmt.Println(err)

}

a:=hex.EncodeToString(result)

fmt.Println(a)

}

func DesECBEncrypt(data, key []byte) ([]byte, error) {

//NewCipher創(chuàng)建一個新的加密塊

block, err := des.NewCipher(key)

if err != nil {

return nil, err

}

bs := block.BlockSize()

data = Pkcs5Padding(data, bs)

if len(data)%bs != 0 {

return nil, errors.New(“need a multiple of the blocksize”)

}

out := make([]byte, len(data))

dst := out

for len(data) 》 0 {

//Encrypt加密第一個塊,將其結(jié)果保存到dst

block.Encrypt(dst, data[:bs])

data = data[bs:]

dst = dst[bs:]

}

return out, nil

}

func Pkcs5Padding(ciphertext []byte, blockSize int) []byte {

padding := blockSize - len(ciphertext)%blockSize

padtext := bytes.Repeat([]byte{byte(padding)}, padding)

return append(ciphertext, padtext.。.)

}

下面加密模式采用CBC、填充方式采用pkcs5padding、密碼使用“12345678”、偏移量“43218765”,輸出時以hex方式輸出。自己可以通過一些在線測試工具進(jìn)行測試,看結(jié)果是否一致。

package main

import (

“crypto/des”

“bytes”

“fmt”

“encoding/hex”

“crypto/cipher”

func main() {

data := []byte(“hello world”)

key := []byte(“12345678”)

iv := []byte(“43218765”)

result, err := DesCBCEncrypt(data, key, iv)

if err != nil {

fmt.Println(err)

}

b := hex.EncodeToString(result)

fmt.Println(b)

}

func DesCBCEncrypt(data, key, iv []byte) ([]byte, error) {

block, err := des.NewCipher(key)

if err != nil {

return nil, err

}

data = pkcs5Padding(data, block.BlockSize())

cryptText := make([]byte, len(data))

blockMode := cipher.NewCBCEncrypter(block, iv)

blockMode.CryptBlocks(cryptText, data)

return cryptText, nil

}

func pkcs5Padding(cipherText []byte, blockSize int) []byte {

padding := blockSize - len(cipherText)%blockSize

padText := bytes.Repeat([]byte{byte(padding)}, padding)

return append(cipherText, padText.。.)

}

第三方包

github.com/marspere/goencrypt包實現(xiàn)了多種加密算法,包括對稱加密和非對稱加密等。

package main

import (

“fmt”

“github.com/marspere/goencrypt”

func main() {

// key為12345678

// iv為空

// 采用ECB分組模式

// 采用pkcs5padding填充模式

// 輸出結(jié)果使用base64進(jìn)行加密

cipher := goencrypt.NewDESCipher([]byte(“12345678”), []byte(“”), goencrypt.ECBMode, goencrypt.Pkcs5, goencrypt.PrintBase64)

cipherText, err := cipher.DESEncrypt([]byte(“hello world”))

if err != nil {

fmt.Println(err)

return

}

fmt.Println(cipherText)

}

責(zé)任編輯:haq

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • 加密
    +關(guān)注

    關(guān)注

    0

    文章

    317

    瀏覽量

    24390
  • DES
    DES
    +關(guān)注

    關(guān)注

    0

    文章

    65

    瀏覽量

    48736
  • 代碼
    +關(guān)注

    關(guān)注

    30

    文章

    4900

    瀏覽量

    70758

原文標(biāo)題:Golang DES 加解密

文章出處:【微信號:gh_3980db2283cd,微信公眾號:開關(guān)電源芯片】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關(guān)推薦
    熱點推薦

    harmony-utils之DESDES加解密

    harmony-utils之DES,DES加解密 harmony-utils 簡介與說明 [harmony-utils]一款功能豐富且極易上手的HarmonyOS工具庫,借助眾多實用工具類,致力于
    的頭像 發(fā)表于 06-30 17:16 ?122次閱讀

    進(jìn)行濾波器的諧波測試,它的作用是什么呢

    進(jìn)行濾波器的諧波測試,它的作用是什么呢,沒理解?測三個頻點來看它超過規(guī)定值沒
    發(fā)表于 06-23 19:19

    STM32配合可編程加密芯片SMEC88ST的防抄板加密方案設(shè)計

    SEMC88ST與STM32配的的各種加密功能說明,具體可參見SMEC88ST SDK開發(fā)包。 注: ①STM32與SMEC88ST間的I2C協(xié)議指令接口規(guī)則開發(fā)者自定義。 ②上述加解密密鑰均為對稱DES
    發(fā)表于 12-27 13:03

    【RA-Eco-RA4E2-64PIN-V1.0開發(fā)板試用】RA4E2使用之DES加密解密

    命科學(xué)醫(yī)用電子儀器設(shè)備,自能駕駛汽車應(yīng)用上,黑客入侵會導(dǎo)致威脅生命安全的危害事件發(fā)生。 加密和解密變得越來越重要,隨著物聯(lián)網(wǎng)和車聯(lián)網(wǎng)的迅速崛起,信息安全變成一種新型的科研方向。本文就是以DES加密和解密算法
    發(fā)表于 12-23 19:00

    常見的加密算法有哪些?它們各自的優(yōu)勢是什么?

    在于其出色的安全性能和高效的實現(xiàn)方式,已成為目前最廣泛使用的加密算法之一。它能夠抵御暴力破解攻擊,且在各種硬件和軟件平臺上都能實現(xiàn)高效的加密和解密操作。 DES(Data Encryption
    的頭像 發(fā)表于 12-17 15:57 ?1023次閱讀

    京準(zhǔn)電鐘:GPS北斗衛(wèi)星時間同步裝置作用是什么?

    京準(zhǔn)電鐘:GPS北斗衛(wèi)星時間同步裝置作用是什么?
    的頭像 發(fā)表于 11-26 15:57 ?496次閱讀
    京準(zhǔn)電鐘:GPS北斗衛(wèi)星時間同步裝置<b class='flag-5'>作用是</b>什么?

    云存儲服務(wù)中的數(shù)據(jù)加密技術(shù)

    技術(shù) 對稱加密技術(shù)是一種經(jīng)典的加密方法,其特點是加密和解密使用相同的密鑰。在云存儲服務(wù)中,對稱加密技術(shù)主要用于數(shù)據(jù)傳輸和存儲過程中的加密。常
    的頭像 發(fā)表于 10-28 15:04 ?1232次閱讀

    underfill膠水的作用是什么?

    underfill膠水的作用是什么?Underfill膠水,也稱為底部填充膠,在電子半導(dǎo)體封裝技術(shù)工藝中扮演著至關(guān)重要的角色。其作用主要體現(xiàn)在以下幾個方面:加固與保護加固芯片連接:Underfill
    的頭像 發(fā)表于 10-11 10:12 ?1312次閱讀
    underfill膠水的<b class='flag-5'>作用是</b>什么?

    PCM6240 AC-Coupled 偏置電阻的作用是什么

    請問一下,關(guān)于PCM6240 AC-Coupled Single-Ended Input Connection中,偏置電阻R0的作用是將INP和INM偏置到合適的Common-mode
    發(fā)表于 10-08 08:32

    大帶寬服務(wù)器的作用是什么

    大帶寬服務(wù)器在現(xiàn)代互聯(lián)網(wǎng)應(yīng)用中扮演著至關(guān)重要的角色,其作用主要體現(xiàn)在以下幾個方面,rak小編為您整理發(fā)布大帶寬服務(wù)器的作用是什么。
    的頭像 發(fā)表于 09-26 10:01 ?396次閱讀

    請問跟隨器的具體作用是什么?

    請問跟隨器的具體作用是什么,我知道電壓放大倍數(shù)為零,那么他能改善什么性能?請專家解答
    發(fā)表于 09-19 07:35

    二極管在電子設(shè)備中的作用是什么?

    二極管在電子設(shè)備中的作用是什么?
    的頭像 發(fā)表于 08-29 11:32 ?1190次閱讀
    二極管在電子設(shè)備中的<b class='flag-5'>作用是</b>什么?

    電容的濾波作用是什么原理

    電容的濾波作用是電子電路中非常常見的一種功能,其基本原理是通過電容對交流信號進(jìn)行充電和放電,從而實現(xiàn)對信號的濾波。 一、電容濾波的基本原理 電容的基本特性 電容是一種能夠存儲電荷的電子元件,其
    的頭像 發(fā)表于 08-28 10:15 ?4363次閱讀

    請問電路中電容C8的作用是什么呢?

    上面這個電路中電容C8的作用是什么呢?下面電路去掉這個電容之后仿真就不一樣了,幫忙解答一下,謝謝啦
    發(fā)表于 08-21 08:24

    TIPD122設(shè)計中,U8的作用是什么?

    TIPD122設(shè)計中,U8的作用是什么?為什么Vin從U8的IN+引入?
    發(fā)表于 07-31 06:12