首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >asn1 go (客户端认证)

asn1 go (客户端认证)
EN

Stack Overflow用户
提问于 2015-01-16 20:46:43
回答 1查看 78关注 0票数 0

我正在努力使客户端证书正常工作,在阅读了https://developer.mozilla.org/en-US/docs/Web/HTML/Element/keygen之后,我意识到我需要解析一些asn1。

我试图使用的结构是:

代码语言:javascript
复制
type PublicKeyAndChallenge struct {
    Spki asn1.BitString
    Challenge asn1.BitString
}

type SignedPublicKeyAndChallenge struct{
    PublicKeyAndChallenge PublicKeyAndChallenge
    SignitureAlgorithm  asn1.BitString
    Signiture asn1.BitString
}

我将base64编码的asn1解码为[]字节,然后尝试将asn1解编组到结构中。

代码语言:javascript
复制
signeeKeySigned := make([]byte, 2048)
    _ , err = base64.StdEncoding.Decode(signeeKeySigned, signeePubKeySigned)
    if ( err != nil ){
        log.Fatal(err)
    }   
    //Parse should be asn.1 encoded
    var signee SignedPublicKeyAndChallenge
    _, err = asn1.Unmarshal(signeeKeySigned, &signee)
    if err != nil {
        log.Fatal(err)
    }  

我得到了一个结构错误,所以我相信我的结构在围棋肯定是不正确的,但我无法弄清楚它。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2015-01-17 15:32:00

我做了一些鸭子,并找到了rfc320,它提供了asn.1类的定义,并让它工作了!

现在的结构是:

代码语言:javascript
复制
type SubjectPublicKeyInfo struct {
    Algorithm pkix.AlgorithmIdentifier
    SubjectPublicKey asn1.BitString
}

type PublicKeyAndChallenge struct {
    Spki SubjectPublicKeyInfo
    Challenge string
}

type SignedPublicKeyAndChallenge struct{
    PublicKeyAndChallenge PublicKeyAndChallenge
    SignitureAlgorithm pkix.AlgorithmIdentifier
    Signiture asn1.BitString
}
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/27992496

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档