草庐IT

hmac_sha

全部标签

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

go - 使用与 node.js 或 Python 不同的结果的 Go 签名的 Hmac/sha1 消息

我正在尝试使用Go生成Hmac/SHA1签名,但我得到的结果与我使用Node.js或Python进行测试时的结果不同。这是我在Go中的代码:signature:=hmac.New(sha1.New,[]byte(signKey))signature.Write([]byte(buffer))returnhex.EncodeToString(signature.Sum(nil))这是我在Node.js中的代码:returncrypto.createHmac('sha1',signKey).update(buffer).digest('hex');python:returnhmac.new

arrays - 函数应返回 sha256/sha384/sha512 结果作为 byte slice

我正在编写一个函数,它将输入数据作为字符串和要调用的SHA算法的位大小。它应该将生成的散列作为byteslice返回(第一次尝试):packagemainimport("crypto/sha256""crypto/sha512""errors""fmt")funcmain(){input:="Thisisatest."sha256,_:=shaSum(input,256)sha384,_:=shaSum(input,384)sha512,_:=shaSum(input,512)fmt.Println(input,sha256,sha384,sha512)}funcshaSum(data

go - SHA1 encoding with secret,相当于PHP hash_hmac

我有以下PHP函数publicfunctionencodePassword($raw,$salt){returnhash_hmac('sha1',$raw.$salt,$this->secret);}我需要将其翻译成Go。我找到了以下示例,但它不涉及key。https://gobyexample.com/sha1-hashes我如何在Go中创建一个函数,它产生与PHP的hash_hmac完全相同的结果?Update:AfterLeo'sanswer,foundthisresourcewithhmacexamplesinmanylanguages:https://github.com/d

go - "undefined: hmac.Equal"错误,而 hmac.New 在这之前的行中工作正常

我正在用go开发一个网络服务器,在顶部我有import("net/http""log""fmt""encoding/json""encoding/hex""time""math/rand""crypto/sha256""crypto/hmac""strconv""strings""github.com/crowdmob/goamz/aws""github.com/crowdmob/goamz/dynamodb")后来我有funcsingSomething(someidstring)string{mac:=hmac.New(sha256.New,key)mac.Write([]byte(

cryptography - Golang 使用 ecdsa 和来自 SHA224 摘要的私钥进行签名

我需要签署一条消息以提交给远程服务(通过websocket)。为此,我需要根据一个整数(我的用户ID)和一个密码(一个base64编码的字符串)构建一个私钥,并使用SHA224进行哈希处理。为此,我使用golang和crypto/ecdsa以及用于字节编码等的随附包。这是我的文档:SignaturesuseanEllipticCurveDigitalSignatureAlgorithm(ECDSA)encodedmessagecontaining:userID,ServerNonce,ClientNodeandPrivatekey.Privatekeysaregeneratedhash

javascript - 如何将此代码从 golang 转换为 crypto hmac sha256 hex 中的 reactjs

Golang代码如下funcGenerateClientToken(secret,user,timestamp,infostring)string{token:=hmac.New(sha256.New,[]byte(secret))token.Write([]byte(user))token.Write([]byte(timestamp))token.Write([]byte(info))returnhex.EncodeToString(token.Sum(nil))}我如何将其转换为reactjs代码。我正在尝试这样importCryptoJSfrom'crypto-js'gener

Golang crypto/sha256 - 相同的输入产生不同的输出

我对Golang的crypto/sha256包有疑问。我将相同的输入发送到sha256.Sum256两次,每次输出都不同。我的代码如下://RuntheHMAC-SHA256onthegivenkmacandmessageandreturnthegeneratedMACtagfuncPCSSHA256(kmac[]byte,message[]byte)[32]byte{//NOTE:bitwiseXOR^onlyworksonintegers.kmac64:=append(kmac,[]byte(strings.Repeat("0",48))[0:]...)//Padtoobtaina

go - 如何使用 go-git 查找 sha of origin/master?

我正在尝试使用go-git查找origin/master的SHA1,在我已经完成了与gitfetch--all等效的操作之后。然而,go-git似乎不支持:gitls-remotegit@github.com:StevenACoffman/toolbox.gitgitrev-parseorigin/master有没有其他方法可以使用go-git确定origin/master的SHA1? 最佳答案 糟糕!支持gitrev-parse!使用./main.go$PWDorigin/master执行以下命令:///usr/bin/envgo

security - 带时间窗的 HMAC

我正在使用基于UTC+0同步时间的时间窗口机制对HMAC进行一些测试。服务器有一个特殊的公共(public)API调用http://myserver.com/api/servertime/,它将返回服务器的确切UTC+0时间。通过这种方式,API用户可以同步他们的请求客户端,以便它能够匹配我的API允许安全调用的时间窗口。我建立了一个30分钟的时间段(-15min-+15min)。我的代码是这样的:funcGenerateHmac512(message[]byte,key[]byte)[]byte{h:=hmac.New(sha512.New,key)h.Write(message)r