在使用Context.ResponseWriter中的Set/WriteHeader/Write这三个方法时,使用顺序必须如下所示,否则会出现某一设置不生效的情况。
1
2
3
|
ctx.ResponseWriter.Header().Set("Content-type", "application/text")
ctx.ResponseWriter.WriteHeader(403)
ctx.ResponseWriter.Write([]byte(resp))
|
如1:
1
2
3
|
ctx.ResponseWriter.Header().Set("Content-type", "application/text")
ctx.ResponseWriter.Write([]byte(resp))
ctx.ResponseWriter.WriteHeader(403)
|
会导致返回码一直是200
补充:Go里w http.ResponseWriter,调用w.Write()方法报错
Go里w http.ResponseWriter写入报错
http: request method or response status code does not allow
1. 下面是报错截图
2. 点进去Write方法
它首先是一个接口;
由于它是在HTTP web服务器的应用场景,所以它具体的实现方法在net/http/server.go里:
1
2
3
|
func (w *response) Write(data []byte) (n int, err error) {
return w.write(len(data), data, "")
}
|
再点进去,函数里你会发现有一个关键的判断
1
2
3
4
5
6
|
// 其中ErrBodyNotAllowed的
// 代码内容
// ErrBodyNotAllowed = errors.New("http: request method or response status code does not allow body")
if !w.bodyAllowed() {
return 0, ErrBodyNotAllowed
}
|
点进去,发现它在没有设置Header时会panic,当然这跟我们当前要讨论的问题关系不大,关键在bodyAllowedForStatus()方法
1
2
3
4
5
6
|
func (w *response) bodyAllowed() bool {
if !w.wroteHeader {
panic("")
}
return bodyAllowedForStatus(w.status)
}
|
再点,终于看到了,当设置状态码为【100,199】、204、304就会报这个错,而我刚好设置的状态码就是204,我把它改成200重新试下,问题解决。
1
2
3
4
5
6
7
8
9
10
11
|
func bodyAllowedForStatus(status int) bool {
switch {
case status >= 100 && status <= 199:
return false
case status == 204:
return false
case status == 304:
return false
}
return true
}
|
以上为个人经验,希望能给大家一个参考,也希望大家多多支持服务器之家。如有错误或未考虑完全的地方,望不吝赐教。
原文链接:https://blog.csdn.net/u012107512/article/details/80691423