Django-restframework05 用户认证和权限管理

本文详细介绍了在Django-restframework中实现用户认证和权限管理的步骤,包括设置数据库字段的on update和on delete参数,删除与迁移,用户控制入口,断点设置,序列化器更新,视图函数的权限认证,登录URL配置,用户权限等级管理和认证机制(SessionAuthentication和BasicAuthentication)。目的是确保只有认证用户能进行创建、更新和删除操作,未认证用户仅限于读取。
摘要由CSDN通过智能技术生成

1. 目的

  • 实例对象始终与创建者相关联
  • 只有通过身份验证的用户可以创建实例
  • 只有对象的创建者能够更新和删除该对象
  • 未认证用户应该只有只读权限

2. 数据库中字段的on update 和 on delete参数

  • 数据库外键定义的可选项,用来设置当主键表中的被参考列的数据发生变化时,外键表中响应字段的变化规则。update则是主键表中被参考字段的值更新,delete是指在主键表中删除一条记录
  • on_update 和 on_delete的值有四个:DO_NOTHING , SET_NULL , SET_DEFAULT ,CASCADE,PROTECT
  • no action 表示不做任何操作
  • set null 表示在外件表中将相应字段设置为null
  • ser default 表示设置默认值
  • cascade 表示级联操作,如果主键表中被参考字段更新,外键表中也更新,主键表中的记录被删除,外键表中该行也相应删除

3. 删除原数据库和迁移记录

rm -f tmp.db db.sqlite3
rm -r snippets/migrations

4.添加用户控制入口

  • 首先在模型文件中设置关联外键
owner = models.ForeignKey('auth.User', related_name='snippets', on_delete=models.CASCADE)
    highlighted = models.TextField()
  • 设置文本高亮,重写保存方法
 def save(self, *args, **kwargs):
        """
        利用pygments,创建高亮的html文本呈现code块
        """
        lexer = get_lexer_by_name(self.language)
        linenos = self.linenos and 
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

豆豆orz

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值