精品国产人成在线_亚洲高清无码在线观看_国产在线视频国产永久2021_国产AV综合第一页一个的一区免费影院黑人_最近中文字幕MV高清在线视频

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

DES加密原理和作用是什么

開關電源芯片 ? 來源:CSDN博客 ? 作者:benben_2015 ? 2021-08-23 10:06 ? 次閱讀

【導讀】本文介紹了 DES 加密原理和作用,和 golang 中 DES 加密解密機制的相應實現。

概念理解

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

模式

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

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

優缺點:模式操作簡單;明文中的重復內容將在密文中表現出來,特別對于圖像數據和明文變化較少的數據;適于短報文的加密傳遞。

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

特點:同一個明文分組重復出現時產生不同的密文分組;加密函數的輸入是當前的明文分組和前一個密文分組的異或;每個明文分組的加密函數的輸入與明文分組之間不再有固定的關系;適合加密長消息。

填充方式

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

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

zeropadding填充字節的值都為0。

密碼

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

偏移量

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

輸出

加密后的字節在顯示時可以進行hex和base64編碼,hex是十六進制編碼,base64是一種基于64個可打印字符來標識二進制數據的方法。

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

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

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創建一個新的加密塊

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加密第一個塊,將其結果保存到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方式輸出。自己可以通過一些在線測試工具進行測試,看結果是否一致。

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包實現了多種加密算法,包括對稱加密和非對稱加密等。

package main

import (

“fmt”

“github.com/marspere/goencrypt”

func main() {

// key為12345678

// iv為空

// 采用ECB分組模式

// 采用pkcs5padding填充模式

// 輸出結果使用base64進行加密

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)

}

責任編輯:haq

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • 加密
    +關注

    關注

    0

    文章

    302

    瀏覽量

    23898
  • DES
    DES
    +關注

    關注

    0

    文章

    64

    瀏覽量

    48199
  • 代碼
    +關注

    關注

    30

    文章

    4748

    瀏覽量

    68356

原文標題:Golang DES 加解密

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

收藏 人收藏

    評論

    相關推薦

    云存儲服務中的數據加密技術

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

    大帶寬服務器的作用是什么

    大帶寬服務器在現代互聯網應用中扮演著至關重要的角色,其作用主要體現在以下幾個方面,rak小編為您整理發布大帶寬服務器的作用是什么。
    的頭像 發表于 09-26 10:01 ?139次閱讀

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

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

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

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

    RF校準的作用是什么,是校準RF頻率嗎?

    RF校準的作用是什么,是校準RF頻率嗎?
    發表于 06-07 07:12

    AES加密協議是什么?AES加密協議的應用

    院(NIST)于2001年將其選定為新的聯邦數據加密標準,以取代之前廣泛使用的DES(Data Encryption Standard)。 基本特性 1、對稱密鑰加密
    的頭像 發表于 04-15 15:34 ?764次閱讀

    中性點接地的作用是什么?

    中性點接地的主要作用是確保電氣系統的安全性、穩定性和可靠性,同時保護設備和人身安全。
    的頭像 發表于 03-19 14:16 ?3752次閱讀
    中性點接地的<b class='flag-5'>作用是</b>什么?

    什么是差速器?差速器的作用是什么?

    什么是差速器?差速器的作用是什么? 差速器是一種機械裝置,通常用于車輛的傳動系統中,主要用于解決驅動力分配、轉彎時輪胎間速度差異的問題。差速器具有非常重要的作用,使得車輛在轉彎時能夠更加平穩地行駛
    的頭像 發表于 02-04 17:15 ?4602次閱讀

    接觸器的作用是什么 接觸器的觸點是什么材質

    接觸器是一種電控制裝置,用于控制電路的開關和斷開。它主要由電磁鐵和一對觸點組成。當電磁鐵受到電流激勵時,會產生磁場,吸引或推動觸點,使其閉合或斷開電路。其作用是在電路中起到開關的功能,實現電氣設備
    的頭像 發表于 02-03 15:07 ?4069次閱讀

    終端電阻的作用是什么

    終端電阻,又稱為負載電阻或終止電阻,是電路中用于限制電流的一種元件。它通常安裝在電路的末端,與負載并聯連接。終端電阻的主要作用是減小回路中的電壓降,提高電路的性能和穩定性。本文將對終端電阻的作用進行
    的頭像 發表于 01-16 10:35 ?4036次閱讀
    終端電阻的<b class='flag-5'>作用是</b>什么

    時鐘芯片的作用是什么?

    時鐘芯片是一種微型電子器件,其作用是在電子設備中提供精確的時間基準。它能夠產生穩定的電子脈沖,用于同步和控制設備中的各種操作和功能。
    的頭像 發表于 01-11 18:20 ?1288次閱讀

    抗干擾磁環的原理與作用是什么呢?

    抗干擾磁環的原理與作用是什么呢? 抗干擾磁環是一種應用于電子設備中的磁性材料,它的作用是抑制或屏蔽電子設備中的干擾信號,確保設備的正常工作和性能穩定。本文將詳細介紹抗干擾磁環的原理、作用及其在
    的頭像 發表于 12-21 16:34 ?3365次閱讀

    ad7699評估板電路圖ADC BUFFERS中R46的作用是什么?R53與C58的作用是低通濾波嗎?

    ad7699評估板電路圖 ADC BUFFERS中 R46的作用是什么,R53與C58的作用是低通濾波嗎 ad7699評估板電路圖EXTERNAL REFERENCE OPTIONS中R26、C38、R28的作用是什么
    發表于 12-18 07:45

    php加密方式有哪些

    PHP加密方式有許多種,以下是一些常用的加密方式: 對稱加密 對稱加密算法使用相同的密鑰進行加密和解密。常見的對稱
    的頭像 發表于 12-04 15:32 ?627次閱讀

    JACK DETECTION引腳的作用是什么?可以檢測什么?

    這個引腳的作用是什么?可以檢測什么?
    發表于 11-29 07:40