如何使用 OpenAPI 生成器客户端 SDK 访问 HTTP 错误正文

How do I get access to HTTP error body using a OpenAPI Generator Client SDK

OpenAPI Generator 创建 API 遵循一般模式的函数:

func (api *MyAPI) OperationId(context.Context) (ResponseStruct, *http.Response, error)

如何在出现错误时检索 HTTP 正文?当 HTTP 状态代码是错误时,error 不是 nil,但是,它不包括正文,*http.Response 也不包括正文,因为正文已被读取。而且,错误不会作为成功和失败定义解组到 ResponseStruct 中。不一样。

生成的客户端创建一个 mypackage.GenericOpenAPIError 结构,它作为 error 返回,其中 mypackage 是客户端的包名称。它将 HTTP 错误主体存储在 GenericOpenAPIError.body 属性 中,可以通过 Body() []byte 函数访问。但是,因为函数定义 returns 和 error 不支持 Body() 函数,所以在访问它之前需要转换错误。

这是从生成的客户端创建错误的代码:

if localVarHttpResponse.StatusCode >= 300 {
    newErr := GenericOpenAPIError{
        body:  localVarBody,
        error: localVarHttpResponse.Status,
    }

要访问主体 属性,需要转换错误。例如:

data, resp, err := myclient.MyAPI.OperationId(context.Background())
if err != nil && resp.StatusCode >= 300 {
    openAPIErr := err.(mypackage.GenericOpenAPIError)
    fmt.Println(string(openAPIErr.Body()))
}

由于需要将其解码为生成的客户端包中的结构,因此将其作为辅助函数添加到客户端包中会很有用。