我正在尝试构建一个示例Web应用程序,演示使用go后端的休息技术,在前端提供基于json的请求和javascript,jquery(我不使用包).html/template
文件服务器 "returns a handler that serves HTTP requests with the contents of the file system rooted at root."
supose说我发表我的static文件夹包含index.html和scripts文件夹拿着一些javascript 文件.
如何阻止客户端查看我的js文件(仅发布index.htmlat /)?
你可以很容易地限制FileServer,这是HttpHandler通过HttpHandler围绕它包装另一个.例如,使用这个仅允许提供*.js文件的包装器:
func GlobFilterHandler(h http.Handler, pattern string) http.Handler {
return http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
path := r.URL.Path
fileName := filepath.Base(path)
if ok, err := filepath.Match(pattern, fileName); !ok || err != nil {
if err != nil {
log.Println("Error in pattern match:", err)
}
http.NotFound(w, r)
return
}
h.ServeHTTP(w, r)
})
}
func main() {
fileHandler := http.FileServer(http.Dir("/tmp/dtest"))
wrappedHandler := GlobFilterHandler(fileHandler, "*.js")
}
Run Code Online (Sandbox Code Playgroud)
您拥有的另一个选择是扩展http.Dir并制作您自己的http.FileSystem实现,它完全符合您的要求:
type GlobDir struct {
Dir http.Dir
Pattern string
}
func (d GlobDir) Open(name string) (http.File, error) {
baseName := filepath.Base(name)
if ok, err := filepath.Match(d.Pattern, baseName); !ok || err != nil {
if err != nil {
return nil, err
}
return nil, fmt.Errorf("%s not match GlobDir pattern.", baseName)
}
return d.Dir.Open(name)
}
func main() {
fileHandler := http.FileServer(GlobDir{
Dir: http.Dir("/tmp/dtest"),
Pattern: "*.js",
})
http.ListenAndServe(":8080", fileHandler)
}
Run Code Online (Sandbox Code Playgroud)
第二种解决方案实现了http.FileSystem接受的接口http.FileServer.它检查输入文件名是否与提供的模式匹配,然后将控制权控制为原始模式http.Dir.这可能就是你想去的地方.
| 归档时间: |
|
| 查看次数: |
208 次 |
| 最近记录: |