草庐IT

哈希表(HashTable)

全部标签

go - 哈希反射类型

我正在尝试找到一种在两个[]reflect.Type之间执行比较的快速方法。现在我有以下内容:funcEqual(left,right[]reflect.Type)bool{iflen(left)!=len(right){returnfalse}fori:=0;i大部分slice不会改变。因此,如果我能找到一种对它们进行哈希处理的方法,我将获得巨大的性能提升。背景我正在尝试(为了好玩)使用reflect包在Go中实现一种函数重载形式。我做的第一件事是将每个专用/重载函数转换为签名类型。typeSignaturestruct{VariadicboolIn,Out[]reflect.Typ

Golang crypto/hmac 全局哈希对象

我尝试使用全局hmac哈希来生成签名。代码运行良好,但生成的签名不满足第3方集成检查器的要求。如果将为每个“签名生成”过程创建hmac哈希,它将正常工作。工作正常-签名被第3方接受:functokenSignatureFunc(keystring)tokenSignType{signToken:=func(tokenstring)[]byte{h:=hmac.New(sha256.New,[]byte(key))h.Write([]byte(token))signature:=h.Sum(nil)base64Signature:=make([]byte,base64.StdEncodi

python - 在 Go 中创建哈希

免责声明:我是Go新手我正在尝试将Python函数转换为Go:defverify_signature(self,token,timestamp,signature):returnsignature==hmac.new(key=self.api_key,msg='{0}{1}'.format(timestamp,token),digestmod=hashlib.sha256).hexdigest()我认为我下面的Go函数接近正确,但我不明白Python函数“digestmod=hashlib.sha256”.hexdigest()”的最后一行可以肯定地说:funcverify_signa

Golang 有人可以解释为什么哈希比较失败

我正在尝试开发一个用户登录系统,为此我正在测试golang的bcrypt功能。但我遇到了一些有趣的情况。我的bcrypt学习资料来源于此,代码运行良好https://medium.com/@jcox250/password-hash-salt-using-golang-b041dc94cb72但是当我自己写代码的时候,比较失败。packagemainimport("log""golang.org/x/crypto/bcrypt")funcmain(){hash1,_:=bcrypt.GenerateFromPassword([]byte("123456"),bcrypt.MinCost

dictionary - golang 内置映射和字符串键的哈希冲突?

我编写了这个函数来为我的测试用例生成随机唯一ID:funcuuid(t*testing.T)string{uidCounterLock.Lock()deferuidCounterLock.Unlock()uidCounter++//return"["+t.Name()+"|"+strconv.FormatInt(uidCounter,10)+"]"return"["+t.Name()+"|"+string(uidCounter)+"]"}varuidCounterint64=1varuidCounterLocksync.Mutex为了测试它,我在不同的goroutines中生成了一堆值

json - 访问具有哈希结构的嵌套 JSON 文件

我有如下所示的JSON文件:{"env":{"production":{"test":{"text":"hello"},"url":{"str":"url1"}},"staging":{"test":{"text":"hel1lo"},"url":{"str":"url31"}}}}有没有一种方法可以导入此文件并进入嵌套结构格式,以便以正确的顺序进行暂存及其内部字段? 最佳答案 使用此代码将暂存数据解析为Go值:typeenvstruct{Teststruct{Textstring}URLstruct{Strstring}}varv

go - 如何创建自定义哈希码以确定数据是否已发生变化

假设我有一个包含int64和bool的结构类型,以及具有更多int64和bool类型字段的嵌入式类型。typeT1struct{f1int64f2int64f3boolT2T2}typeT2struct{f4int64f5int64f6bool}现在使用所有结构字段/属性,我想生成一个哈希码。这样做的目的是为了确定实例的内容是否已更改,但比较之前/之后的哈希码值。因此,如果T1实例已更改,即它自己的任何属性,则哈希值应该不同。 最佳答案 你可以使用类似的东西:func(t*T1)Hash()uint64{hb:=make([]byt

转到哈希表 : casting without conversion?

我正在实现一个专门的哈希表。出于空间使用和性能原因,我正在尝试将大量数据存储在单个64位intkey中。每个键都应该有这样的结构://Keystructure,fromLSB//evalresult(16bits)//move(16bits)//age(16bits):themoveofthegameonwhichthispositionwouldhaveoccurred//depth(8bits)//nodetype(8bits):fromthethreeconstantsabove这是一个简单的实现:varkeys[1000]uint64varvalues[1000]uint64f

go - 如何在 Golang 中计算嵌套/迭代 MD5 哈希?

我正在构建一个使用golang来暴力破解密码的程序。密码哈希的格式是将1000倍应用于初始密码然后使用的md5哈希。(我展示的代码只应用了这个5x)md5(md5(md5(md5(....(md5(密码))))))funchash(pwstring)string{hasher:=md5.New()data:=[]byte(pw)fmt.Printf("Initialdata:%s\n",pw)fori:=0;i此结果不同于使用命令行实用程序md5sum给出的结果。我的另一个尝试是使用,因为这是无状态的,但我仍然开始偏离第二轮哈希sum:=md5.Sum([]byte(data))实现计

node.js - 将密码哈希脚本从 GO 转换为 Nodejs

我很难将现有的GO脚本转换为NodeJS。它基本上是一个哈希脚本,它接受2个参数agreedUponKey和salt并返回密码哈希。packagemainimport("fmt""hash""crypto/sha256")funcmain(){varagreedUponKeystringvarsaltstringvarhhash.HashagreedUponKey="giri"salt="XYZabc987"h=sha256.New()h.Write([]byte(agreedUponKey))h.Write([]byte(salt))sha256Sum:=h.Sum(nil)prin