【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 方法计算哈希值。

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

相关推荐
草原上唱山歌几秒前
如何理解C语言中的指针?
c语言·开发语言·数据结构
m0_662577971 分钟前
C++中的模板方法模式
开发语言·c++·算法
参.商.2 分钟前
【Day47】912. 排序数组【6 种排序】
leetcode·golang·排序算法
csbysj20202 分钟前
PHP 多维数组
开发语言
墨白曦煜4 分钟前
RocketMQ 实战:揭秘 @RocketMQMessageListener 的反序列化魔法与“万能”消费策略
开发语言·python·rocketmq
东方-教育技术博主8 分钟前
AI 写一个可被 Blueprint 调用的角色技能系统
开发语言
m0_748873551 小时前
C++与Rust交互编程
开发语言·c++·算法
ZTLJQ8 小时前
序列化的艺术:Python JSON处理完全解析
开发语言·python·json
2401_891482179 小时前
多平台UI框架C++开发
开发语言·c++·算法