1 DES加密原理和作用是什么-德赢Vwin官网 网
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

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表德赢Vwin官网 网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 加密
    +关注

    关注

    0

    文章

    304

    浏览量

    23914
  • DES
    DES
    +关注

    关注

    0

    文章

    64

    浏览量

    48215
  • 代码
    +关注

    关注

    30

    文章

    4779

    浏览量

    68516

原文标题:Golang DES 加解密

文章出处:【微信号:gh_3980db2283cd,微信公众号:开关电源芯片】欢迎添加关注!文章转载请注明出处。

收藏 人收藏

    评论

    相关推荐

    常见的加密算法有哪些?它们各自的优势是什么?

    在于其出色的安全性能和高效的实现方式,已成为目前最广泛使用的加密算法之一。它能够抵御暴力破解攻击,且在各种硬件和软件平台上都能实现高效的加密和解密操作。 DES(Data Encryption
    的头像 发表于 12-17 15:57 72次阅读

    云存储服务中的数据加密技术

    技术 对称加密技术是一种经典的加密方法,其特点是加密和解密使用相同的密钥。在云存储服务中,对称加密技术主要用于数据传输和存储过程中的加密。常
    的头像 发表于 10-28 15:04 420次阅读

    underfill胶水的作用是什么?

    underfill胶水的作用是什么?Underfill胶水,也称为底部填充胶,在电子半导体封装技术工艺中扮演着至关重要的角色。其作用主要体现在以下几个方面:加固与保护加固芯片连接:Underfill
    的头像 发表于 10-11 10:12 377次阅读
    underfill胶水的<b class='flag-5'>作用是</b>什么?

    大带宽服务器的作用是什么

    大带宽服务器在现代互联网应用中扮演着至关重要的角色,其作用主要体现在以下几个方面,rak小编为您整理发布大带宽服务器的作用是什么。
    的头像 发表于 09-26 10:01 164次阅读

    请问跟随器的具体作用是什么?

    请问跟随器的具体作用是什么,我知道电压放大倍数为零,那么他能改善什么性能?请专家解答
    发表于 09-19 07:35

    电容的滤波作用是什么原理

    电容的滤波作用是电子电路中非常常见的一种功能,其基本原理是通过电容对交流信号进行充电和放电,从而实现对信号的滤波。 一、电容滤波的基本原理 电容的基本特性 电容是一种能够存储电荷的电子元件,其
    的头像 发表于 08-28 10:15 1785次阅读

    pi调节器的作用是什么

    的基本概念 比例(P)调节:比例调节是PI调节器的基础,其作用是将输入信号与设定值之间的偏差进行比例放大,从而产生控制信号。比例调节的特点是响应速度快,但存在稳态误差。 积分(I)调节:积分调节的作用是消除比例调节中的稳态误差。通过将
    的头像 发表于 06-30 10:43 3492次阅读

    RF校准的作用是什么,是校准RF频率吗?

    RF校准的作用是什么,是校准RF频率吗?
    发表于 06-07 07:12

    示波器探头的作用是什么

    示波器探头的主要作用是将被测试电路的信号传递到示波器上进行分析。具体来说,示波器探头通过接触电路来读取电压信号,并将其传递给示波器,然后示波器会显示电压随时间变化的波形图。这样,人们就可以观察电信号的幅值、频率、相位等特征,从而对电路进行分析和调试。
    的头像 发表于 05-09 15:38 480次阅读

    AES加密协议是什么?AES加密协议的应用

    院(NIST)于2001年将其选定为新的联邦数据加密标准,以取代之前广泛使用的DES(Data Encryption Standard)。 基本特性 1、对称密钥加密
    的头像 发表于 04-15 15:34 849次阅读

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

    中性点接地的主要作用是确保电气系统的安全性、稳定性和可靠性,同时保护设备和人身安全。
    的头像 发表于 03-19 14:16 4008次阅读
    中性点接地的<b class='flag-5'>作用是</b>什么?

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

    什么是差速器?差速器的作用是什么? 差速器是一种机械装置,通常用于车辆的传动系统中,主要用于解决驱动力分配、转弯时轮胎间速度差异的问题。差速器具有非常重要的作用,使得车辆在转弯时能够更加平稳地行驶
    的头像 发表于 02-04 17:15 4775次阅读

    接触器的作用是什么 接触器的触点是什么材质

    接触器是一种电控制装置,用于控制电路的开关和断开。它主要由电磁铁和一对触点组成。当电磁铁受到电流激励时,会产生磁场,吸引或推动触点,使其闭合或断开电路。其作用是在电路中起到开关的功能,实现电气设备
    的头像 发表于 02-03 15:07 4303次阅读

    终端电阻的作用是什么

    终端电阻,又称为负载电阻或终止电阻,是电路中用于限制电流的一种元件。它通常安装在电路的末端,与负载并联连接。终端电阻的主要作用是减小回路中的电压降,提高电路的性能和稳定性。本文将对终端电阻的作用进行
    的头像 发表于 01-16 10:35 4235次阅读
    终端电阻的<b class='flag-5'>作用是</b>什么

    时钟芯片的作用是什么?

    时钟芯片是一种微型电子器件,其作用是在电子设备中提供精确的时间基准。它能够产生稳定的电子脉冲,用于同步和控制设备中的各种操作和功能。
    的头像 发表于 01-11 18:20 1341次阅读