代码拉取完成,页面将自动刷新
package wxpay
import (
"bytes"
"crypto/tls"
"encoding/pem"
"encoding/xml"
"golang.org/x/crypto/pkcs12"
"log"
"strconv"
"strings"
"time"
)
func XmlToMap(xmlStr string) Params {
params := make(Params)
decoder := xml.NewDecoder(strings.NewReader(xmlStr))
var (
key string
value string
)
for t, err := decoder.Token(); err == nil; t, err = decoder.Token() {
switch token := t.(type) {
case xml.StartElement: // 开始标签
key = token.Name.Local
case xml.CharData: // 标签内容
content := string([]byte(token))
value = content
}
if key != "xml" {
if value != "\n" {
params.SetString(key, value)
}
}
}
return params
}
func MapToXml(params Params) string {
var buf bytes.Buffer
buf.WriteString(`<xml>`)
for k, v := range params {
buf.WriteString(`<`)
buf.WriteString(k)
buf.WriteString(`><![CDATA[`)
buf.WriteString(v)
buf.WriteString(`]]></`)
buf.WriteString(k)
buf.WriteString(`>`)
}
buf.WriteString(`</xml>`)
return buf.String()
}
// 用时间戳生成随机字符串
func nonceStr() string {
return strconv.FormatInt(time.Now().UTC().UnixNano(), 10)
}
// 将Pkcs12转成Pem
func pkcs12ToPem(p12 []byte, password string) tls.Certificate {
blocks, err := pkcs12.ToPEM(p12, password)
// 从恐慌恢复
defer func() {
if x := recover(); x != nil {
log.Print(x)
}
}()
if err != nil {
panic(err)
}
var pemData []byte
for _, b := range blocks {
pemData = append(pemData, pem.EncodeToMemory(b)...)
}
cert, err := tls.X509KeyPair(pemData, pemData)
if err != nil {
panic(err)
}
return cert
}
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。