从字符串格式的 x509 证书生成主题名称

从字符串格式的 x509 证书生成主题名称

php小编草莓从字符串格式的 x509 证书生成主题名称是一项重要的操作,它可以帮助开发人员从证书中提取出关键信息。通过解析字符串格式的 x509 证书,我们可以获取证书的主题名称,包括证书的颁发者、有效期、公钥等信息。这个过程对于构建安全的网络通信、验证证书的合法性以及保护用户隐私具有重要意义。在 PHP 中,我们可以借助 OpenSSL 扩展提供的函数来实现这个功能,简单、高效地处理 x509 证书。

问题内容

我正在尝试从 x509.certificate 生成可分辨名称。

我期望的格式是:

"cn=,ou=,o=,dnqualifier=+7he5grzxim+lkemb5fs98e+fpy="

登录后复制

(我用标签替换了一些值)

通过我的代码,我得到了没有 dnqualifier 部分的预期字符串,如下所示:

cn=,ou=,o=,2.5.4.46=#131c537771614a5531514c2449444e4846373755547a1f5749653955303d"

登录后复制

在这里,2.5.4.46 是“dnqualifier”的 asn.1 对象 id 参考:链接该值看起来像一个十六进制字符串。

是否有标准方法(或简单的解决方法)来获取预期格式的专有名称?即,应该出现文本“dnqualifier”而不是其 objectidentifier,并且应该出现实际的字符串值而不是十六进制。

我的代码如下所示:

