## 靜態資源綁定
在 [請求與響應/路由](1789787) 章節已經描述了如何通過路由方法綁定本地靜態資源目錄,實現文件服務,通過該章節的方法能快速生成一個簡單的文件服務;而本章節將介紹一種更為復雜的場景。
有部分應用對靜態資源是有權限控制的,比如需要登錄后、校驗特定用戶屬性后才能訪問等,為了實現這種場景框架在 `v0.5.6` 版本加入了執行自定義 httpHandler 方法;
## 執行自定義 httpHandler
實現一個文件服務的核心方法如下所示:
~~~
handler:=http.FileServer(http.Dir("./storage"))
~~~
該方法獲得一個原生的 httpHandler, 為了實現當前的場景,我們需要通過 Orange 框架,中間件,對相關用戶的屬性進行驗證,通過后才執行文件服務的核心方法,流程如下圖所示。

通過在框架控制器內部執行原始 httpHandler 實現對文件服務的實現,以相同的方法思想,只要是原始的 httpHandler 都能運行,可以更加靈活的實現各類功能。
## 代碼示例
回到靜態資源綁定這個使用場景,實現一個帶驗證功能的文件服務代碼如下:
~~~
app.NewRouter("").GET("/assets/*", func(c *app.Context) error {
// 驗證邏輯
//....
// 將URL重新定義成路由指定文件相對路徑
c.Request().URL.Path = "/" + c.GetPathParam("*")
// 將訪問該目錄下靜態文件
fc := http.FileServer(http.Dir("./storage"))
c.RunHttpHandler(fc)
return nil
})
~~~
通過上述代碼,我們可以實現如下效果:
用戶訪問 `http://127.0.0.1:8088/assets/orange.txt` 頁面將 `./storage/orange.txt` 該文件輸出到頁面。