新增自定义的 Cors

This commit is contained in:
eson 2023-07-11 19:43:46 +08:00
parent e0de8bfcf2
commit a4f429a528
17 changed files with 88 additions and 21 deletions

View File

@ -15,7 +15,9 @@ func main() {
var c config.Config var c config.Config
conf.MustLoad(*configFile, &c) conf.MustLoad(*configFile, &c)
server := rest.MustNewServer(c.RestConf, rest.WithCors()) server := rest.MustNewServer(c.RestConf, rest.WithCustomCors(auth.FsCors, func(w http.ResponseWriter) {
}))
defer server.Stop() defer server.Stop()
ctx := svc.NewServiceContext(c) ctx := svc.NewServiceContext(c)

View File

@ -15,7 +15,9 @@ func main() {
var c config.Config var c config.Config
conf.MustLoad(*configFile, &c) conf.MustLoad(*configFile, &c)
server := rest.MustNewServer(c.RestConf, rest.WithCors()) server := rest.MustNewServer(c.RestConf, rest.WithCustomCors(auth.FsCors, func(w http.ResponseWriter) {
}))
defer server.Stop() defer server.Stop()
ctx := svc.NewServiceContext(c) ctx := svc.NewServiceContext(c)

View File

@ -30,7 +30,7 @@ func SetCors(w http.ResponseWriter, r *http.Request) {
func main() { func main() {
rootDir := "../server" // Change this to your root directory rootDir := "../server" // Change this to your root directory
vueBuild := "/home/ldm/workdir/fusenpack-vue-created" vueBuild := "/home/eson/workspace/fusenpack-vue-created"
apiURL, err := url.Parse("http://localhost:9900") apiURL, err := url.Parse("http://localhost:9900")
if err != nil { if err != nil {
panic(err) panic(err)
@ -130,7 +130,7 @@ func NewBackend(mux *http.ServeMux, httpAddress string, muxPaths ...string) *Bac
return return
} }
hasBridge := strings.Contains(r.Header.Get("Access-Control-Request-Headers"), "bridge") // hasBridge := strings.Contains(r.Header.Get("Access-Control-Request-Headers"), "bridge")
// 解析目标URL时已经包含了查询参数 // 解析目标URL时已经包含了查询参数
targetURL.RawQuery = r.URL.RawQuery targetURL.RawQuery = r.URL.RawQuery
@ -166,9 +166,9 @@ func NewBackend(mux *http.ServeMux, httpAddress string, muxPaths ...string) *Bac
} }
} }
if hasBridge { // if hasBridge {
w.Header().Add("Access-Control-Allow-Headers", "Bridge") // w.Header().Add("Access-Control-Allow-Headers", "Bridge")
} // }
// 转发目标服务器的响应状态码和主体 // 转发目标服务器的响应状态码和主体
w.WriteHeader(resp.StatusCode) w.WriteHeader(resp.StatusCode)
@ -177,8 +177,8 @@ func NewBackend(mux *http.ServeMux, httpAddress string, muxPaths ...string) *Bac
http.Error(w, "Error copying proxy response", http.StatusInternalServerError) http.Error(w, "Error copying proxy response", http.StatusInternalServerError)
return return
} }
} }
for _, muxPath := range muxPaths { for _, muxPath := range muxPaths {
mux.HandleFunc(muxPath, handleRequest) mux.HandleFunc(muxPath, handleRequest)
} }

View File

