代码拉取完成,页面将自动刷新
/*
Copyright IBM Corp. All Rights Reserved.
SPDX-License-Identifier: Apache-2.0
*/
/*
Notice: This file has been modified for Hyperledger Fabric SDK Go usage.
Please review third_party pinning scripts and patches for more details.
*/
package lib
import (
"crypto/tls"
"crypto/x509"
"encoding/hex"
"encoding/pem"
"net/http"
"gitee.com/bupt-zkjc/fabric-sdk-go/internal/github.com/hyperledger/fabric-ca/sdkinternal/pkg/util"
"github.com/pkg/errors"
)
var clientAuthTypes = map[string]tls.ClientAuthType{
"noclientcert": tls.NoClientCert,
"requestclientcert": tls.RequestClientCert,
"requireanyclientcert": tls.RequireAnyClientCert,
"verifyclientcertifgiven": tls.VerifyClientCertIfGiven,
"requireandverifyclientcert": tls.RequireAndVerifyClientCert,
}
// GetCertID returns both the serial number and AKI (Authority Key ID) for the certificate
func GetCertID(bytes []byte) (string, string, error) {
cert, err := BytesToX509Cert(bytes)
if err != nil {
return "", "", err
}
serial := util.GetSerialAsHex(cert.SerialNumber)
aki := hex.EncodeToString(cert.AuthorityKeyId)
return serial, aki, nil
}
// BytesToX509Cert converts bytes (PEM or DER) to an X509 certificate
func BytesToX509Cert(bytes []byte) (*x509.Certificate, error) {
dcert, _ := pem.Decode(bytes)
if dcert != nil {
bytes = dcert.Bytes
}
cert, err := x509.ParseCertificate(bytes)
if err != nil {
return nil, errors.Wrap(err, "Buffer was neither PEM nor DER encoding")
}
return cert, err
}
func addQueryParm(req *http.Request, name, value string) {
url := req.URL.Query()
url.Add(name, value)
req.URL.RawQuery = url.Encode()
}
// CertificateDecoder is needed to keep track of state, to see how many certificates
// have been returned for each enrollment ID.
type CertificateDecoder struct {
certIDCount map[string]int
storePath string
}
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。