为了账号安全,请及时绑定邮箱和手机立即绑定

使用 golang 时(进一步)限制表单的大小是否可取?

使用 golang 时(进一步)限制表单的大小是否可取?

Go
米脂 2021-09-13 15:16:07
我四处搜索,据我所知,POST 表单请求已经限制为 10MB(http://golang.org/src/net/http/request.go#L721)。如果我要在我的ServeHTTP方法中减少这种情况,我不确定如何正确地做到这一点。我会尝试这样的事情:r.Body = http.MaxBytesReader(w, r.Body, MaxFileSize) err := r.ParseForm()if err != nil {     //redirect to some error page     return}但是错误返回也会关闭连接吗?我将如何防止必须阅读所有内容?但是如果没有设置内容长度并且在阅读过程中我意识到文件太大了怎么办。我将此用作安全措施,以防止有人占用我的服务器资源。
查看完整描述

2 回答

?
互换的青春

TA贡献1797条经验 获得超6个赞

限制请求正文大小的正确方法是按照您的建议进行操作:


r.Body = http.MaxBytesReader(w, r.Body, MaxFileSize) 

err := r.ParseForm()

if err != nil {

 // redirect or set error status code.

 return

}

当达到限制时,MaxBytesReader在响应上设置一个标志。设置此标志后,服务器不会读取请求正文的其余部分,服务器会在处理程序返回时关闭连接。


如果您担心恶意客户端,那么您还应该设置Server.ReadTimeout、Server.WriteTimeout和可能的Server.MaxHeaderBytes。


如果要为所有处理程序设置请求正文限制,请使用在委派给根处理程序之前设置限制的处理程序包装根处理程序:


 type maxBytesHandler struct {

     h http.Handler

     n int64

 }


 func (h *maxBytesHandler) ServeHTTP(w http.ResponseWriter, r *http.Request) {

     r.Body = http.MaxBytesReader(w, r.Body, h.n) 

     h.h.ServeHTTP(w, r)

 }

调用 ListenAndServe 时包装根处理程序:


log.Fatal(http.ListenAndServe(":8080", &maxBytesHandler{h:mux, n:4096))

或者在配置服务器时:


s := http.Server{

    Addr: ":8080",

    Handler: &maxBytesReader{h:mux, n:4096},

}

log.Fatal(s.ListenAndServe())

不需要另一个答案中建议的补丁。MaxBytesReader 是限制请求正文大小的官方方法。


查看完整回答
反对 回复 2021-09-13
?
largeQ

TA贡献2039条经验 获得超7个赞

编辑:正如其他人所引用的 MaxByteReader 是支持的方式。有趣的是,默认读取器是在为最大字节读取器进行类型断言后的 limitreader。



查看完整回答
反对 回复 2021-09-13
  • 2 回答
  • 0 关注
  • 170 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信