From 0e889877094eda4725e3bc9247a3bc4b7998d728 Mon Sep 17 00:00:00 2001 From: wenzi1 Date: Tue, 29 May 2018 23:23:49 +0800 Subject: [PATCH] =?UTF-8?q?=E4=BF=AE=E5=A4=8D=E5=BD=93xml=E4=B8=ADencoding?= =?UTF-8?q?=E5=AD=97=E7=AC=A6=E9=9B=86=E4=B8=BA=E9=9D=9EUTF-8=E5=AD=97?= =?UTF-8?q?=E7=AC=A6=E9=9B=86=E6=97=B6=E6=8A=A5=E9=94=99=E7=9A=84=E9=97=AE?= =?UTF-8?q?=E9=A2=98?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- g/encoding/gxml/gxml.go | 22 ++++++++++++++++++++-- 1 file changed, 20 insertions(+), 2 deletions(-) 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 {