概念理解

DES是以64比特的明文为一个单位来进行加密,并生成64比特的密文。由于它每次只能处理特定长度的一块数据,所以DES属于分组密码算法。cypto/des包提供了有关des加密的功能。

模式

由于分组密码算法只能加密固定长度的分组,所以当加密的明文超过分组密码的长度时,就需要对分组密码算法进行迭代,而迭代的方法就称为分组密码的模式。模式主要有ECB(电子密码本)、CBC(密码分组链接模式)、CTR(计数器模式)、OFB(输出反馈模式)、CFB(密码反馈模式)五种。下面简单介绍下前两种:

  1. ECB(electronic code book)是最简单的方式,它将明文分组加密后的结果直接成为密文分组。
    优缺点:模式操作简单;明文中的重复内容将在密文中表现出来,特别对于图像数据和明文变化较少的数据;适于短报文的加密传递。
  2. CBC(cipher block chaining)的原理是加密算法的输入是当前的明文分组和前一密文分组的异或,第一个明文分组和一个初始向量进行异或,这样同一个明文分组重复出现时会产生不同的密文分组。
    特点:同一个明文分组重复出现时产生不同的密文分组;加密函数的输入是当前的明文分组和前一个密文分组的异或;每个明文分组的加密函数的输入与明文分组之间不再有固定的关系;适合加密长消息。

填充方式

在按8个字节对DES进行加密或解密时,如果最后一段字节不足8位,就需要对数据进行补位。即使加密或解密的数据刚好是8的倍数时,也会再补8位。举个栗子,如果末尾刚好出现1,这时你就无法判断这个1是原来数据,还是经过补位得到的1。因此,可以再补8位进行标识。填充方式主要有以下几种:pkcs7padding、pkcs5padding、zeropadding、iso10126、ansix923。

  1. pkcs7padding和pkcs5padding的填充方式相同,填充字节的值都等于填充字节的个数。例如需要填充4个字节,则填充的值为"4 4 4 4"。
  2. zeropadding填充字节的值都为0。

密码

DES的密钥长度是64比特,但由于每隔7个比特会设置一个用于错误检测的比特,因此其实质密钥长度为56比特。

偏移量

上面模式中,例如CBC,再加密第一个明文分组时,由于不存在“前一个密文分组”,因此需要事先准备一个长度为一个分组的比特序列来代替“前一个密文分组”,这个比特序列成为初始化向量,也称偏移量,通常缩写为IV。一般来说,每次加密时都会随机产生一个不同的比特序列来作为初始化向量。偏移量的长度必须和块的大小相同。

输出

加密后的字节在显示时可以进行hex和base64编码,hex是十六进制编码,base64是一种基于64个可打印字符来标识二进制数据的方法。

下面以上面提到的几种模式和填充方式为例,进行演示如何在代码中使用。

加密模式采用ECB、填充方式采用pkcs5padding、密码使用"12345678",输出时经hex编码。自己可以通过一些在线测试工具进行测试,看结果是否一致。

package mainimport ("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 := outfor len(data) > 0 {//Encrypt加密第一个块,将其结果保存到dstblock.Encrypt(dst, data[:bs])data = data[bs:]dst = dst[bs:]}return out, nil
}func Pkcs5Padding(ciphertext []byte, blockSize int) []byte {padding := blockSize - len(ciphertext)%blockSizepadtext := bytes.Repeat([]byte{byte(padding)}, padding)return append(ciphertext, padtext...)
}

下面加密模式采用CBC、填充方式采用pkcs5padding、密码使用"12345678"、偏移量"43218765",输出时以hex方式输出。自己可以通过一些在线测试工具进行测试,看结果是否一致。

package mainimport ("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)%blockSizepadText := bytes.Repeat([]byte{byte(padding)}, padding)return append(cipherText, padText...)
}

第三方包

github.com/marspere/goencrypt包实现了多种加密算法,包括对称加密和非对称加密等。

package mainimport ("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)
}

