chinese直男口爆体育生外卖, 99久久er热在这里只有精品99, 又色又爽又黄18禁美女裸身无遮挡, gogogo高清免费观看日本电视,私密按摩师高清版在线,人妻视频毛茸茸,91论坛 兴趣闲谈,欧美 亚洲 精品 8区,国产精品久久久久精品免费

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

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

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

DES加密原理和作用是什么

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

掃碼添加小助手

加入工程師交流群

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

概念理解

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

模式

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

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

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

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

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

填充方式

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

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

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

密碼

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

偏移量

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

輸出

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

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

加密模式采用ECB、填充方式采用pkcs5padding、密碼使用“12345678”,輸出時(shí)經(jīng)hex編碼。自己可以通過一些在線測(cè)試工具進(jìn)行測(cè)試,看結(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)建一個(gè)新的加密塊

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加密第一個(gè)塊,將其結(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”,輸出時(shí)以hex方式輸出。自己可以通過一些在線測(cè)試工具進(jìn)行測(cè)試,看結(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包實(shí)現(xiàn)了多種加密算法,包括對(duì)稱加密和非對(duì)稱加密等。

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)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • 加密
    +關(guān)注

    關(guān)注

    0

    文章

    319

    瀏覽量

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

    關(guān)注

    0

    文章

    66

    瀏覽量

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

    關(guān)注

    30

    文章

    4956

    瀏覽量

    73494

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

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

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

掃碼添加小助手

加入工程師交流群

    評(píng)論

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

    凌科芯安32位低功耗加密芯片LCS4110R介紹

    LCS4110R 32位IIC接口防盜版加密芯片,是我司研發(fā)的一款以32位安全芯片平臺(tái)為基礎(chǔ)的較低功耗加密產(chǎn)品,內(nèi)嵌LKCOS智能操作系統(tǒng),通訊速度最高可達(dá)400Kbps。支持DES/TDES
    的頭像 發(fā)表于 01-21 13:02 ?289次閱讀
    凌科芯安32位低功耗<b class='flag-5'>加密</b>芯片LCS4110R介紹

    請(qǐng)問GPIO在微控制器中的作用是什么?

    GPIO在微控制器中的作用是什么?
    發(fā)表于 12-25 06:46

    MOSFET在電源控制中的作用是什么?

    請(qǐng)問MOSFET在電源控制中的作用是什么?
    發(fā)表于 12-16 06:37

    NVIC中斷屏蔽的具體作用是什么?

    NVIC 中斷屏蔽的具體作用是什么?
    發(fā)表于 12-05 06:06

    DES加密運(yùn)算模塊結(jié)構(gòu)設(shè)計(jì)

    DES加密運(yùn)算模塊使用純組合邏輯完成初始IP置換、E擴(kuò)展置換、P盒置換和初始IP逆置換的設(shè)計(jì)。加以一個(gè)以keysel為選通信號(hào)的二選一選通器選擇置換結(jié)果,1為初始置換結(jié)果,0為中間結(jié)果,將輸入分為
    發(fā)表于 10-30 07:56

    DES算法分享——DES控制模塊架構(gòu)

    本設(shè)計(jì)的DES控制模塊是使用有限狀態(tài)機(jī)(FSM)實(shí)現(xiàn)的。FSM的現(xiàn)態(tài)是邊沿觸發(fā)的,根據(jù)rst_n復(fù)位信號(hào)和start啟動(dòng)信號(hào)進(jìn)行現(xiàn)態(tài)的賦值;次態(tài)邏輯設(shè)計(jì)是S0-S17的次態(tài)跳轉(zhuǎn);輸出邏輯設(shè)計(jì)是控制
    發(fā)表于 10-30 07:27

    DES輪密鑰產(chǎn)生模塊結(jié)構(gòu)設(shè)計(jì)

    DES輪密鑰產(chǎn)生模塊中的置換選擇PC-1、循環(huán)左移、置換選擇PC-2均采用assign語句實(shí)現(xiàn),配合一個(gè)二選一選通器和一個(gè)十六選一選通器實(shí)現(xiàn)。其中二選一選通器以mode模式判斷信號(hào)為選通信
    發(fā)表于 10-30 07:13

    加密算法的應(yīng)用

    的要求。常見的對(duì)稱加密算法包括DES、3DES、AES等。 對(duì)稱加密算法的基本原理是:將明文數(shù)據(jù)按照一定規(guī)則和密鑰進(jìn)行處理,生成密文數(shù)據(jù),解密時(shí)按照相同的規(guī)則和密鑰進(jìn)行處理,得到明
    發(fā)表于 10-24 08:03

    AES加密流程

    等領(lǐng)域。 在1997年,美國(guó)國(guó)家標(biāo)準(zhǔn)技術(shù)研究院(NIST)發(fā)起了一個(gè)密碼競(jìng)賽,以尋求一種新的高級(jí)加密標(biāo)準(zhǔn)來替代DES加密算法。經(jīng)過多輪的評(píng)選和篩選,Rijndael算法成為最終的勝者,并在2001年
    發(fā)表于 10-23 06:13

    rt_mq_recv函數(shù)中timeout作用是什么?

    的值,并不被使用。 請(qǐng)問下這部分代碼作用是什么了? /* message queue is empty */ while (mq-&gt;entry == 0
    發(fā)表于 09-29 06:27

    請(qǐng)問NUC505 中的 VMID 引腳的作用是什么?如何設(shè)計(jì)電路圖?

    NUC505 中的 VMID 引腳的作用是什么?如何設(shè)計(jì)電路圖?
    發(fā)表于 08-28 06:26

    harmony-utils之DES,DES加解密

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

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

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

    DLPC3439的中的3DR引腳的作用是什么?

    請(qǐng)問一下 1.DLPC3439的中的3DR引腳的作用是什么? 2.該引腳該如何配置?只要給它輸入一個(gè)高電平就可以了嗎? 3.對(duì)于雙控制器來說,是不是主控制器和從控制器的3DR引腳配置相同? 非常感謝
    發(fā)表于 02-24 08:28

    ads1174中的DIN腳的功能說是Daisy-chain,它的作用是什么?

    我看的ads1174中的DIN腳的功能說是Daisy-chain,也就是雛菊鏈的意思,請(qǐng)問他的作用是什么?求解答
    發(fā)表于 02-05 06:23