Go의 요청 본문에서 JSON 검색
JSON 콘텐츠가 포함된 POST 요청으로 작업할 때 JSON 데이터를 추출해야 합니다. 요청 본문에서. 그러나 이는 Node.js와 같은 언어에서 코드를 마이그레이션하는 Go 초보자에게는 어려운 작업이 될 수 있습니다.
이 문제를 해결하기 위해 몇 가지 접근 방식이 시도되었습니다.
var v 인터페이스{}<br>err := json.NewDecoder(context.Request().Body).Decode(&v)<br>if err != nil {</p> <pre class="brush:php;toolbar:false">return result, err
}
fmt .Println(v)
이 예에서는 결과가 비어 있는 경우가 많아 본문이 비어 있음을 나타냅니다. 이는 http.Request.Body가 버퍼이고 일단 데이터를 읽으면 다시 읽을 수 없기 때문입니다.
또 다른 접근 방식은 다음과 같습니다.
m := echo .Map{}<br>if err := context.Bind(&m); err != nil {</p> <pre class="brush:php;toolbar:false">return result, err
}
fmt.Println(m)
여기서 코드는 "EOF"라는 오류 메시지를 표시합니다. ." 이 오류는 요청에 콘텐츠 유형 헤더가 없어 Echo가 전송되는 데이터 유형을 확인할 수 없기 때문에 발생합니다.
마지막으로 본문을 직접 읽으려는 시도:
< pre>body, error := ioutil.ReadAll(context.Request().Body)
if error != nil {
return result, error
}
fmt.Println(body)
ioutil.ReadAll()이 요청 본문을 소비하므로 빈 바이트 배열이 생성됩니다.
해결책은 http.Request.Body의 특성을 다음과 같이 이해하는 데 있습니다. 버퍼를 읽고 읽은 후 복원하는 방법을 찾는 것입니다. 다음 코드 조각은 해결 방법을 제공합니다.
// 본문 내용 읽기<br>var bodyBytes []byte<br>if context.Request().Body != nil {</p> <pre class="brush:php;toolbar:false">bodyBytes, _ = ioutil.ReadAll(context.Request().Body)
}
// io.ReadCloser를 원래 상태로 복원
context.Request().Body = ioutil.NopCloser(bytes.NewBuffer(bodyBytes))
// 구조체에 바인딩하는 것처럼 Body를 계속 사용합니다:
order := new(models.GeaOrder)
error := context.Bind(order)
이 해결 방법을 사용하면 이제 본문을 읽고, 나중에 사용할 수 있도록 내용을 보존하고, 해당 데이터를 구조체에 성공적으로 바인딩할 수 있습니다.
위 내용은 Go의 요청 본문에서 JSON 데이터를 검색하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!