casbin_rcba.go 675 B

12345678910111213141516171819202122232425262728293031
  1. package middleware
  2. import (
  3. "gin-vue-admin/global/response"
  4. "gin-vue-admin/model/request"
  5. "gin-vue-admin/service"
  6. "github.com/gin-gonic/gin"
  7. )
  8. //拦截器
  9. func CasbinHandler() gin.HandlerFunc {
  10. return func(c *gin.Context) {
  11. claims, _ := c.Get("claims")
  12. waitUse := claims.(*request.CustomClaims)
  13. //获取请求的URI
  14. obj := c.Request.URL.RequestURI()
  15. //获取请求方法
  16. act := c.Request.Method
  17. //获取用户的角色
  18. sub := waitUse.AuthorityId
  19. e := service.Casbin()
  20. //判断策略中是否存在
  21. if e.Enforce(sub, obj, act) {
  22. c.Next()
  23. } else {
  24. response.Result(response.ERROR, gin.H{}, "权限不足", c)
  25. c.Abort()
  26. return
  27. }
  28. }
  29. }