Django DRF权限怎么加_IsAuthenticated与自定义BasePermission

DRF中IsAuthenticated未生效最常见的原因是权限类未正确注册到视图或全局配置;必须显式声明permission_classes=IsAuthenticated,且多个权限类需全部返回True才通过,顺序不可颠倒。DRF里IsAuthenticated为什么没生效?最常见的原因是权限类没正确注册到视图或全局配置里,而不是代码写错了。DRF默认不启用任何权限,IsAuthenticated必须显式声明才会起作用。全局配置写在settings.py的REST_FRAMEWORK'DEFAULT_PERMISSION_CLASSES'里,但一旦写了,所有视图都受约束------包括APIView、ViewSet甚至未登录时的登录接口本身,容易导致401循环更安全的做法是只在具体视图上加:permission_classes = IsAuthenticated,尤其适合混合权限场景(比如列表页公开、详情页需登录)注意:如果视图继承自APIView,必须用permission_classes属性;若用ViewSet,同样适用,但动作级控制得靠get_permissions()方法自定义BasePermission怎么写才不踩坑?核心就一条:has_permission(self, request, view)返回True或False,别抛异常、别返回字符串、别漏写self------这是最常被复制粘贴错的地方。判断逻辑里别直接访问request.user而忘了检查is_authenticated,未登录用户request.user是AnonymousUser,它没有is_active等属性,会抛AttributeError需要对象级权限时(比如编辑某条订单),必须实现has_object_permission(self, request, view, obj),且视图得调用get_object()触发它------单纯list()不会走这个方法多个权限类同时存在时,DRF按顺序执行,**全部返回True才算通过**,所以别把IsAuthenticated和自定义类顺序搞反,否则未登录就直接短路失败IsAuthenticated和自定义权限能一起用吗?能,而且推荐这么用:用IsAuthenticated兜底身份,再用自定义类做业务判断。但要注意组合方式不是"或",而是"与"。 知网AI智能写作 知网AI智能写作,写文档、写报告如此简单

相关推荐
曹牧7 小时前
Oracle:前缀匹配之REGEXP_LIKE
数据库·oracle
Unbelievabletobe7 小时前
解决了股票api接口盘后数据更新慢的问题
大数据·开发语言·python
lpd_lt9 小时前
AI Coding的常用Prompt技巧
python·ai·ai编程
小江的记录本9 小时前
【JVM虚拟机】堆内存分代模型:年轻代(Eden+Survivor)、老年代、元空间Metaspace(附《思维导图》+《面试高频考点清单》)
java·前端·jvm·后端·python·spring·面试
在繁华处9 小时前
Java从零到熟练(三):流程控制
java·开发语言·python
asdzx679 小时前
使用 Python 快速提取 PDF 中的表格
python·pdf
无情的西瓜皮10 小时前
MCP协议实战:用Python从零搭建一个AI Agent工具服务器(保姆级教程)
服务器·人工智能·python·mcp
暴躁小师兄数据学院10 小时前
【AI大数据工程师特训笔记】第05讲:关联查询
数据库·sql·oracle
倔强的石头_10 小时前
《Kingbase护城河》——跨平台环境下的数据库联调实战
数据库
lzhdim10 小时前
SQL 入门 17:MySQL 数据类型:从字符串到 JSON 的全面解析
数据库·sql·mysql·json