既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上Go语言开发知识点,真正体系化!
由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新
请求到达view时 执行self.dispatch()
def dispatch(self, request, \*args, \*\*kwargs):
self.args = args
self.kwargs = kwargs
request = self.initialize_request(request, \*args, \*\*kwargs)
self.request = request
self.headers = self.default_response_headers # deprecate?
try:
self.initial(request, \*args, \*\*kwargs)
'''
执行到self.initial() 调用该方法
def initial(self, request, \*args, \*\*kwargs):
self.check_permissions(request)
调用check_permissions()
def check\_permissions(self, request):
for permission in self.get_permissions():
if not permission.has_permission(request, self):
self.permission_denied(
request, message=getattr(permission, 'message', None)
)
执行 get_permissions() return [permission() for permission in self.permission_classes] 获取permission_classes中的权限类
has_permission()判断是否拥有权限 返回true/false
def has\_permission(self, request):
"""
Returns True if the given HttpRequest has permission to view
\*at least one\* page in the admin site.
"""
return request.user.is_active and request.user.is_staff
使用
1.自定义一个权限类
# 自定义权限
class MyPermission(BasePermission):
message = 'VIP用户才能访问'
def has\_permission(self, request, view):
"""
自定义权限只有VIP用户才能访问
"""
# 因为在进行权限判断之前已经做了认证判断,所以这里可以直接拿到request.user
if request.user and request.user.type == 2: # 如果是VIP用户
return True



**既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上Go语言开发知识点,真正体系化!**
**由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新**
**[如果你需要这些资料,可以戳这里获取](https://bbs.youkuaiyun.com/topics/618658159)**
笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新**
**[如果你需要这些资料,可以戳这里获取](https://bbs.youkuaiyun.com/topics/618658159)**