Golang DES加解密相关推荐

  1. 一个java的DES加解密类转换成C#

    原文:一个java的DES加解密类转换成C# 一个java的des加密解密代码如下: //package com.visionsky.util;import java.security.*; //im ...

  2. 密码学入门1——凯撒密码和三重DES加解密

    实验目的 1.完成第一个入门加解密--凯撒密码 2.完成当下较为流行的三重DES加解密技术 3.熟悉所学的实际运用方向 实验准备 硬件:计算机或笔记本电脑 操作系统:Mac操作系统 IDE环境:Ecl ...

  3. PHP 基础篇 - PHP 中 DES 加解密详解

    2019独角兽企业重金招聘Python工程师标准>>> 一.简介 DES 是对称性加密里面常见一种,全称为 Data Encryption Standard,即数据加密标准,是一种使 ...

  4. C语言实现DES加解密算法

    C语言实现DES加解密算法 DES加解密 DES加解密 #include <stdio.h> #include <stdlib.h> #include <string.h ...

  5. js des加密 java_Java实现与JS相同的Des加解密算法完整实例

    本文实例讲述了Java实现与JS相同的Des加解密算法.分享给大家供大家参考,具体如下: 这里演示java与js实现相同的des加解密算法,不多说,不废话,直接上代码 一.java实现 package ...

  6. LKT系列加密芯片DES加解密以及OpenSSL DES接口实现加解密

    1.测试目标 使用已经预置DES密钥的LKT4201N系列加密芯片完成运算 2.测试环境 本示例运行环境为windows系统.测试软件LCS KIT.LKT-K100开发板. 3.测试步骤 注意:&q ...

  7. Hutool进行DES加解密

    Hutool进行DES加解密 先简述以下:一个数据接口,接收到的是DES加密后的json字符串,需要先解密再转成bean对象. 我试了网上很多方式实现,发现每次加密后最后几位不同.想着对称加解密还能这 ...

  8. java 和 c# 下的RSA证书+AES+DES加解密实现

    java 和 c# 下的RSA+AES+DES加解密实现 前言 在实际应用中,经常有需要使用加解密的情况,RSA\AES\DES是比较常用的几种加解密方式,使用和实现方式都比较成熟可靠,本文简要介绍一 ...

  9. DES加解密算法原理详解与实现

    [DES密码编写] 1. Equipment (1) operating system version :WIN 10 (2) CPU instruction set: x 64 (3) softwa ...

最新文章

  1. 27岁华裔小伙一战成名!搞出美国新冠最准预测模型,一人干翻专业机构,彭博:Superstar...
  2. Windows环境下在IDEA编辑器中spark开发安装步骤
  3. Java取得当前类的路径
  4. 字节Java高工面试:java软件开发工程师的市场薪资
  5. 一起学nRF51xx 23 -  s130蓝牙API介绍
  6. c语言1A,C程序设计语言1a.ppt
  7. oracle的简单命令
  8. sql注入攻击与防御第二章
  9. linux 安装java环境
  10. java水果仓库管理系统_java水果商城管理系统(界面框架代码)
  11. 多变量微积分笔记20——球坐标系
  12. 斯诺登逃亡之路上的守护天使都有谁
  13. 对角矩阵、对称矩阵、单位向量、正交矩阵
  14. 虚拟机的桥接模式和NAT模式
  15. 常识:大白话讲解「对账」
  16. jQuery设置按钮的属性_可用不可用
  17. Golang读写锁读锁重复获取的问题
  18. 如何在WordPress中添加Pinterest“ Pin It”按钮(最终指南)
  19. Python科学计算summary
  20. VS Code配置用批处理编译C++

热门文章

  1. 关于CAM卡(大卡)和智能卡(小卡)
  2. 电脑摄像头未能创建连接服务器,win8打开摄像头提示“未能创建视频预览,请坚持设备连接”怎么办...
  3. 黑帽seo 模板生成php,2020最新黑帽SEO技术中排名稳定方法,万能采集模板CMS
  4. 2022年制冷与空调设备运行操作理论题库模拟考试平台操作
  5. IDEA 逆向工程创建及报错解决方案
  6. spark 算子 详解
  7. 最近一波对中文编程(包括中文命名)的攻势
  8. Word中的5个技巧,都很实用,收藏!
  9. 深入浅出的数据分析方法
  10. ngrok服务端搭建并使用docker解放80端口