mirror of
https://github.com/duanhf2012/origin.git
synced 2026-03-06 22:27:36 +08:00
权限验证优化
This commit is contained in:
@@ -25,7 +25,7 @@ import (
|
|||||||
type HttpRedirectData struct {
|
type HttpRedirectData struct {
|
||||||
Url string
|
Url string
|
||||||
//Cookies map[string]string
|
//Cookies map[string]string
|
||||||
|
|
||||||
CookieList []*http.Cookie
|
CookieList []*http.Cookie
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -35,19 +35,19 @@ type HttpRequest struct {
|
|||||||
|
|
||||||
ParamStr string
|
ParamStr string
|
||||||
mapParam map[string]string
|
mapParam map[string]string
|
||||||
URL string
|
URL string
|
||||||
//Req http.Request
|
//Req http.Request
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
type HttpRespone struct {
|
type HttpRespone struct {
|
||||||
Respone []byte
|
Respone []byte
|
||||||
RedirectData HttpRedirectData
|
RedirectData HttpRedirectData
|
||||||
//Resp http.ResponseWriter
|
//Resp http.ResponseWriter
|
||||||
}
|
}
|
||||||
|
|
||||||
type ServeHTTPRouterMux struct {
|
type ServeHTTPRouterMux struct {
|
||||||
|
httpfiltrateList []HttpFiltrate
|
||||||
}
|
}
|
||||||
type ControllerMapsType map[string]reflect.Value
|
type ControllerMapsType map[string]reflect.Value
|
||||||
|
|
||||||
@@ -56,11 +56,11 @@ type HttpServerService struct {
|
|||||||
httpserver network.HttpServer
|
httpserver network.HttpServer
|
||||||
port uint16
|
port uint16
|
||||||
|
|
||||||
controllerMaps ControllerMapsType
|
controllerMaps ControllerMapsType
|
||||||
certfile string
|
certfile string
|
||||||
keyfile string
|
keyfile string
|
||||||
ishttps bool
|
ishttps bool
|
||||||
httpfiltrateList []HttpFiltrate
|
serverHTTPMux ServeHTTPRouterMux
|
||||||
}
|
}
|
||||||
|
|
||||||
type RouterMatchData struct {
|
type RouterMatchData struct {
|
||||||
@@ -116,7 +116,7 @@ func (slf *HttpRequest) Query(key string) (string, bool) {
|
|||||||
slf.ParamStr = strings.Trim(slf.ParamStr, "/")
|
slf.ParamStr = strings.Trim(slf.ParamStr, "/")
|
||||||
paramStrList := strings.Split(slf.ParamStr, "&")
|
paramStrList := strings.Split(slf.ParamStr, "&")
|
||||||
for _, val := range paramStrList {
|
for _, val := range paramStrList {
|
||||||
Index := strings.Index(val,"=")
|
Index := strings.Index(val, "=")
|
||||||
slf.mapParam[val[0:Index]] = val[Index+1:]
|
slf.mapParam[val[0:Index]] = val[Index+1:]
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -183,7 +183,8 @@ func Get(url string, handle HttpHandle) error {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func (slf *HttpServerService) OnInit() error {
|
func (slf *HttpServerService) OnInit() error {
|
||||||
slf.httpserver.Init(slf.port, &ServeHTTPRouterMux{}, 10*time.Second, 10*time.Second)
|
slf.serverHTTPMux = ServeHTTPRouterMux{}
|
||||||
|
slf.httpserver.Init(slf.port, &slf.serverHTTPMux, 10*time.Second, 10*time.Second)
|
||||||
if slf.ishttps == true {
|
if slf.ishttps == true {
|
||||||
slf.httpserver.SetHttps(slf.certfile, slf.keyfile)
|
slf.httpserver.SetHttps(slf.certfile, slf.keyfile)
|
||||||
}
|
}
|
||||||
@@ -197,6 +198,22 @@ func (slf *ServeHTTPRouterMux) ServeHTTP(w http.ResponseWriter, r *http.Request)
|
|||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
|
//权限验证
|
||||||
|
var errRet error
|
||||||
|
for _, filter := range slf.httpfiltrateList {
|
||||||
|
ret := filter(r.URL.Path, w, r)
|
||||||
|
if ret == nil {
|
||||||
|
errRet = nil
|
||||||
|
break
|
||||||
|
} else {
|
||||||
|
errRet = ret
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if errRet != nil {
|
||||||
|
writeRespone(w, http.StatusOK, errRet.Error())
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
url := strings.Trim(r.URL.Path, "/")
|
url := strings.Trim(r.URL.Path, "/")
|
||||||
var strCallPath string
|
var strCallPath string
|
||||||
matchData, ok := methodRouter[url]
|
matchData, ok := methodRouter[url]
|
||||||
@@ -228,7 +245,7 @@ func (slf *ServeHTTPRouterMux) ServeHTTP(w http.ResponseWriter, r *http.Request)
|
|||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
request := HttpRequest{r.Header, string(msg), r.URL.RawQuery, nil,r.URL.Path}
|
request := HttpRequest{r.Header, string(msg), r.URL.RawQuery, nil, r.URL.Path}
|
||||||
var resp HttpRespone
|
var resp HttpRespone
|
||||||
//resp.Resp = w
|
//resp.Resp = w
|
||||||
timeFuncStart := time.Now()
|
timeFuncStart := time.Now()
|
||||||
@@ -241,12 +258,12 @@ func (slf *ServeHTTPRouterMux) ServeHTTP(w http.ResponseWriter, r *http.Request)
|
|||||||
if err != nil {
|
if err != nil {
|
||||||
writeRespone(w, http.StatusBadRequest, fmt.Sprint(err))
|
writeRespone(w, http.StatusBadRequest, fmt.Sprint(err))
|
||||||
} else {
|
} else {
|
||||||
if resp.RedirectData.Url != ""{
|
if resp.RedirectData.Url != "" {
|
||||||
resp.redirects(&w,r)
|
resp.redirects(&w, r)
|
||||||
}else {
|
} else {
|
||||||
writeRespone(w, http.StatusOK, string(resp.Respone))
|
writeRespone(w, http.StatusOK, string(resp.Respone))
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -266,7 +283,7 @@ func SetStaticResource(method HTTP_METHOD, urlpath string, dirname string) error
|
|||||||
routerData.method = "GET"
|
routerData.method = "GET"
|
||||||
} else if method == METHOD_POST {
|
} else if method == METHOD_POST {
|
||||||
routerData.method = "POST"
|
routerData.method = "POST"
|
||||||
}else{
|
} else {
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
routerData.localpath = dirname
|
routerData.localpath = dirname
|
||||||
@@ -284,7 +301,7 @@ func writeRespone(w http.ResponseWriter, status int, msg string) {
|
|||||||
type HttpFiltrate func(path string, w http.ResponseWriter, r *http.Request) error
|
type HttpFiltrate func(path string, w http.ResponseWriter, r *http.Request) error
|
||||||
|
|
||||||
func (slf *HttpServerService) AppendHttpFiltrate(fun HttpFiltrate) bool {
|
func (slf *HttpServerService) AppendHttpFiltrate(fun HttpFiltrate) bool {
|
||||||
slf.httpfiltrateList = append(slf.httpfiltrateList, fun)
|
slf.serverHTTPMux.httpfiltrateList = append(slf.serverHTTPMux.httpfiltrateList, fun)
|
||||||
|
|
||||||
return false
|
return false
|
||||||
}
|
}
|
||||||
@@ -356,12 +373,10 @@ func staticServer(routerUrl string, routerData RouterStaticResoutceData, w http.
|
|||||||
errRet = ret
|
errRet = ret
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if errRet != nil {
|
if errRet != nil {
|
||||||
w.Write([]byte(errRet.Error()))
|
w.Write([]byte(errRet.Error()))
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
r.ParseMultipartForm(32 << 20) // max memory is set to 32MB
|
r.ParseMultipartForm(32 << 20) // max memory is set to 32MB
|
||||||
resourceFile, resourceFileHeader, err := r.FormFile("file")
|
resourceFile, resourceFileHeader, err := r.FormFile("file")
|
||||||
if err != nil {
|
if err != nil {
|
||||||
@@ -387,9 +402,7 @@ func staticServer(routerUrl string, routerData RouterStaticResoutceData, w http.
|
|||||||
return
|
return
|
||||||
}
|
}
|
||||||
defer localfd.Close()
|
defer localfd.Close()
|
||||||
|
|
||||||
io.Copy(localfd, resourceFile)
|
io.Copy(localfd, resourceFile)
|
||||||
|
|
||||||
writeResp(http.StatusOK, upath+fileName)*/
|
writeResp(http.StatusOK, upath+fileName)*/
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -459,18 +472,15 @@ func (slf *HttpRespone) WriteRespones(Code int32, Msg string, Data interface{})
|
|||||||
slf.Respone = []byte(StrRet)
|
slf.Respone = []byte(StrRet)
|
||||||
}
|
}
|
||||||
|
|
||||||
func (slf *HttpRespone) Redirect(url string,cookieList []*http.Cookie) {
|
func (slf *HttpRespone) Redirect(url string, cookieList []*http.Cookie) {
|
||||||
slf.RedirectData.Url = url
|
slf.RedirectData.Url = url
|
||||||
slf.RedirectData.CookieList = cookieList
|
slf.RedirectData.CookieList = cookieList
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
func (slf *HttpRespone) redirects(w *http.ResponseWriter, req *http.Request) {
|
func (slf *HttpRespone) redirects(w *http.ResponseWriter, req *http.Request) {
|
||||||
if slf.RedirectData.CookieList != nil {
|
if slf.RedirectData.CookieList != nil {
|
||||||
for _,v := range slf.RedirectData.CookieList{
|
for _, v := range slf.RedirectData.CookieList {
|
||||||
http.SetCookie(*w,v)
|
http.SetCookie(*w, v)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user