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.

54 lines
2.1 KiB

5 months ago
5 months ago
5 months ago
  1. package cmd
  2. import (
  3. "context"
  4. "github.com/goflyfox/gtoken/gtoken"
  5. "github.com/gogf/gf/v2/frame/g"
  6. "github.com/gogf/gf/v2/net/ghttp"
  7. "github.com/gogf/gf/v2/os/gcmd"
  8. "link_homework/internal/controller/homework"
  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: "/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.MiddlewareIsLogin)
  36. gfToken.Middleware(ctx, group)
  37. //直接写接口,不用再分组
  38. group.POST("/get-homework-list", homework.Homework().GetHomeworkList)
  39. })
  40. //客户端
  41. s.Group("/api/homework_client", func(group *ghttp.RouterGroup) {
  42. //group.Middleware(middleware.MiddlewareIsLogin)
  43. gfToken.Middleware(ctx, group)
  44. //直接写接口,不用再分组
  45. })
  46. s.Run()
  47. return nil
  48. },
  49. }
  50. )