mirror of
https://github.com/caddyserver/caddy.git
synced 2025-01-21 04:25:15 +08:00
Merge pull request #1584 from tw4452852/encoded_path
proxy: use untouched URL for concatenating
This commit is contained in:
commit
236341f78b
|
@ -26,6 +26,7 @@ import (
|
|||
|
||||
"github.com/mholt/caddy/caddyfile"
|
||||
"github.com/mholt/caddy/caddyhttp/httpserver"
|
||||
"github.com/mholt/caddy/caddyhttp/staticfiles"
|
||||
|
||||
"golang.org/x/net/websocket"
|
||||
)
|
||||
|
@ -896,6 +897,7 @@ func basicAuthTestcase(t *testing.T, upstreamUser, clientUser *url.Userinfo) {
|
|||
|
||||
func TestProxyDirectorURL(t *testing.T) {
|
||||
for i, c := range []struct {
|
||||
originalPath string
|
||||
requestURL string
|
||||
targetURL string
|
||||
without string
|
||||
|
@ -969,6 +971,12 @@ func TestProxyDirectorURL(t *testing.T) {
|
|||
targetURL: `https://localhost:2021/%2C`,
|
||||
expectURL: `https://localhost:2021/%2C/%2C`,
|
||||
},
|
||||
{
|
||||
originalPath: `///test`,
|
||||
requestURL: `http://localhost:2020/%2F/test`,
|
||||
targetURL: `https://localhost:2021/`,
|
||||
expectURL: `https://localhost:2021/%2F/test`,
|
||||
},
|
||||
} {
|
||||
targetURL, err := url.Parse(c.targetURL)
|
||||
if err != nil {
|
||||
|
@ -980,6 +988,8 @@ func TestProxyDirectorURL(t *testing.T) {
|
|||
t.Errorf("case %d failed to create request: %s", i, err)
|
||||
continue
|
||||
}
|
||||
req = req.WithContext(context.WithValue(req.Context(),
|
||||
staticfiles.URLPathCtxKey, c.originalPath))
|
||||
|
||||
NewSingleHostReverseProxy(targetURL, c.without, 0).Director(req)
|
||||
if expect, got := c.expectURL, req.URL.String(); expect != got {
|
||||
|
|
|
@ -25,6 +25,7 @@ import (
|
|||
"golang.org/x/net/http2"
|
||||
|
||||
"github.com/mholt/caddy/caddyhttp/httpserver"
|
||||
"github.com/mholt/caddy/caddyhttp/staticfiles"
|
||||
)
|
||||
|
||||
var (
|
||||
|
@ -154,7 +155,13 @@ func NewSingleHostReverseProxy(target *url.URL, without string, keepalive int) *
|
|||
prefer(target.RawPath, target.Path),
|
||||
prefer(req.URL.RawPath, req.URL.Path))
|
||||
}
|
||||
req.URL.Path = singleJoiningSlash(target.Path, req.URL.Path)
|
||||
untouchedPath, _ := req.Context().Value(staticfiles.URLPathCtxKey).(string)
|
||||
req.URL.Path = singleJoiningSlash(target.Path,
|
||||
prefer(untouchedPath, req.URL.Path))
|
||||
// req.URL.Path must be consistent with decoded form of req.URL.RawPath if any
|
||||
if req.URL.RawPath != "" && req.URL.RawPath != req.URL.EscapedPath() {
|
||||
panic("RawPath doesn't match Path")
|
||||
}
|
||||
|
||||
// Trims the path of the socket from the URL path.
|
||||
// This is done because req.URL passed to your proxied service
|
||||
|
|
Loading…
Reference in New Issue
Block a user