diff options
author | Petar Maymounkov <petarm@gmail.com> | 2010-02-05 18:32:02 -0800 |
---|---|---|
committer | Petar Maymounkov <petarm@gmail.com> | 2010-02-05 18:32:02 -0800 |
commit | e9a99e594a08526d8ebb1e0ef083c93831b16a6f (patch) | |
tree | c901e1545a0f13aaedf59d05c2e664791f9f78c7 /src/pkg/http/request.go | |
parent | 180da78b10b84d4923a8430a0ec130502dca05ee (diff) | |
download | golang-e9a99e594a08526d8ebb1e0ef083c93831b16a6f.tar.gz |
http: sort header keys when writing Response or Request to wire
R=rsc
CC=golang-dev
http://codereview.appspot.com/203050
Committer: Russ Cox <rsc@golang.org>
Diffstat (limited to 'src/pkg/http/request.go')
-rw-r--r-- | src/pkg/http/request.go | 11 |
1 files changed, 3 insertions, 8 deletions
diff --git a/src/pkg/http/request.go b/src/pkg/http/request.go index 0c8748586..17afc9cc1 100644 --- a/src/pkg/http/request.go +++ b/src/pkg/http/request.go @@ -49,6 +49,8 @@ type badStringError struct { func (e *badStringError) String() string { return fmt.Sprintf("%s %q", e.what, e.str) } +var reqExcludeHeader = map[string]int{"Host": 0, "User-Agent": 0, "Referer": 0} + // A Request represents a parsed HTTP request header. type Request struct { Method string // GET, POST, PUT, etc. @@ -169,14 +171,7 @@ func (req *Request) Write(w io.Writer) os.Error { // from Request, and introduce Request methods along the lines of // Response.{GetHeader,AddHeader} and string constants for "Host", // "User-Agent" and "Referer". - for k, v := range req.Header { - // Host, User-Agent, and Referer were sent from structure fields - // above; ignore them if they also appear in req.Header. - if k == "Host" || k == "User-Agent" || k == "Referer" { - continue - } - io.WriteString(w, k+": "+v+"\r\n") - } + writeSortedKeyValue(w, req.Header, reqExcludeHeader) io.WriteString(w, "\r\n") |