mirror of
https://github.com/golang/go
synced 2024-11-21 17:04:42 -07:00
net/http/httputil: fix joinURLPath unexpectedly appends a trailing slash
Fixes #50337
This commit is contained in:
parent
ea537cca31
commit
29b349708f
@ -207,6 +207,9 @@ type BufferPool interface {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func singleJoiningSlash(a, b string) string {
|
func singleJoiningSlash(a, b string) string {
|
||||||
|
if b == "" {
|
||||||
|
return a
|
||||||
|
}
|
||||||
aslash := strings.HasSuffix(a, "/")
|
aslash := strings.HasSuffix(a, "/")
|
||||||
bslash := strings.HasPrefix(b, "/")
|
bslash := strings.HasPrefix(b, "/")
|
||||||
switch {
|
switch {
|
||||||
@ -227,14 +230,16 @@ func joinURLPath(a, b *url.URL) (path, rawpath string) {
|
|||||||
apath := a.EscapedPath()
|
apath := a.EscapedPath()
|
||||||
bpath := b.EscapedPath()
|
bpath := b.EscapedPath()
|
||||||
|
|
||||||
aslash := strings.HasSuffix(apath, "/")
|
if bpath != "" {
|
||||||
bslash := strings.HasPrefix(bpath, "/")
|
aslash := strings.HasSuffix(apath, "/")
|
||||||
|
bslash := strings.HasPrefix(bpath, "/")
|
||||||
|
|
||||||
switch {
|
switch {
|
||||||
case aslash && bslash:
|
case aslash && bslash:
|
||||||
return a.Path + b.Path[1:], apath + bpath[1:]
|
return a.Path + b.Path[1:], apath + bpath[1:]
|
||||||
case !aslash && !bslash:
|
case !aslash && !bslash:
|
||||||
return a.Path + "/" + b.Path, apath + "/" + bpath
|
return a.Path + "/" + b.Path, apath + "/" + bpath
|
||||||
|
}
|
||||||
}
|
}
|
||||||
return a.Path + b.Path, apath + bpath
|
return a.Path + b.Path, apath + bpath
|
||||||
}
|
}
|
||||||
|
@ -1662,6 +1662,29 @@ func TestJoinURLPath(t *testing.T) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func TestJoinURLPath_trailingSlash(t *testing.T) {
|
||||||
|
tests := []struct {
|
||||||
|
a *url.URL
|
||||||
|
b *url.URL
|
||||||
|
wantPath string
|
||||||
|
wantRaw string
|
||||||
|
}{
|
||||||
|
{&url.URL{Path: "/a/b"}, &url.URL{Path: ""}, "/a/b", ""},
|
||||||
|
{&url.URL{Path: "/a/b", RawPath: "/a%2Fb"}, &url.URL{Path: ""}, "/a/b", "/a%2Fb"},
|
||||||
|
}
|
||||||
|
|
||||||
|
for _, tt := range tests {
|
||||||
|
p, rp := joinURLPath(tt.a, tt.b)
|
||||||
|
if p != tt.wantPath || rp != tt.wantRaw {
|
||||||
|
t.Errorf("joinURLPath(URL(%q,%q),URL(%q,%q)) want (%q,%q) got (%q,%q)",
|
||||||
|
tt.a.Path, tt.a.RawPath,
|
||||||
|
tt.b.Path, tt.b.RawPath,
|
||||||
|
tt.wantPath, tt.wantRaw,
|
||||||
|
p, rp)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
func TestReverseProxyRewriteReplacesOut(t *testing.T) {
|
func TestReverseProxyRewriteReplacesOut(t *testing.T) {
|
||||||
const content = "response_content"
|
const content = "response_content"
|
||||||
backend := httptest.NewServer(http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
|
backend := httptest.NewServer(http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
|
||||||
|
Loading…
Reference in New Issue
Block a user