mirror of
https://github.com/caddyserver/caddy.git
synced 2024-12-26 13:43:47 +03:00
fastcgi: Protect against requests with null bytes in the path (#4614)
This commit is contained in:
parent
ab0455922a
commit
c8f2834b51
1 changed files with 7 additions and 0 deletions
|
@ -110,6 +110,13 @@ func (t *Transport) Provision(ctx caddy.Context) error {
|
|||
|
||||
// RoundTrip implements http.RoundTripper.
|
||||
func (t Transport) RoundTrip(r *http.Request) (*http.Response, error) {
|
||||
// Disallow null bytes in the request path, because
|
||||
// PHP upstreams may do bad things, like execute a
|
||||
// non-PHP file as PHP code. See #4574
|
||||
if strings.Contains(r.URL.Path, "\x00") {
|
||||
return nil, caddyhttp.Error(http.StatusBadRequest, fmt.Errorf("invalid request path"))
|
||||
}
|
||||
|
||||
env, err := t.buildEnv(r)
|
||||
if err != nil {
|
||||
return nil, fmt.Errorf("building environment: %v", err)
|
||||
|
|
Loading…
Reference in a new issue