修复解析xml字段int类型传string值失败问题

This commit is contained in:
yangjiechina
2024-08-11 14:06:06 +08:00
parent 3a79cbb8ac
commit d3593b1f82
2 changed files with 6 additions and 16 deletions

View File

@@ -53,7 +53,7 @@ type Channel struct {
Certifiable int `xml:"Certifiable,omitempty"` Certifiable int `xml:"Certifiable,omitempty"`
ErrCode int `xml:"ErrCode,omitempty"` ErrCode int `xml:"ErrCode,omitempty"`
EndTime string `xml:"EndTime,omitempty"` EndTime string `xml:"EndTime,omitempty"`
Secrecy int `xml:"Secrecy,omitempty"` Secrecy string `xml:"Secrecy,omitempty"`
IPAddress string `xml:"IPAddress,omitempty"` IPAddress string `xml:"IPAddress,omitempty"`
Port int `xml:"Port,omitempty"` Port int `xml:"Port,omitempty"`
Password string `xml:"Password,omitempty"` Password string `xml:"Password,omitempty"`

20
xml.go
View File

@@ -7,21 +7,11 @@ import (
"golang.org/x/text/encoding/simplifiedchinese" "golang.org/x/text/encoding/simplifiedchinese"
"golang.org/x/text/transform" "golang.org/x/text/transform"
"io" "io"
"io/ioutil"
"strings"
) )
func GbkToUtf8(s []byte) ([]byte, error) { func GbkToUtf8(s []byte) ([]byte, error) {
reader := transform.NewReader(bytes.NewReader(s), simplifiedchinese.GBK.NewDecoder()) reader := transform.NewReader(bytes.NewReader(s), simplifiedchinese.GBK.NewDecoder())
return io.ReadAll(reader)
d, e := ioutil.ReadAll(reader)
if e != nil {
return nil, e
}
return d, nil
} }
func DoDecodeXML(data []byte, message interface{}) error { func DoDecodeXML(data []byte, message interface{}) error {
@@ -34,16 +24,16 @@ func DoDecodeXML(data []byte, message interface{}) error {
} }
func DecodeXML(data []byte, message interface{}) error { func DecodeXML(data []byte, message interface{}) error {
uft8Data := []byte(strings.Replace(string(data), "GB2312", "UTF-8", 1)) //uft8Data := []byte(strings.Replace(string(data), "GB2312", "UTF-8", 1))
uft8Data := data
err := DoDecodeXML(uft8Data, message) err := DoDecodeXML(uft8Data, message)
if err != nil { if err != nil {
utf8, err := GbkToUtf8(uft8Data) uft8Data, err = GbkToUtf8(uft8Data)
if err != nil { if err != nil {
return err return err
} }
err = DoDecodeXML(uft8Data, utf8) err = DoDecodeXML(uft8Data, message)
} }
return err return err