json.Marshal에서 HTML 문자 이스케이프 우회
Go의 json.Marshal 함수는 < 및 >, 브라우저의 잘못된 해석을 방지합니다. 그러나 이 동작은 XML 데이터를 직렬화할 때 의도한 콘텐츠를 변경하므로 바람직하지 않을 수 있습니다.
안타깝게도 json.Marshal 함수만 사용하여 문자 이스케이프를 비활성화하는 것은 불가능합니다. 소스 코드에서는 문자 이스케이프가 true로 하드코딩되어 < > 항상 각각 "u003c" 및 "u003e"로 변환됩니다. 내부 json.Marshal 구현에 여전히 의존하기 때문에 이러한 제한 사항은 사용자 지정 MarshalJSON 메서드 구현까지 확장됩니다.
이 장애물을 극복하기 위한 해결 방법에는 마샬링을 위한 사용자 지정 함수를 정의하는 것이 포함됩니다. 다음은 JSON 메소드를 구현하는 수정된 버전의 Track 유형입니다.
import "bytes" import "encoding/json" type Track struct { XmlRequest string `json:"xmlRequest"` } func (t *Track) JSON() ([]byte, error) { buffer := &bytes.Buffer{} encoder := json.NewEncoder(buffer) encoder.SetEscapeHTML(false) err := encoder.Encode(t) return buffer.Bytes(), err }
이 사용자 정의 JSON 메소드를 사용하면 SetEscapeHTML(false)을 명시적으로 설정하여 이스케이프 동작을 제어할 수 있습니다.
모든 구조체에 대한 일반적인 솔루션이 필요한 경우 다음 함수를 정의할 수 있습니다.
import "bytes" import "encoding/json" func JSONMarshal(t interface{}) ([]byte, error) { buffer := &bytes.Buffer{} encoder := json.NewEncoder(buffer) encoder.SetEscapeHTML(false) err := encoder.Encode(t) return buffer.Bytes(), err }
위 내용은 Go의 `json.Marshal`에서 HTML 문자 이스케이프를 우회하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!