第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

為了賬號(hào)安全,請(qǐng)及時(shí)綁定郵箱和手機(jī)立即綁定
已解決430363個(gè)問題,去搜搜看,總會(huì)有你想問的

使用 Go 生成帶有 DSA 簽名的 SHA256,然后使用 Java 對(duì)其進(jìn)行驗(yàn)證

使用 Go 生成帶有 DSA 簽名的 SHA256,然后使用 Java 對(duì)其進(jìn)行驗(yàn)證

Go
LEATH 2022-09-26 19:50:44
去sha256原始數(shù)據(jù),然后DSA簽名按十六進(jìn)制打印符號(hào)結(jié)果使用 Java SHA256 和DSA 驗(yàn)證第一步結(jié)果是否返回錯(cuò)誤我知道沙256然后DSA是差異SHA256與DSA我怎么能在Go中生成一個(gè)符號(hào),可以在Java中使用sha256與dsa進(jìn)行驗(yàn)證?Go是否有任何其他第三方庫(kù)支持?去package mainimport (    "crypto/dsa"    "crypto/rand"    "crypto/sha256"    "encoding/asn1"    "encoding/hex"    "fmt"    "golang.org/x/crypto/ssh"    "math/big")func main() {    pemData := []byte("-----BEGIN DSA PRIVATE KEY-----\n" +        "MIIBvAIBAAKBgQD9f1OBHXUSKVLfSpwu7OTn9hG3UjzvRADDHj+AtlEmaUVdQCJR\n" +        "+1k9jVj6v8X1ujD2y5tVbNeBO4AdNG/yZmC3a5lQpaSfn+gEexAiwk+7qdf+t8Yb\n" +        "+DtX58aophUPBPuD9tPFHsMCNVQTWhaRMvZ1864rYdcq7/IiAxmd0UgBxwIVAJdg\n" +        "UI8VIwvMspK5gqLrhAvwWBz1AoGBAPfhoIXWmz3ey7yrXDa4V7l5lK+7+jrqgvlX\n" +        "TAs9B4JnUVlXjrrUWU/mcQcQgYC0SRZxI+hMKBYTt88JMozIpuE8FnqLVHyNKOCj\n" +        "rh4rs6Z1kW6jfwv6ITVi8ftiegEkO8yk8b6oUZCJqIPf4VrlnwaSi2ZegHtVJWQB\n" +        "TDv+z0kqAoGBAIb9o0KPsjAdzjK571e1Mx7ZhEyJGrcxHiN2sW8IztEbqrKKiMxp\n" +        "NlTwm234uBdtzVHE3uDWZpfHPMIRmwBjCYDFRowWWVRdhdFXZlpCyp1gMWqJ11dh\n" +        "3FI3+O43DevRSyyuLRVCNQ1J3iVgwY5ndRpZU7n6y8DPH4/4EBT7KvnVAhR4Vwun\n" +        "Fhu/+4AGaVeMEa814I3dqg==\n" +        "-----END DSA PRIVATE KEY-----")    p, _ := ssh.ParseRawPrivateKey(pemData)    pp := p.(*dsa.PrivateKey)    hashed := []byte{1}    sha256 := sha256.New()    sha256.Write(hashed)    hashed = sha256.Sum(nil)    r, s, _ := dsa.Sign(rand.Reader, pp, hashed)    type dsaSignature struct {        R, S *big.Int    }    var ss dsaSignature    ss.S = s    ss.R = r    signatureBytes, _ := asn1.Marshal(ss)    fmt.Println(hex.EncodeToString(signatureBytes))}
查看完整描述

2 回答

?
慕妹3242003

TA貢獻(xiàn)1824條經(jīng)驗(yàn) 獲得超6個(gè)贊

如果發(fā)生這種情況,請(qǐng)遵循 FIPS186-4 第 4.6 節(jié)和第 4.7 節(jié)


hashed := []byte{1}

pemData, _ := ioutil.ReadFile("config/secure/private.key")

p, err := ssh.ParseRawPrivateKey(pemData)

pp, ok := p.(*dsa.PrivateKey)

h := sha256.New()

h.Write(hashed)

hashed := h.Sum(nil)

if pp.Q.BitLen()/8 < len(hashed) {

    hashed = hashed[0 : pp.Q.BitLen()/8]

}

r, s, _ := dsa.Sign(rand.Reader, pp, hashed)

var ss dsaSignature

ss.S = s

ss.R = r

hashed, _ = asn1.Marshal(ss)


查看完整回答
反對(duì) 回復(fù) 2022-09-26
?
神不在的星期二

TA貢獻(xiàn)1963條經(jīng)驗(yàn) 獲得超6個(gè)贊

我在爪哇中發(fā)現(xiàn)


package sun.security.provider;


private BigInteger generateS(BigInteger var1, BigInteger var2, BigInteger var3, BigInteger var4) throws SignatureException {

        byte[] var5;

        try {

            var5 = this.md.digest();

        } catch (RuntimeException var9) {

            throw new SignatureException(var9.getMessage());

        }


        // this line split the hash256 redsult

        int var6 = var2.bitLength() / 8;

        if (var6 < var5.length) {

            var5 = Arrays.copyOfRange(var5, 0, var6);

        }


        BigInteger var7 = new BigInteger(1, var5);

        BigInteger var8 = var4.modInverse(var2);

        return var1.multiply(var3).add(var7).multiply(var8).mod(var2);

}

你可以在戈朗使用


    hashed := []byte{1}

    sha256 := sha2562.New()

    sha256.Write(hashed)

    hashed = sha256.Sum(nil)

    // you must split it 

    hashed = hashed[0:20]


原因是sha256結(jié)果在java中分裂,但glang沒有分裂


查看完整回答
反對(duì) 回復(fù) 2022-09-26
  • 2 回答
  • 0 關(guān)注
  • 144 瀏覽
慕課專欄
更多

添加回答

舉報(bào)

0/150
提交
取消
微信客服

購(gòu)課補(bǔ)貼
聯(lián)系客服咨詢優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動(dòng)學(xué)習(xí)伙伴

公眾號(hào)

掃描二維碼
關(guān)注慕課網(wǎng)微信公眾號(hào)