Changes regarding review

Use path.Join and then check if the request had a slash at the end to
place it again.
This commit is contained in:
Maxime 2015-07-12 21:22:15 +02:00
parent eea68c34ad
commit d9ebc5398a

View file

@ -7,7 +7,8 @@ import (
"html"
"net/http"
"net/url"
"regexp"
"path"
"strings"
"github.com/mholt/caddy/middleware"
)
@ -27,9 +28,10 @@ func (rd Redirect) ServeHTTP(w http.ResponseWriter, r *http.Request) (int, error
if err != nil {
return http.StatusInternalServerError, err
}
newPath := toURL.Host + toURL.Path + r.URL.Path
rmSlashs := regexp.MustCompile("//+")
newPath = rmSlashs.ReplaceAllString(newPath, "/")
newPath := path.Join(toURL.Host, toURL.Path, r.URL.Path)
if strings.HasSuffix(r.URL.Path, "/") {
newPath = newPath + "/"
}
newPath = toURL.Scheme + "://" + newPath
parameters := toURL.Query()
for k, v := range r.URL.Query() {