时间:2021-05-22
Golang计算md5值的方法都是接收byte型slice([]byte)。而且使用习惯上也觉得略奇怪。
看了好几个例子才看懂。
感觉Golang标准库在设计这些模块的时候,都会考虑使用带New关键字工厂生成一个该类型的结构体对象。然后再使用改对象的方法进行操作。
md5包就是这样,来看例子:
s := "api_key" + ApiKey + "param" + Param + "time" + time + "version" + version + ApiSecretsignByte := []byte(s)hash := md5.New()hash.Write(signByte)return hex.EncodeToString(hash.Sum(nil))第一行我拼接了一个字符串。
第二行我将这个字符串转成byte型数组并赋值给了sighByte。
第三行我new了一个md5的实现了hash.Hash的结构体。
第四行我调用这个结构体的方法Write将我需要计算md5的[]byte传入进去。
第五行我调用hex.EncodeToSring方法来把计算结果转换成16进制字符串。其中hash.Sum(nil)方法可以生成前面Write进去的signByte变量的128bit md5值。
这个hash.Sum方法并不是我们在操作其它语言的那种使用习惯,将值传递进去然后返回hash,这里其实是追加一个值一并生成hash。
由于我们不需要再追加值了,所以传入nil得到signByte的hash值。
补充:golang标准库-crypto/md5(md5加密算法)
本文讲解如何使用go封装好的md5算法,不深入剖析md5算法原理。
首先我们要知道md5算法属于hash算法的一种,所以在了解md5之前,我们先认识一下go提供的hash接口。hash算法是保证只要输入的值不同,就一定会得到两个不同的指定长度的hash值。
当前两个不同值产生相同的hash还是有可能的,只是这个可能性很小很小
crypto/md5包实现的就是这个Hash接口。
md5实现的第一个Hash接口是16位的hash函数(它的Sum方法返回的字符切片长度为16位),Hash32和hash64是属于安全性更高的两个Hash函数,产生的hash值也更长。
crypto/md5包提供了一个方法创建md5算法:
func New() hash.Hash => 返回一个新的使用MD5校验的hash.Hash接口
接着看示例:
package main import ( "crypto/md5" "encoding/hex" "fmt") func main() { has := md5.New() // 创建md5算法 has.Write([]byte("abc123")) // 写入需要加密的数据 b := has.Sum(nil) // 获取hash值字符切片;Sum函数接受一个字符切片,这个切片的内容会原样的追加到abc123加密后的hash值的前面,这里我们不需要这么做,所以传入nil fmt.Println(b) // 打印一下 [233 154 24 196 40 203 56 213 242 96 133 54 120 146 46 3] // 上面可以看到加密后的数据为长度为16位的字符切片,一般我们会把它转为16进制,方便存储和传播,下一步转换16进制 fmt.Println(hex.EncodeToString(b)) // 通过hex包的EncodeToString函数,将数据转为16进制字符串; 打印 e99a18c428cb38d5f260853678922e03 // 还有一种方法转换为16进制,通过fmt的格式化打印方法, %x表示转换为16进制 fmt.Printf("%x",b) // 打印 e99a18c428cb38d5f260853678922e03}运行结果:
crypto/md5包还提供了一个md5加密简便的方法:
func Sum(data []byte) [Size]byte => 直接返回数据data的MD5加密值,注意它返回的是指定大小(Size)的数组,而不是切片了
下面看例子:
package main import ( "crypto/md5" "fmt") func main() { b := md5.Sum([]byte("abc123")) // 加密数据 fmt.Printf("%x",b) // 转换为16进制,并打印}运行结果:
这二种方法都可以md5加密数据,甚至后面更加简洁。
以上为个人经验,希望能给大家一个参考,也希望大家多多支持。如有错误或未考虑完全的地方,望不吝赐教。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
起因最近遇到一个问题,把某个字符串计算MD5,之后把该字符串加密与MD5一起上传到服务端,服务端解密后重新计算md5发现与上传的MD5不一致,而出问题的字符串中
详解PythonMD5加密Python3下MD5加密#由于MD5模块在python3中被移除#在python3中使用hashlib模块进行md5操作import
linux下使用md5sum递归生成整个目录的md5今天要用md5sum操作目录,递归生成目录下所有文件的md5值,结果发现它不支持递归操作于是写了个php脚本
复制代码代码如下://计算字符串的MD5值publicstringGetMD5(stringsDataIn){MD5CryptoServiceProviderm
系统镜像md5不正确可能是因为文件是修改过的,不是原版的。要是md5值不正确,那么就重新再换个操作系统,下载的操作系统镜像一定要检验过md5值以后再安装,不然系