dongpan2788 2015-05-20 17:32
浏览 108
已采纳

如何访问接口属性

It was my intention to use the HTTP status codes both in the header and the body of the two response structs. Bu that without setting the status code twice as function parameter and again for the struct to avoid redundancy.

The parameter response of JSON() is an interface to allow both structs to be accepted. The compiler throws the following exception:

response.Status undefined (type interface {} has no field or method Status)

because the response field must not have a status attribute. Is there an alternative way to avoid setting the status code twice?

type Response struct {
    Status int         `json:"status"`
    Data   interface{} `json:"data"`
}

type ErrorResponse struct {
    Status int      `json:"status"`
    Errors []string `json:"errors"`
}

func JSON(rw http.ResponseWriter, response interface{}) {
    payload, _ := json.MarshalIndent(response, "", "    ")
    rw.WriteHeader(response.Status)
    ...
}
  • 写回答

2条回答 默认 最新

  • douguanya4248 2015-05-20 17:41
    关注

    The type response in rw.WriteHeader(response.Status) is interface{}. In Go, you need to explicitly assert the type of the underlying struct and then access the field:

    func JSON(rw http.ResponseWriter, response interface{}) {
        payload, _ := json.MarshalIndent(response, "", "    ")
        switch r := response.(type) {
        case ErrorResponse:
            rw.WriteHeader(r.Status)
        case Response:
            rw.WriteHeader(r.Status) 
        }
        ...
    }
    

    A better and the preferred way to do this however is to define a common interface for your responses, that has a method for getting the status of the response:

    type Statuser interface {
        Status() int
    }
    
    // You need to rename the fields to avoid name collision.
    func (r Response) Status() int { return r.ResStatus }
    func (r ErrorResponse) Status() int { return r.ResStatus }
    
    func JSON(rw http.ResponseWriter, response Statuser) {
        payload, _ := json.MarshalIndent(response, "", "    ")
        rw.WriteHeader(response.Status())
        ...
    }
    

    And it's better to rename Response to DataResponse and ResponseInterface to Response, IMO.

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

悬赏问题

  • ¥15 用windows做服务的同志有吗
  • ¥60 求一个简单的网页(标签-安全|关键词-上传)
  • ¥35 lstm时间序列共享单车预测,loss值优化,参数优化算法
  • ¥15 Python中的request,如何使用ssr节点,通过代理requests网页。本人在泰国,需要用大陆ip才能玩网页游戏,合法合规。
  • ¥100 为什么这个恒流源电路不能恒流?
  • ¥15 有偿求跨组件数据流路径图
  • ¥15 写一个方法checkPerson,入参实体类Person,出参布尔值
  • ¥15 我想咨询一下路面纹理三维点云数据处理的一些问题,上传的坐标文件里是怎么对无序点进行编号的,以及xy坐标在处理的时候是进行整体模型分片处理的吗
  • ¥15 一直显示正在等待HID—ISP
  • ¥15 Python turtle 画图