JSON 응답에서 타임스탬프 형식 지정
Go의 시간 패키지는 타임스탬프를 표시하기 위한 time.Time 유형을 제공합니다. 그러나 json.NewEncoder를 사용하여 time.Time 객체를 JSON으로 인코딩하는 경우 시스템 친화적인 형식으로 형식이 지정됩니다. JSON 응답에서 타임스탬프 형식을 사용자 정의하려면 다음 단계를 따르세요.
타임스탬프 형식 사용자 정의
time.Time을 포함하고 Marshaler 인터페이스.
type JSONTime time.Time func (t JSONTime) MarshalJSON() ([]byte, error) { stamp := fmt.Sprintf("\"%s\"", time.Time(t).Format("Mon Jan _2")) return []byte(stamp), nil }
이 코드는 타임스탬프 형식을 "Mon Jan _2".
사용자 정의 시간 유형 사용
문서 구조에서 타임스탬프 필드에 JSONTime 유형을 사용합니다.
type Document struct { Name string Content string Stamp JSONTime Author string }
샘플 코드
문서 초기화 사용자 정의 타임스탬프:
testDoc := model.Document{"Meeting Notes", "These are some notes", JSONTime(time.Now()), "Bacon"}
이제 사용자 정의 타임스탬프 형식으로 응답을 보낼 수 있습니다:
sendResponse(testDoc, w,r)
참고:
또는 , timelib와 같은 라이브러리를 사용하여 타임스탬프 형식을 쉽게 사용자 정의할 수 있습니다. time.Time 값에 대한 MarshalJSON 메서드를 제공합니다.
위 내용은 Go의 JSON 응답에서 타임스탬프 형식을 어떻게 사용자 정의할 수 있나요?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!