http: download: use PathEscape instead of QueryEscape (#340)

pull/351/head
Equim 2018-01-23 16:28:08 +08:00 committed by Henrique Dias
parent e171f7ac12
commit d97f17facb
1 changed files with 2 additions and 2 deletions

View File

@ -71,7 +71,7 @@ func downloadHandler(c *fm.Context, w http.ResponseWriter, r *http.Request) (int
} }
name += extension name += extension
w.Header().Set("Content-Disposition", "attachment; filename*=utf-8''"+url.QueryEscape(name)) w.Header().Set("Content-Disposition", "attachment; filename*=utf-8''"+url.PathEscape(name))
err := ar.Write(w, files) err := ar.Write(w, files)
return 0, err return 0, err
@ -94,7 +94,7 @@ func downloadFileHandler(c *fm.Context, w http.ResponseWriter, r *http.Request)
w.Header().Set("Content-Disposition", "inline") w.Header().Set("Content-Disposition", "inline")
} else { } else {
// As per RFC6266 section 4.3 // As per RFC6266 section 4.3
w.Header().Set("Content-Disposition", "attachment; filename*=utf-8''"+url.QueryEscape(c.File.Name)) w.Header().Set("Content-Disposition", "attachment; filename*=utf-8''"+url.PathEscape(c.File.Name))
} }
http.ServeContent(w, r, stat.Name(), stat.ModTime(), file) http.ServeContent(w, r, stat.Name(), stat.ModTime(), file)