Go语言实现md4、md5、sha256哈希算法加密

本文涉及的产品
密钥管理服务KMS,1000个密钥,100个凭据,1个月
简介: 目录1. 哈希算法特点2. 常用的哈希算法3. go实现MD加密3.1 MD43.2 MD53. go实现SHA加密最后

目录

1. 哈希算法特点

2. 常用的哈希算法

3. go实现MD加密

3.1 MD4

3.2 MD5

3. go实现SHA加密

最后

1. 哈希算法特点

不可逆:无法从一个哈希值恢复原始数据,哈希并不加密


唯一性:对于特定的数据 只能有一个哈希 并且这个哈希是唯一的


防篡改:改变输入数据中的一个字节 导致输出一个完全不同的哈希值


2. 常用的哈希算法

MD4、MD5、hash1、sha224、sha256、sha384、sha512


性能 : md4 > md5 > sha224 > sha256 > sha384 > sha512


内存消耗:md5 > md4 > sha512 > sha384 > sha256 = sha224


建议平常使用sha256即可,安全性可靠且消耗资源不高。


3. go实现MD加密

3.1 MD4

import (
  "encoding/hex"
  "golang.org/x/crypto/md4"
)
func GetMd4(str string) string {
  srcByte := []byte(str)
  md4New := md4.New()
  md4Bytes := md4New.Sum(srcByte)
  md4String := hex.EncodeToString(md4Bytes)
  return md4String
}

3.2 MD5

import (
  "crypto/md5"
  "encoding/hex"
)
func GetMd5(str string) string {
  srcByte := []byte(str)
  md5New := md5.New()
  md5Bytes := md5New.Sum(srcByte)
  md5String := hex.EncodeToString(md5Bytes)
  return md5String
}

3. go实现SHA加密

import (
  "crypto/sha256"
  "encoding/hex"
)
func GetSha256(str string) string {
  srcByte := []byte(str)
  sha256New := sha256.New()
  sha256Bytes := sha256New.Sum(srcByte)
  sha256String := hex.EncodeToString(sha256Bytes)
  return sha256String
}

最后

小生凡一,期待你的关注。

image.png

相关文章
|
12天前
|
弹性计算 算法 Linux
使用SM4算法加密LUKS格式磁盘
本文介绍了在Anolis 8操作系统使用cryptsetup对磁盘进行分区、加密和挂载的过程。采用SM4加密算法。具体步骤包括:初始化加密卷、解锁加密分区、格式化并挂载设备。最后,展示了如何取消挂载并关闭加密卷以确保数据安全。整个过程确保了磁盘数据的安全性和隐私保护。
41 2
使用SM4算法加密LUKS格式磁盘
|
4月前
|
存储 算法 Java
解析HashSet的工作原理,揭示Set如何利用哈希算法和equals()方法确保元素唯一性,并通过示例代码展示了其“无重复”特性的具体应用
在Java中,Set接口以其独特的“无重复”特性脱颖而出。本文通过解析HashSet的工作原理,揭示Set如何利用哈希算法和equals()方法确保元素唯一性,并通过示例代码展示了其“无重复”特性的具体应用。
86 3
|
1月前
|
算法 安全 Go
Go语言中的加密和解密是如何实现的?
Go语言通过标准库中的`crypto`包提供丰富的加密和解密功能,包括对称加密(如AES)、非对称加密(如RSA、ECDSA)及散列函数(如SHA256)。`encoding/base64`包则用于Base64编码与解码。开发者可根据需求选择合适的算法和密钥,使用这些包进行加密操作。示例代码展示了如何使用`crypto/aes`包实现对称加密。加密和解密操作涉及敏感数据处理,需格外注意安全性。
50 14
|
2月前
|
算法 安全
散列值使用相同的哈希算法
当使用相同的哈希算法对相同的数据进行散列时,所产生的散列值(也称为哈希值或摘要)总是相同的。这是因为哈希算法是一种确定性的函数,它对于给定的输入将始终产生相同的输出。 例如,如果你用SHA-256算法对字符串"hello world"进行哈希处理,无论何时何地,只要输入是完全一样的字符串,你都会得到相同的160位(40个十六进制字符)的SHA-256散列值。 但是,需要注意的是,即使是输入数据的微小变化也会导致产生的散列值完全不同。此外,不同的哈希算法(如MD5、SHA-1、SHA-256等)会对相同的数据产生不同的散列值。 哈希算法的一个关键特性是它们的“雪崩效应”,即输入中的一点小小
50 4
|
4月前
|
存储 算法 C#
C#哈希查找算法
C#哈希查找算法
|
4月前
|
算法 安全 Go
RSA加密算法详解与Python和Go实现
RSA加密算法详解与Python和Go实现
329 1
|
4月前
|
算法 安全 Go
Python与Go语言中的哈希算法实现及对比分析
Python与Go语言中的哈希算法实现及对比分析
73 0
|
4月前
|
安全 测试技术 Go
Python 和 Go 实现 AES 加密算法的技术详解
Python 和 Go 实现 AES 加密算法的技术详解
202 0
|
5天前
|
算法 数据安全/隐私保护 计算机视觉
基于FPGA的图像双线性插值算法verilog实现,包括tb测试文件和MATLAB辅助验证
本项目展示了256×256图像通过双线性插值放大至512×512的效果,无水印展示。使用Matlab 2022a和Vivado 2019.2开发,提供完整代码及详细中文注释、操作视频。核心程序实现图像缩放,并在Matlab中验证效果。双线性插值算法通过FPGA高效实现图像缩放,确保质量。
|
1月前
|
算法 数据安全/隐私保护 计算机视觉
基于Retinex算法的图像去雾matlab仿真
本项目展示了基于Retinex算法的图像去雾技术。完整程序运行效果无水印,使用Matlab2022a开发。核心代码包含详细中文注释和操作步骤视频。Retinex理论由Edwin Land提出,旨在分离图像的光照和反射分量,增强图像对比度、颜色和细节,尤其在雾天条件下表现优异,有效解决图像去雾问题。

热门文章

最新文章