package mainimport (    "crypto/x509"    "encoding/pem"    "fmt"    "github.com/sirupsen/logrus")func main() {    cert := "" // certificate string here    block, rest := pem.decode([]byte(cert))    if len(rest) != 0 {        logrus.error("certificate string not fully decoded : ", rest)    }    certificate, err := x509.parsecertificate(block.bytes)    if err != nil {        logrus.witherror(err).error("error parsing certificate")    }    fmt.println(certificate.subject.string())}

登录后复制

从此代码 certificate.subject.string() 给出的输出如下:cn=,ou=,o=,2.5.4.46=#131c537771614a5531514c2449444e4846373755547a1f5749653955303d”

另外,

fmt.printf("%+v", cert.subject.tordnsequence())

登录后复制

var sub pkix.RDNSequenceasn1.Unmarshal(certificate.RawSubject, &sub)

登录后复制

两者都没有帮助。

解决方法

标准库仅提供 有限的属性列表:

var attributetypenames = map[string]string{    "2.5.4.6":  "c",    "2.5.4.10": "o",    "2.5.4.11": "ou",    "2.5.4.3":  "cn",    "2.5.4.5":  "serialnumber",    "2.5.4.7":  "l",    "2.5.4.8":  "st",    "2.5.4.9":  "street",    "2.5.4.17": "postalcode",}

登录后复制

对于其他属性,它只是使用对象标识符作为名称,并在可能的情况下将值编码为十六进制字符串(请参阅(rdnsequence).string):

oidstring := tv.type.string()typename, ok := attributetypenames[oidstring]if !ok {    derbytes, err := asn1.marshal(tv.value)    if err == nil {        s += oidstring + "=#" + hex.encodetostring(derbytes)        continue // no value escaping necessary.    }    typename = oidstring}valuestring := fmt.sprint(tv.value)escaped := make([]rune, 0, len(valuestring))

登录后复制

它没有提供任何旋钮让我们获得定制的琴弦。所以我们必须自己做。

我建议列出我们想要的属性,并将它们附加到从 certificate.subject.tordnsequence().string() 返回的字符串中。像这样:

package mainimport (    "crypto/x509"    "crypto/x509/pkix"    "encoding/pem"    "fmt")func tostring(name pkix.name) string {    s := name.tordnsequence().string()    // list the extra attributes that should be added.    attributetypenames := map[string]string{        "2.5.4.43": "initials",        "2.5.4.46": "dnqualifier",    }    for typ, typename := range attributetypenames {        for _, atv := range name.names {            oidstring := atv.type.string()            if oidstring == typ {                // to keep this demo simple, i just call fmt.sprint to get the string.                // maybe you want to escape some of the characters.                // see https://github.com/golang/go/blob/1db23771afc7b9b259e926db35602ecf5047ae23/src/crypto/x509/pkix/pkix.go#l67-l86                s += "," + typename + "=" + fmt.sprint(atv.value)                break            }        }    }    return s}func main() {    block, _ := pem.decode([]byte(cert))    certificate, err := x509.parsecertificate(block.bytes)    if err != nil {        panic(err)    }    fmt.println(certificate.subject.string())    fmt.println()    fmt.println(certificate.subject.tordnsequence().string())    fmt.println()    fmt.println(tostring(certificate.subject))}var cert = `-----begin certificate-----miigvdccbksgawibagiupminkycv6nqggfhrq1sj/y/4gykwdqyjkozihvcnaqelbqawgfsxgzazbgnvbammennly3vyzs5legftcgxllmnvbtelmakga1uebhmcwfgxetapbgnvbacmcez1bibmyw5kmsgwjgydvqqkdb9neunviexmqybmveqgsu5dichklmiuys4gt3vyq28pmriweaydvqqldaltu0wgrgvwdc4xczajbgnvbagmallzmsqwigyjkozihvcnaqkbfhvzc2wtywrtaw5azxhhbxbszs5jb20xetapbgnvbckmcepvag4grg9lmqwwcgydvqqedaneb2uxdtalbgnvbcombepvag4xddakbgnvbcsma0pyrdenmasga1uelhmec29tztaefw0ymza2mtixndi2mzhafw0ynda2mtexndi2mzhamih7mrswgqydvqqddbjzzwn1cmuuzxhhbxbszs5jb20xczajbgnvbaytalhymrewdwydvqqhdahgdw4gtgfuzdeomcyga1uecgwftxldbybmtemgtfreieloqyaozc5ilmeuie91cknvktesmbaga1uecwwju1nmierlchqumqswcqydvqqidajzwtekmcigcsqgsib3dqejaryvc3nslwfkbwluqgv4yw1wbguuy29tmrewdwydvqqpdahkb2huiervztemmaoga1uebawdrg9lmq0wcwydvqqqdarkb2humqwwcgydvqqrdankweqxdtalbgnvbc4tbhnvbwuwggiima0gcsqgsib3dqebaquaa4icdwawggikaoicaqdli0xuep6r94lf5yn0lqni2qljtf4yiuapwsph1g6jutldcr5f70bkaxagznzkxssbrgu+zwviphu1kilnx1youhfdzdx0ecmayw22zet4p8f88slnmhquxixjypopo+2bhz8u1by7ojdccw94jhmhbug07whiu8y54wijgjv3xwnvgaorjtxs3csubmldfki7s9gfgvqpokqpbbl+v37vbvkzgs3bw4lf7apyqe9q63q2held8/aabatujhgn1bzstruvda9fkktdlvkn6furaeccdc+eaonpsxwimp/d01wukofojywmbgbm7a/bpby0uxyqwmkxztquxd8mdaev89oao4ijuo8q50+9xehtb/q4tdhzjjw5k6xxqfxatrqa/xmn8fmitvddirxqaz4ttvpdeqxnudh3retzbgoqzy4mqcgzv723tdbfzlgiqnif1atjueotmbl7juj/1qulrpb+/ayzgqrg0xlpjr3h1essebn1ts8elvk5z6ekp5urrjlv3z2qq1vsn/ngnqkviyeppwj1wgxkkmaz3d6i3gixqpmklno2wdorwf/m+opuc5+bl8nhpc0hirodi8vnkbj5mimqazwfnfhq1vveihkzxfeuee8y1r7ju/mo5qd1z6wato77vcqd2g1xgqdjy7hrzgvmx/m9rrhqe57gyqidaqabozywndatbgnvhsueddakbggrbgefbqcdatadbgnvhq4efgqu8wifqbhufesmbdsbjclj4zhcynewdqyjkozihvcnaqelbqadggibafx4qapmwkzd6juofcdmdxynjzlgyu0vtosjaor5vck8qk/rhpqmg/j+eoikjy+xyh72wuovp25z2c99gyeyx3ve2ttsqq9uhz5eeonvi4h5em68s5hwpywwo2u5fsvcofmpbeft/vtuvt+jczpxvrzz3a9zbwkapivoclp5y9ikslzrkbvosafanfeffk/kyootrnoe/ahpezua8efkrlh4ggp8nzzcjamwwaoqkf3ohufizyaenja6sm37id3eqwvsrtwkrrdkci6nqcpf0tpvxwazist2+tyimbuhacq7qc1vhul9oyabhgjkgvhqsxxuybobqaoxdvmjueapdzgzfljlpari7aao1vamft1/+4ulio1p9egkqdtzuu4grvbwo1pftj/alp2o/b/fnecevlphnlast+frldymrnszr3uv47pzpuka1+zivmpkk0kwjcb1xdficpj0t9uc7bmueyrxkf9zytbf9iqzlfnl1lrxdod7/tf/gjlwbtiei8gwi38fimhy6iawl2epk1gzq3wep0km/lx6ol5dgmrr2sbczecqhzvb7ya7k28iff2wma9txl/nbdhw57/7bclkbevaniwgvuqroggrmlxgz1xp51mthl8bl2zn+q4x7xjvfvxbetfwxa8b9vlho1qkdzcdrgzt5jebpm5zgj5k-----end certificate-----`

登录后复制

输出:

CN=secure.example.com,OU=SSL Dept.,O=MyCo LLC LTD INC (d.b.a. OurCo),L=Fun Land,ST=YY,C=XX,2.5.4.46=#1304736f6d65,2.5.4.43=#13034a5844,2.5.4.42=#13044a6f686e,2.5.4.4=#1303446f65,2.5.4.41=#13084a6f686e20446f65,1.2.840.113549.1.9.1=#0c1573736c2d61646d696e406578616d706c652e636f6dCN=secure.example.com,OU=SSL Dept.,O=MyCo LLC LTD INC (d.b.a. OurCo),L=Fun Land,ST=YY,C=XXCN=secure.example.com,OU=SSL Dept.,O=MyCo LLC LTD INC (d.b.a. OurCo),L=Fun Land,ST=YY,C=XX,initials=JXD,dnQualifier=some

登录后复制

以上就是从字符串格式的 x509 证书生成主题名称的详细内容,更多请关注【创想鸟】其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/2483865.html

(0)
上一篇 2025年3月4日 21:24:46
下一篇 2025年3月4日 21:25:03

AD推荐 黄金广告位招租... 更多推荐

相关推荐

  • 深入了解Go语言库:五个不可错过的利器

    标题:深入了解Go语言库:五个不可错过的利器 Go语言作为一门快速、高效的编程语言,其标准库和第三方库为开发者提供了丰富的工具和资源。本文将介绍五个在Go语言开发中不可错过的利器,让我们一起深入了解这些强大的库,并附上具体的代码示例。 1.…

    2025年3月4日
    200
  • 提升编程效率:Golang工具助力方案

    Golang是一种受欢迎的开发语言,它具有高效的并发能力和简洁的语法,深受开发者的喜爱。然而,在实际编程过程中,我们常常会遇到一些重复的任务或者困难的问题,这时就需要借助一些优秀的辅助工具来提高开发效率和质量。本文将介绍一些常用的Golan…

    2025年3月4日
    200
  • Go语言编程:提高效率的简洁实践

    Golang简洁之道:高效编程实践 作为一种简洁高效的编程语言,Golang(又称Go语言)在近年来逐渐受到程序员们的关注和喜爱。其简洁的语法、快速的编译速度以及强大的并发特性,使得Golang成为许多开发者们的首选之一。然而,要想在Gol…

    2025年3月4日
    200
  • 发现Golang对云计算的推动力量

    Golang,也称作Go语言,是由Google开发的一种编程语言,是一种面向并发编程和网络编程的高级编程语言。近年来,随着云计算技术的快速发展,Golang在云计算领域的应用也逐渐得到重视。本文将探索Golang如何助力云计算发展,通过具体…

    2025年3月4日
    200
  • 五大必学类库助力Go语言学习之路

    五大必学类库助力Go语言学习之路 Go语言作为一门简洁高效的编程语言,越来越受到开发者的喜爱。为了更好地学习和应用Go语言,掌握一些常用的类库是必不可少的。本文将介绍五大必学类库,分别是: fmt: fmt类库是Go语言中用于格式化输入输出…

    2025年3月4日
    200
  • 探秘大公司Go语言应用场景

    探秘大公司Go语言应用场景 Go语言,也被称为Golang,是一种由谷歌开发的开源编程语言。自诞生以来,Go语言以其简洁、高效、并发性强等特点备受程序员们的青睐。越来越多的大公司也开始将Go语言应用于其项目开发中,并取得了显著成效。本文将探…

    2025年3月4日
    200
  • golang在跨语言开发中的应用探讨

    「Golang在跨语言开发中的应用探讨」 Go语言(Golang)作为一种开源的静态编程语言,由Google开发,具有高效的并发性能和简洁的语法设计,越来越受到开发者的青睐。在当今跨语言开发的背景下,Golang的应用越来越广泛,尤其在构建…

    2025年3月4日
    200
  • 深度解读:Go语言开发者必知的优秀项目

    Go语言是一门快速高效的编程语言,因其简洁易用的特点越来越受到开发者的青睐。在开发过程中,借助一些优秀的第三方项目可以大大提高开发效率和性能。本文将深度解读一些Go语言开发者必知的优秀项目,并提供具体的代码示例。 1. Go语言标准库 Go…

    2025年3月4日
    200
  • 了解GO语言在哪些领域有出色表现?

    GO语言作为一种高效、简洁、并发特性显著的编程语言,其在众多领域都有出色的表现。本文将介绍GO语言在网络编程、云计算、区块链、人工智能等领域的应用,并提供一些具体的代码示例。 首先,让我们来看GO语言在网络编程方面的表现。由于GO语言天生支…

    2025年3月4日
    200
  • Go语言编程实例:Web开发中的代码示例

    《Go语言编程实例:Web开发中的代码示例》 随着互联网的快速发展,Web开发已经成为各行业中必不可少的一部分。作为一门功能强大且性能优越的编程语言,Go语言在Web开发中越来越受到开发者们的青睐。本文将通过具体的代码示例,介绍如何利用Go…

    2025年3月4日
    200

发表回复

登录后才能评论