From 8f92776103083d64e547dc9ddebacdb5e38d7e9e Mon Sep 17 00:00:00 2001 From: laodaming <11058467+laudamine@user.noreply.gitee.com> Date: Tue, 10 Oct 2023 15:08:41 +0800 Subject: [PATCH] fix --- server/collection/internal/handler/routes.go | 2 +- .../internal/handler/testpdfhandler.go | 35 +++++++++++++ .../collection/internal/logic/testpdflogic.go | 49 +++++++++++++++++++ server/collection/internal/types/types.go | 4 +- server_api/collection.api | 2 +- 5 files changed, 88 insertions(+), 4 deletions(-) create mode 100644 server/collection/internal/handler/testpdfhandler.go create mode 100644 server/collection/internal/logic/testpdflogic.go diff --git a/server/collection/internal/handler/routes.go b/server/collection/internal/handler/routes.go index ca29fb08..4abd6190 100644 --- a/server/collection/internal/handler/routes.go +++ b/server/collection/internal/handler/routes.go @@ -33,7 +33,7 @@ func RegisterHandlers(server *rest.Server, serverCtx *svc.ServiceContext) { Handler: TestAiHandler(serverCtx), }, { - Method: http.MethodPost, + Method: http.MethodGet, Path: "/api/collection/test_pdf", Handler: TestPdfHandler(serverCtx), }, diff --git a/server/collection/internal/handler/testpdfhandler.go b/server/collection/internal/handler/testpdfhandler.go new file mode 100644 index 00000000..6a40187c --- /dev/null +++ b/server/collection/internal/handler/testpdfhandler.go @@ -0,0 +1,35 @@ +package handler + +import ( + "net/http" + "reflect" + + "fusenapi/utils/basic" + + "fusenapi/server/collection/internal/logic" + "fusenapi/server/collection/internal/svc" + "fusenapi/server/collection/internal/types" +) + +func TestPdfHandler(svcCtx *svc.ServiceContext) http.HandlerFunc { + return func(w http.ResponseWriter, r *http.Request) { + + var req types.TestPdfReq + userinfo, err := basic.RequestParse(w, r, svcCtx, &req) + if err != nil { + return + } + + // 创建一个业务逻辑层实例 + l := logic.NewTestPdfLogic(r.Context(), svcCtx) + + rl := reflect.ValueOf(l) + basic.BeforeLogic(w, r, rl) + + resp := l.TestPdf(&req, userinfo) + + if !basic.AfterLogic(w, r, rl, resp) { + basic.NormalAfterLogic(w, r, resp) + } + } +} diff --git a/server/collection/internal/logic/testpdflogic.go b/server/collection/internal/logic/testpdflogic.go new file mode 100644 index 00000000..a80d2252 --- /dev/null +++ b/server/collection/internal/logic/testpdflogic.go @@ -0,0 +1,49 @@ +package logic + +import ( + "context" + "fusenapi/server/collection/internal/svc" + "fusenapi/server/collection/internal/types" + "fusenapi/utils/auth" + "fusenapi/utils/basic" + "fusenapi/utils/pdf" + + "github.com/zeromicro/go-zero/core/logx" +) + +type TestPdfLogic struct { + logx.Logger + ctx context.Context + svcCtx *svc.ServiceContext +} + +func NewTestPdfLogic(ctx context.Context, svcCtx *svc.ServiceContext) *TestPdfLogic { + return &TestPdfLogic{ + Logger: logx.WithContext(ctx), + ctx: ctx, + svcCtx: svcCtx, + } +} + +// 处理进入前逻辑w,r +// func (l *TestPdfLogic) BeforeLogic(w http.ResponseWriter, r *http.Request) { +// } + +func (l *TestPdfLogic) TestPdf(req *types.TestPdfReq, userinfo *auth.UserInfo) (resp *basic.Response) { + switch req.Type { + case "url": + case "html": + default: + return resp.SetStatusWithMessage(basic.CodeRequestParamsErr, "invalid type") + } + res, err := pdf.HtmlToPdfBase64(req.Content, req.Type) + if err != nil { + return resp.SetStatusWithMessage(basic.CodeServiceErr, err.Error()) + } + return resp.SetStatus(basic.CodeOK, res) +} + +// 处理逻辑后 w,r 如:重定向, resp 必须重新处理 +// func (l *TestPdfLogic) AfterLogic(w http.ResponseWriter, r *http.Request, resp *basic.Response) { +// // httpx.OkJsonCtx(r.Context(), w, resp) +// } diff --git a/server/collection/internal/types/types.go b/server/collection/internal/types/types.go index c6268e1d..0b3cbda3 100644 --- a/server/collection/internal/types/types.go +++ b/server/collection/internal/types/types.go @@ -45,8 +45,8 @@ type TestAiReq struct { } type TestPdfReq struct { - Content string `json:"content"` - Type string `json:"type"` + Content string `form:"content"` + Type string `form:"type"` } type Request struct { diff --git a/server_api/collection.api b/server_api/collection.api index 31253735..22c8501c 100644 --- a/server_api/collection.api +++ b/server_api/collection.api @@ -23,7 +23,7 @@ service collection { get /api/collection/test_ai(TestAiReq) returns (response); //测试pdf @handler TestPdfHandler - post /api/collection/test_pdf(TestPdfReq) returns (response); + get /api/collection/test_pdf(TestPdfReq) returns (response); } //收藏产品