草庐IT

戈朗 : sha256 returns two different values for the same input

我正在努力实现一些需要哈希操作的加密函数(我想计算自定义结构的哈希)所以我想使用crypto中的SHA256哈希函数golang包。但是,我注意到,当我针对同一输入多次运行哈希函数时,有时它会返回不同的值。我的理解是SHA函数为单个输入值返回相同的哈希输出。下面是我对哈希函数的实现:funcmyHash(sMyStruct)[]byte{bytes:=[]byte(fmt.Sprintf("%v",s))h:=sha256.New()h.Write(bytes)returnh.Sum(nil)}myStruct有以下字段:typeMyStructstruct{elliptic.Curv

go - sha256 和与 gzip 命令输出不匹配

我正在尝试在Go中计算一个gzip文件的sha256总和,但我的输出与gzip命令的输出不匹配。我有一个函数Compress可以压缩io.Reader的内容,在我的例子中是一个文件。funcCompress(rio.Reader)(io.Reader,error){varbufbytes.Bufferzw:=gzip.NewWriter(&buf)if_,err:=io.Copy(zw,r);err!=nil{returnnil,err}iferr:=zw.Close();err!=nil{returnnil,err}return&buf,nil}然后我有一个函数Sum256可以计算读

golang 中的 java RSA/ECB/OAEPWithSHA 256AndMGF1Padding 等价物

我正在尝试将一些java加密代码迁移到golang中并遇到了这个Ciphercipher=Cipher.getInstance(RSA_ECB_OAEPWithSHA256AndMGF1Padding);cipher.init(Cipher.WRAP_MODE,cert);returncipher.wrap(key);我正试图在go中找到此的任何实现。任何帮助,将不胜感激。谢谢。 最佳答案 虽然问题有点不清楚,但我认为您想要一种在Go中编码数据的方法。你可能会发现用谷歌搜索以下标准Go包很有帮助:加密/hmac加密/sha256编码

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 - 在使用 GOMAXPROCS = 256 运行无限循环 goroutines 时理解 golang 的调度程序

我正在玩Go,在我的20158核MacBookPro上运行go1.7.3。尝试了解runtime.GOMAXPROCS设置为其最大值(256)并启动相同数量的goroutine时goscheduler的工作原理,每个goroutine都运行一个无限循环。我的假设是goruntime会产生runtime.GOMAXPROCS数量的操作系统线程(即256个线程)并在这些线程中运行我的goroutines。我期待下面的代码打印出256个1:funcmain(){procs:=256runtime.GOMAXPROCS(procs)fori:=0;i此代码每次运行时都会打印不同数量的1。大多数

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

go - 如何使用 golang.org/x/crypto/bn256 计算 e(g1^x,g1^x)?

golang包bn256可以这样做:e(g_1^x,g_2^y),但我想计算e(g_1^x,g_1^y)。有什么办法可以把g1上的点转移到g2上吗? 最佳答案 bn256不允许您使用pair(G1,G2)进行对称配对。实现它的一种方法是将目标组元素提高到所需的指数。 关于go-如何使用golang.org/x/crypto/bn256计算e(g1^x,g1^x)?,我们在StackOverflow上找到一个类似的问题: https://stackoverflo

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

php - 在PHP中解密由openssl_encrypt加密的AES-256-CBC密文时出现坏 block 大小错误

我有一个PHP模块,它使用openssl_encrypt使用aes-256-cbc加密电子邮件。本模块生成的密文也可以用本模块解密。但是,如果我尝试使用相同的IV和key在Go中使用aes-256-cbc的实现来解密它们,我会得到一个badblocksize错误。block大小应该是16的倍数,但PHP生成的密文不是16的倍数。这是代码packagemainimport("crypto/aes""crypto/cipher""crypto/sha256""encoding/base64""encoding/hex""fmt")var(IV=[]byte("fg3Dk54f4340fKF

php - 解密在 GOLang 上用 PHP 解密的 AES-CBC-256 Mcrypt_RIJNDAEL

我尝试在go中重写一些在php5.6(CodeIgniter)中编写的旧代码,但我正在忙于解密。我设法从php解码MCRYPT_RIJNDAEL_128去,其中iv大小是16个字符,但我不能在256上这样做-iv是32。我不想使用go_mcrypt因为它对libcryptheader很严格,所以我试过了在CBC模式下使用goclassicencryptlibsAES密码,但在256上它提示IV长度...phpIV有32个字符而不是预期的16个字符..php部分运行良好...private$CIPHER_KEY="12345678901234567890123456789012";pri