JSON 언마샬링에서 Int64 필드에 대한 문자열 입력 처리
JSON 데이터를 Go 값으로 언마샬링하는 것은 때때로 문제에 직면할 수 있으며, 특히 정수 값. 이 문서에서는 문자열로 인코딩된 정수 필드를 사용하여 JSON 데이터를 역마샬링할 때 "json: 문자열을 int64 유형의 Go 값으로 역마샬링할 수 없습니다." 오류에 대한 해결 방법을 살펴봅니다.
문제 설명
설문조사 응답을 나타내는 다음 Go 구조체를 고려하세요.
type tySurvey struct { Id int64 `json:"id,omitempty"` Name string `json:"name,omitempty"` }
여기서 예를 들어, id 필드는 int64로 정의됩니다. tySurvey를 JSON으로 직렬화하고 클라이언트 측 조작을 위해 전송한 후 클라이언트는 이름 필드를 업데이트합니다. 그러나 데이터 전송 중에 실수로 id 필드를 문자열로 인코딩합니다.
서버에서 수정된 JSON 데이터를 수신하면 원래 tySurvey 구조체가 역마샬링되어 다음 오류가 발생합니다. "json: 문자열을 역마샬링할 수 없습니다. 유형의 Go 값 int64."
해결책
해결책은 유형 정의에 ,string을 추가하여 JSON 필드 태그를 수정하는 것입니다. 이는 json 역마샬러가 정수 값에 대한 문자열 표현을 허용하도록 지시합니다.
type tySurvey struct { Id int64 `json:"id,string,omitempty"` Name string `json:"name,omitempty"` }
,string 옵션을 사용하면 역마샬링 중에 문자열로 인코딩된 정수 값을 해당 Go 값으로 원활하게 변환할 수 있습니다.
추가 고려 사항
지정 시 생략 문자열로 인코딩된 정수 값을 사용하는 경우 빈 문자열을 디코딩할 수 없다는 점에 유의하는 것이 중요합니다. 이러한 제한으로 인해 인코딩 중에만 생략이 활용됩니다.
결론
JSON 필드 태그에 ,string을 추가하면 Go에서 문자열로 인코딩된 정수 값을 쉽게 역마샬링할 수 있습니다. 이 기술은 실수로 필드 유형을 변경할 수 있는 클라이언트 측 데이터 조작을 수용하여 데이터 처리를 단순화하고 코드 견고성을 향상시킵니다.
위 내용은 JSON 언마샬링에서 Int64 필드에 대한 문자열 입력을 처리하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!