diff --git a/g/encoding/gxml/gxml.go b/g/encoding/gxml/gxml.go index 4a132546b..e8e90bc5f 100644 --- a/g/encoding/gxml/gxml.go +++ b/g/encoding/gxml/gxml.go @@ -9,10 +9,20 @@ package gxml import ( "github.com/clbanning/mxj" + "encoding/xml" + "io" ) -// 将XML内容解析为map变量 +// 将XML内容解析为map变量,入口参数使用的字符集必须为UTF-8的 func Decode(xmlbyte []byte) (map[string]interface{}, error) { + //@author wenzi1 + //@date 2018-05-29 + //XML中的encoding如果非UTF-8时mxj包中会自动转换,但是自动转换时需要调用方提供转换的方法,这里提供一个空方法 + //所以如果涉及到字符集转换那么需要用户自行转为utf8时再调用该方法 + charsetReader := func(charset string, input io.Reader) (io.Reader, error) { + return input, nil + } + mxj.CustomDecoder = &xml.Decoder{CharsetReader:charsetReader} return mxj.NewMapXml(xmlbyte) } @@ -25,8 +35,16 @@ func EncodeWithIndent(v map[string]interface{}, rootTag...string) ([]byte, error return mxj.Map(v).XmlIndent("", "\t", rootTag...) } -// XML格式内容直接转换为JSON格式内容 +// XML格式内容直接转换为JSON格式内容,入口参数使用的字符集必须为UTF-8的 func ToJson(xmlbyte []byte) ([]byte, error) { + //@author wenzi1 + //@date 2018-05-29 + //XML中的encoding如果非UTF-8时mxj包中会自动转换,但是自动转换时需要调用方提供转换的方法,这里提供一个空方法 + //所以如果涉及到字符集转换那么需要用户自行转为utf8时再调用该方法 + charsetReader := func(charset string, input io.Reader) (io.Reader, error) { + return input, nil + } + mxj.CustomDecoder = &xml.Decoder{CharsetReader:charsetReader} if mv, err := mxj.NewMapXml(xmlbyte); err == nil { return mv.Json() } else {