【go从零单排】SHA256 Hashes加密

🌈Don't worry , just coding!
内耗与overthinking只会削弱你的精力,虚度你的光阴,每天迈出一小步,回头时发现已经走了很远。

📗概念

在 Go 语言中,使用 crypto/sha256 包可以方便地计算 SHA-256 哈希值。SHA-256 是一种广泛使用的加密哈希函数,输出一个固定长度的 256 位(32 字节)的哈希值,通常以十六进制形式表示。

使用 SHA-256 计算哈希的步骤

  1. 导入必要的包:需要 crypto/sha256 和 fmt 包。
  2. 创建 SHA-256 哈希对象:使用 sha256.New() 创建一个新的哈希对象。
  3. 写入数据:使用 Write 方法将要哈希的数据写入哈希对象。
  4. 计算哈希值:使用 Sum 方法获取最终的哈希值。

💻代码

go 复制代码
package main

import (
	//crypto/sha256:用于计算 SHA-256 哈希。
	"crypto/sha256"
	"fmt"
)

func main() {
	//定义字符串:定义一个字符串 s,其内容为 "sha256 this string"。
	s := "sha256 this string"
	//创建 SHA-256 哈希对象:sha256.New() 创建一个新的 SHA-256 哈希对象 h。
	h := sha256.New()
	//写入数据:将字符串 s 转换为字节切片并写入哈希对象 h。这一步是计算哈希的关键。
	h.Write([]byte(s))
	//计算哈希值:h.Sum(nil) 计算当前哈希值并返回一个字节切片 bs。传入 nil 表示不需要额外的字节切片来存储结果。
	bs := h.Sum(nil)
	//输出原始字符串:打印原始字符串 s。
	fmt.Println(s)
	//输出哈希值:使用 %x 格式化输出哈希值 bs,以十六进制形式显示。这是 SHA-256 哈希的常见表示方式。
	fmt.Printf("%x\n", bs)
}

//输出
//sha256 this string
//1af1dfa857bf1d8814fe1af8983c18080019922e557f15a8a0d3db739d77aacb

🔍理解

  • 安全性:SHA-256 是一种安全的哈希算法,广泛应用于数字签名、数据完整性校验等场景。
  • 性能:相较于其他哈希算法(如 MD5),SHA-256 提供了更高的安全性,但计算速度稍慢。
  • 多次哈希:可以多次调用 Write 方法来分块写入数据,最后再调用 Sum 方法计算哈希值。

💪无人扶我青云志,我自踏雪至山巅。

相关推荐
旷世奇才李先生11 分钟前
Next.js 安装使用教程
开发语言·javascript·ecmascript
charlie1145141911 小时前
深入理解Qt的SetWindowsFlags函数
开发语言·c++·qt·原理分析
likeGhee1 小时前
python缓存装饰器实现方案
开发语言·python·缓存
whoarethenext2 小时前
使用 C++/Faiss 加速海量 MFCC 特征的相似性搜索
开发语言·c++·faiss
项目題供诗2 小时前
黑马python(二十五)
开发语言·python
慌糖2 小时前
RabbitMQ:消息队列的轻量级王者
开发语言·javascript·ecmascript
醇醛酸醚酮酯2 小时前
Qt项目锻炼——TODO清单(二)
开发语言·数据库·qt
jioulongzi2 小时前
记录一次莫名奇妙的跨域502(badgateway)错误
开发语言·python
向阳@向远方3 小时前
第二章 简单程序设计
开发语言·c++·算法
Mr_Xuhhh3 小时前
信号与槽的总结
java·开发语言·数据库·c++·qt·系统架构