You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

59 lines
2.5 KiB

  1. package cmd
  2. import (
  3. "context"
  4. "github.com/gogf/gf/v2/frame/g"
  5. "github.com/gogf/gf/v2/net/ghttp"
  6. "github.com/gogf/gf/v2/os/gcmd"
  7. "link_homework/internal/controller/record"
  8. "link_homework/internal/logic/middleware"
  9. )
  10. var (
  11. Main = gcmd.Command{
  12. Name: "main",
  13. Usage: "main",
  14. Brief: "start http server",
  15. Func: func(ctx context.Context, parser *gcmd.Parser) (err error) {
  16. s := g.Server()
  17. //后台
  18. ////启动gtoken
  19. //// 创建一个GfToken对象,用于处理用户登录、登出、权限验证等操作
  20. //gfToken := &gtoken.GfToken{
  21. // // 设置登录路径,即用户登录接口登入成功后会获得一个Token
  22. // LoginPath: "/login",
  23. // //// 设置登录前执行的函数,在用户登录之前会调用这个函数进行一些预处理,比如验证用户名和密码等。
  24. // //LoginBeforeFunc: loginFunc, //手动编写 没有同时配置登入路径,登入方法,登出路径启动时会报错
  25. // // 设置登出路径,即用户登出接口登入成功后会删除Token
  26. // LogoutPath: "/user/logout",
  27. // //// 设置需要拦截的路径,按照前缀拦截,所有以/user或/system开头的路径都需要进行Token认证。
  28. // //AuthPaths: g.SliceStr{"/user", "/system"},
  29. // //// 设置不需要拦截的路径,所有以/user/info或/system/user/开头的路径都不需要进行Token认证。
  30. // //AuthExcludePaths: g.SliceStr{"/user/info", "/system/user/*"},
  31. // //// 开启全局拦截,默认关闭,如果设置为true,则所有请求都会经过Token认证中间件,如果设置为false,则只有指定路径的请求会经过Token认证中间件。
  32. // //GlobalMiddleware: true,
  33. //}
  34. s.Group("/api/homework_manage", func(group *ghttp.RouterGroup) {
  35. group.Middleware(middleware.MiddlewareCORS)
  36. //group.Middleware(middleware.MiddlewareIsLogin)
  37. //gfToken.Middleware(ctx, group)
  38. //直接写接口,不用再分组
  39. group.POST("/getrecordlist", record.NewManageRecord().GetRecordList)
  40. group.POST("/getrecordbycondition", record.NewManageRecord().GetRecordByCondition)
  41. group.POST("/getdeptinfo", record.NewManageRecord().GetDeptInfo)
  42. group.POST("/getshopinfo", record.NewManageRecord().GetShopInfo)
  43. })
  44. //客户端
  45. s.Group("/api/homework_client", func(group *ghttp.RouterGroup) {
  46. group.Middleware(middleware.MiddlewareCORS)
  47. //group.Middleware(middleware.MiddlewareIsLogin)
  48. //gfToken.Middleware(ctx, group)
  49. //直接写接口,不用再分组
  50. })
  51. s.Run()
  52. return nil
  53. },
  54. }
  55. )