dpbrrczhlwbv849228 2016-10-17 10:20
浏览 114
已采纳

在go中解析证书字符串

I'm using ssldump to extract the certificate in a communication. When i parse the result I obtain a string in go defined as:

var string certStr
certStr = "30 82 06 9f...."

How can I parse it to a X509 certificate?

UPDATED

I have tried to parse it directly:

certSlc := []byte(certStr)
cert,err := x509.ParseCertificates(certSlc)

But the result was:

Error:asn1: structure error: tags don't match (16 vs {class:0 tag:19 length:48 isCompound:true}) {optional:false explicit:false application:false defaultValue:<nil> tag:<nil> stringType:0 timeType:0 set:false omitEmpty:false}

Should I do another kind of conversion? maybe is the string incomplete or has got wrong type of cert?

  • 写回答

1条回答 默认 最新

  • douxi8759 2016-10-18 06:43
    关注

    I found the error. The problem was in the source. As I was explaining, my cert string was "30 82 06 09...". This source must be decoded with:

    hex.DecodeString(certStr)
    

    The problem is that hex decoding doesn't work with this format. The error I obtained was:

    encoding/hex: invalid byte: U+0020 ' '
    

    So, removing whitespaces and carriage returns in the original string is the solution to make it work.

    After decoding in a byte slice the X509 certificate can be created with no problem.

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 如何实现H5在QQ平台上的二次分享卡片效果?
  • ¥15 python爬取bilibili校园招聘网站
  • ¥30 求解达问题(有红包)
  • ¥15 请解包一个pak文件
  • ¥15 不同系统编译兼容问题
  • ¥100 三相直流充电模块对数字电源芯片在物理上它必须具备哪些功能和性能?
  • ¥30 数字电源对DSP芯片的具体要求
  • ¥20 antv g6 折线边如何变为钝角
  • ¥30 如何在Matlab或Python中 设置饼图的高度
  • ¥15 nginx中的CORS策略应该如何配置