我的用例看起來像我知道客戶的公共證書并且只想允許它們。我有一個(gè)基于 gin 的 go 服務(wù)器和一個(gè) TLS 配置,其中我為屬性“VerifyPeerCertificate”分配了一個(gè)方法。該函數(shù)看起來像func customVerifyPeerCertificate(rawCerts [][]byte, verifiedChains [][]*x509.Certificate) error {if len(verifiedChains) < 1 { return errors.New("Verified certificate chains is empty.")}if len(verifiedChains[0]) < 1 { return errors.New("No certificates in certificate chains.")}if len(verifiedChains[0][0].Subject.CommonName) < 1 { return errors.New("Common name can not be empty.")}fmt.Println(verifiedChains[0][0].Raw)publicKeyDer, _ := x509.MarshalPKIXPublicKey(verifiedChains[0][0].PublicKey)publicKeyBlock := pem.Block{ Type: "CERTIFICATE", Bytes: publicKeyDer,}publicKeyPem := string(pem.EncodeToMemory(&publicKeyBlock))}然而,問題是變量“publicKeyPem”中的字符串看起來不像我用來向服務(wù)器發(fā)送請(qǐng)求的客戶端公共證書,它的長(zhǎng)度也較短。
在 go 中比較客戶端證書
慕田峪7331174
2023-07-17 16:28:46