@ -3,10 +3,12 @@ package main
import ( import (
"flag" "flag"
"fmt" "fmt"
"net/http"
"fusenapi/server/backend/internal/config" "fusenapi/server/backend/internal/config"
"fusenapi/server/backend/internal/handler" "fusenapi/server/backend/internal/handler"
"fusenapi/server/backend/internal/svc" "fusenapi/server/backend/internal/svc"
"fusenapi/utils/auth"
"github.com/zeromicro/go-zero/core/conf" "github.com/zeromicro/go-zero/core/conf"
"github.com/zeromicro/go-zero/rest" "github.com/zeromicro/go-zero/rest"
@ -20,7 +22,9 @@ func main() {
var c config.Config var c config.Config
conf.MustLoad(*configFile, &c) conf.MustLoad(*configFile, &c)
server := rest.MustNewServer(c.RestConf, rest.WithCors()) server := rest.MustNewServer(c.RestConf, rest.WithCustomCors(auth.FsCors, func(w http.ResponseWriter) {
}))
defer server.Stop() defer server.Stop()
ctx := svc.NewServiceContext(c) ctx := svc.NewServiceContext(c)

View File

@ -3,10 +3,12 @@ package main
import ( import (
"flag" "flag"
"fmt" "fmt"
"net/http"
"fusenapi/server/canteen/internal/config" "fusenapi/server/canteen/internal/config"
"fusenapi/server/canteen/internal/handler" "fusenapi/server/canteen/internal/handler"
"fusenapi/server/canteen/internal/svc" "fusenapi/server/canteen/internal/svc"
"fusenapi/utils/auth"
"github.com/zeromicro/go-zero/core/conf" "github.com/zeromicro/go-zero/core/conf"
"github.com/zeromicro/go-zero/rest" "github.com/zeromicro/go-zero/rest"
@ -20,7 +22,9 @@ func main() {
var c config.Config var c config.Config
conf.MustLoad(*configFile, &c) conf.MustLoad(*configFile, &c)
server := rest.MustNewServer(c.RestConf, rest.WithCors()) server := rest.MustNewServer(c.RestConf, rest.WithCustomCors(auth.FsCors, func(w http.ResponseWriter) {
}))
defer server.Stop() defer server.Stop()
ctx := svc.NewServiceContext(c) ctx := svc.NewServiceContext(c)

View File

@ -6,6 +6,8 @@ import (
config2 "fusenapi/server/data-transfer/internal/config" config2 "fusenapi/server/data-transfer/internal/config"
handler2 "fusenapi/server/data-transfer/internal/handler" handler2 "fusenapi/server/data-transfer/internal/handler"
svc2 "fusenapi/server/data-transfer/internal/svc" svc2 "fusenapi/server/data-transfer/internal/svc"
"fusenapi/utils/auth"
"net/http"
"github.com/zeromicro/go-zero/core/conf" "github.com/zeromicro/go-zero/core/conf"
"github.com/zeromicro/go-zero/rest" "github.com/zeromicro/go-zero/rest"
@ -19,7 +21,9 @@ func main() {
var c config2.Config var c config2.Config
conf.MustLoad(*configFile, &c) conf.MustLoad(*configFile, &c)
server := rest.MustNewServer(c.RestConf, rest.WithCors()) server := rest.MustNewServer(c.RestConf, rest.WithCustomCors(auth.FsCors, func(w http.ResponseWriter) {
}))
defer server.Stop() defer server.Stop()
ctx := svc2.NewServiceContext(c) ctx := svc2.NewServiceContext(c)

View File

@ -3,10 +3,12 @@ package main
import ( import (
"flag" "flag"
"fmt" "fmt"
"net/http"
"fusenapi/server/home-user-auth/internal/config" "fusenapi/server/home-user-auth/internal/config"
"fusenapi/server/home-user-auth/internal/handler" "fusenapi/server/home-user-auth/internal/handler"
"fusenapi/server/home-user-auth/internal/svc" "fusenapi/server/home-user-auth/internal/svc"
"fusenapi/utils/auth"
"github.com/zeromicro/go-zero/core/conf" "github.com/zeromicro/go-zero/core/conf"
"github.com/zeromicro/go-zero/rest" "github.com/zeromicro/go-zero/rest"
@ -20,7 +22,9 @@ func main() {
var c config.Config var c config.Config
conf.MustLoad(*configFile, &c) conf.MustLoad(*configFile, &c)
server := rest.MustNewServer(c.RestConf, rest.WithCors()) server := rest.MustNewServer(c.RestConf, rest.WithCustomCors(auth.FsCors, func(w http.ResponseWriter) {
}))
defer server.Stop() defer server.Stop()
ctx := svc.NewServiceContext(c) ctx := svc.NewServiceContext(c)

View File

@ -3,10 +3,12 @@ package main
import ( import (
"flag" "flag"
"fmt" "fmt"
"net/http"
"fusenapi/server/inventory/internal/config" "fusenapi/server/inventory/internal/config"
"fusenapi/server/inventory/internal/handler" "fusenapi/server/inventory/internal/handler"
"fusenapi/server/inventory/internal/svc" "fusenapi/server/inventory/internal/svc"
"fusenapi/utils/auth"
"github.com/zeromicro/go-zero/core/conf" "github.com/zeromicro/go-zero/core/conf"
"github.com/zeromicro/go-zero/rest" "github.com/zeromicro/go-zero/rest"
@ -20,7 +22,9 @@ func main() {
var c config.Config var c config.Config
conf.MustLoad(*configFile, &c) conf.MustLoad(*configFile, &c)
server := rest.MustNewServer(c.RestConf, rest.WithCors()) server := rest.MustNewServer(c.RestConf, rest.WithCustomCors(auth.FsCors, func(w http.ResponseWriter) {
}))
defer server.Stop() defer server.Stop()
ctx := svc.NewServiceContext(c) ctx := svc.NewServiceContext(c)

View File

@ -3,10 +3,12 @@ package main
import ( import (
"flag" "flag"
"fmt" "fmt"
"net/http"
"fusenapi/server/map-library/internal/config" "fusenapi/server/map-library/internal/config"
"fusenapi/server/map-library/internal/handler" "fusenapi/server/map-library/internal/handler"
"fusenapi/server/map-library/internal/svc" "fusenapi/server/map-library/internal/svc"
"fusenapi/utils/auth"
"github.com/zeromicro/go-zero/core/conf" "github.com/zeromicro/go-zero/core/conf"
"github.com/zeromicro/go-zero/rest" "github.com/zeromicro/go-zero/rest"
@ -20,7 +22,9 @@ func main() {
var c config.Config var c config.Config
conf.MustLoad(*configFile, &c) conf.MustLoad(*configFile, &c)
server := rest.MustNewServer(c.RestConf, rest.WithCors()) server := rest.MustNewServer(c.RestConf, rest.WithCustomCors(auth.FsCors, func(w http.ResponseWriter) {
}))
defer server.Stop() defer server.Stop()
ctx := svc.NewServiceContext(c) ctx := svc.NewServiceContext(c)

View File

@ -3,10 +3,12 @@ package main
import ( import (
"flag" "flag"
"fmt" "fmt"
"net/http"
"fusenapi/server/orders/internal/config" "fusenapi/server/orders/internal/config"
"fusenapi/server/orders/internal/handler" "fusenapi/server/orders/internal/handler"
"fusenapi/server/orders/internal/svc" "fusenapi/server/orders/internal/svc"
"fusenapi/utils/auth"
"github.com/zeromicro/go-zero/core/conf" "github.com/zeromicro/go-zero/core/conf"
"github.com/zeromicro/go-zero/rest" "github.com/zeromicro/go-zero/rest"
@ -20,7 +22,9 @@ func main() {
var c config.Config var c config.Config
conf.MustLoad(*configFile, &c) conf.MustLoad(*configFile, &c)
server := rest.MustNewServer(c.RestConf, rest.WithCors()) server := rest.MustNewServer(c.RestConf, rest.WithCustomCors(auth.FsCors, func(w http.ResponseWriter) {
}))
defer server.Stop() defer server.Stop()
ctx := svc.NewServiceContext(c) ctx := svc.NewServiceContext(c)

View File

@ -3,10 +3,12 @@ package main
import ( import (
"flag" "flag"
"fmt" "fmt"
"net/http"
"fusenapi/server/product-model/internal/config" "fusenapi/server/product-model/internal/config"
"fusenapi/server/product-model/internal/handler" "fusenapi/server/product-model/internal/handler"
"fusenapi/server/product-model/internal/svc" "fusenapi/server/product-model/internal/svc"
"fusenapi/utils/auth"
"github.com/zeromicro/go-zero/core/conf" "github.com/zeromicro/go-zero/core/conf"
"github.com/zeromicro/go-zero/rest" "github.com/zeromicro/go-zero/rest"
@ -20,7 +22,9 @@ func main() {
var c config.Config var c config.Config
conf.MustLoad(*configFile, &c) conf.MustLoad(*configFile, &c)
server := rest.MustNewServer(c.RestConf, rest.WithCors()) server := rest.MustNewServer(c.RestConf, rest.WithCustomCors(auth.FsCors, func(w http.ResponseWriter) {
}))
defer server.Stop() defer server.Stop()
ctx := svc.NewServiceContext(c) ctx := svc.NewServiceContext(c)

View File

@ -3,10 +3,12 @@ package main
import ( import (
"flag" "flag"
"fmt" "fmt"
"net/http"
"fusenapi/server/product-template/internal/config" "fusenapi/server/product-template/internal/config"
"fusenapi/server/product-template/internal/handler" "fusenapi/server/product-template/internal/handler"
"fusenapi/server/product-template/internal/svc" "fusenapi/server/product-template/internal/svc"
"fusenapi/utils/auth"
"github.com/zeromicro/go-zero/core/conf" "github.com/zeromicro/go-zero/core/conf"
"github.com/zeromicro/go-zero/rest" "github.com/zeromicro/go-zero/rest"
@ -20,7 +22,9 @@ func main() {
var c config.Config var c config.Config
conf.MustLoad(*configFile, &c) conf.MustLoad(*configFile, &c)
server := rest.MustNewServer(c.RestConf, rest.WithCors()) server := rest.MustNewServer(c.RestConf, rest.WithCustomCors(auth.FsCors, func(w http.ResponseWriter) {
}))
defer server.Stop() defer server.Stop()
ctx := svc.NewServiceContext(c) ctx := svc.NewServiceContext(c)

View File

@ -3,10 +3,12 @@ package main
import ( import (
"flag" "flag"
"fmt" "fmt"
"net/http"
"fusenapi/server/product/internal/config" "fusenapi/server/product/internal/config"
"fusenapi/server/product/internal/handler" "fusenapi/server/product/internal/handler"
"fusenapi/server/product/internal/svc" "fusenapi/server/product/internal/svc"
"fusenapi/utils/auth"
"github.com/zeromicro/go-zero/core/conf" "github.com/zeromicro/go-zero/core/conf"
"github.com/zeromicro/go-zero/rest" "github.com/zeromicro/go-zero/rest"
@ -20,7 +22,9 @@ func main() {
var c config.Config var c config.Config
conf.MustLoad(*configFile, &c) conf.MustLoad(*configFile, &c)
server := rest.MustNewServer(c.RestConf, rest.WithCors()) server := rest.MustNewServer(c.RestConf, rest.WithCustomCors(auth.FsCors, func(w http.ResponseWriter) {
}))
defer server.Stop() defer server.Stop()
ctx := svc.NewServiceContext(c) ctx := svc.NewServiceContext(c)
handler.RegisterHandlers(server, ctx) handler.RegisterHandlers(server, ctx)

View File

@ -3,10 +3,12 @@ package main
import ( import (
"flag" "flag"
"fmt" "fmt"
"net/http"
"fusenapi/server/shopping-cart-confirmation/internal/config" "fusenapi/server/shopping-cart-confirmation/internal/config"
"fusenapi/server/shopping-cart-confirmation/internal/handler" "fusenapi/server/shopping-cart-confirmation/internal/handler"
"fusenapi/server/shopping-cart-confirmation/internal/svc" "fusenapi/server/shopping-cart-confirmation/internal/svc"
"fusenapi/utils/auth"
"github.com/zeromicro/go-zero/core/conf" "github.com/zeromicro/go-zero/core/conf"
"github.com/zeromicro/go-zero/rest" "github.com/zeromicro/go-zero/rest"
@ -20,7 +22,9 @@ func main() {
var c config.Config var c config.Config
conf.MustLoad(*configFile, &c) conf.MustLoad(*configFile, &c)
server := rest.MustNewServer(c.RestConf, rest.WithCors()) server := rest.MustNewServer(c.RestConf, rest.WithCustomCors(auth.FsCors, func(w http.ResponseWriter) {
}))
defer server.Stop() defer server.Stop()
ctx := svc.NewServiceContext(c) ctx := svc.NewServiceContext(c)

View File

@ -3,10 +3,12 @@ package main
import ( import (
"flag" "flag"
"fmt" "fmt"
"net/http"
"fusenapi/server/upload/internal/config" "fusenapi/server/upload/internal/config"
"fusenapi/server/upload/internal/handler" "fusenapi/server/upload/internal/handler"
"fusenapi/server/upload/internal/svc" "fusenapi/server/upload/internal/svc"
"fusenapi/utils/auth"
"github.com/zeromicro/go-zero/core/conf" "github.com/zeromicro/go-zero/core/conf"
"github.com/zeromicro/go-zero/rest" "github.com/zeromicro/go-zero/rest"
@ -20,7 +22,9 @@ func main() {
var c config.Config var c config.Config
conf.MustLoad(*configFile, &c) conf.MustLoad(*configFile, &c)
server := rest.MustNewServer(c.RestConf, rest.WithCors()) server := rest.MustNewServer(c.RestConf, rest.WithCustomCors(auth.FsCors, func(w http.ResponseWriter) {
}))
defer server.Stop() defer server.Stop()
ctx := svc.NewServiceContext(c) ctx := svc.NewServiceContext(c)

View File

@ -3,10 +3,12 @@ package main
import ( import (
"flag" "flag"
"fmt" "fmt"
"net/http"
"fusenapi/server/webset/internal/config" "fusenapi/server/webset/internal/config"
"fusenapi/server/webset/internal/handler" "fusenapi/server/webset/internal/handler"
"fusenapi/server/webset/internal/svc" "fusenapi/server/webset/internal/svc"
"fusenapi/utils/auth"
"github.com/zeromicro/go-zero/core/conf" "github.com/zeromicro/go-zero/core/conf"
"github.com/zeromicro/go-zero/rest" "github.com/zeromicro/go-zero/rest"
@ -20,7 +22,9 @@ func main() {
var c config.Config var c config.Config
conf.MustLoad(*configFile, &c) conf.MustLoad(*configFile, &c)
server := rest.MustNewServer(c.RestConf, rest.WithCors()) server := rest.MustNewServer(c.RestConf, rest.WithCustomCors(auth.FsCors, func(w http.ResponseWriter) {
}))
defer server.Stop() defer server.Stop()
ctx := svc.NewServiceContext(c) ctx := svc.NewServiceContext(c)

11
utils/auth/cors.go Normal file
View File

@ -0,0 +1,11 @@
package auth
import "net/http"
func FsCors(header http.Header) {
header.Set("Access-Control-Allow-Origin", "*")
header.Set("Access-Control-Allow-Methods", "POST, GET, OPTIONS, PUT, DELETE")
header.Set("Access-Control-Allow-Headers", "*")
header.Set("Access-Control-Expose-Headers", "*")
header.Set("Access-Control-Allow-Credentials", "true")
}