首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
社区首页 >问答首页 >为什么Django没有查看权限?

为什么Django没有查看权限?
EN

Stack Overflow用户
提问于 2015-10-19 03:43:30
回答 2查看 3.6K关注 0票数 7

我有一个活跃的Django项目,其中的管理面板由客户支持团队使用。Django缺少view权限,因此我必须将更改权限分配给客户支持团队,这有点危险。我有一些模型,由于安全问题,客户支持团队只需要查看访问权限,而不需要更改访问权限。为什么Django中缺少view权限?对此有什么解决方法吗?

EN

回答 2

Stack Overflow用户

发布于 2015-10-19 13:55:53

这里有一个解决方法。

模型

只需通过从mixin继承来创建具有查看权限的模型:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
class ViewPermissionsMixin(models.Model):
    """
        Mixin adds view permission to model.
    """
    class Meta:
        abstract=True
        default_permissions = ('add', 'change', 'delete', 'view')

示例模型:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
class ExampleModel(ViewPermissionsMixin):
    name = models.CharField(max_length=255)

    class Meta(ViewPermissionsMixin.Meta):
        abstract = False

这将添加可分配给特定用户/组的查看权限。但是,如果没有适当的管理员修改,这样的权限是无用的。

Admins

这是给你的管理员的混入:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
class AdminViewMixin(admin.ModelAdmin):

    def has_perm(self,user,permission):
        """
            Usefull shortcut for `user.has_perm()`
        """
        if user.has_perm("%s.%s_%s" % (self.model._meta.app_label,permission,self.model.__name__.lower(),)):
            return True
        return False

    def has_module_permission(self, request): # Django 1.8
        pass

    def has_change_permission(self, request, obj=None):
        """
            Necessary permission check to let Django show change_form for `view` permissions
        """
        if request.user.is_superuser:
            return True
        elif self.has_perm(request.user,'change'):
            return True
        elif self.has_perm(request.user,'view'):
            return True
        return super(AdminMixin, self).has_change_permission(request, obj)

    def get_readonly_fields(self, request, obj=None):
        """
            Turn each model field into read-only for `viewers`
        """
        all_model_fields = []
        for field in self.model._meta.fields:
            # TODO in Django 1.8 use ModelAdmin.get_fields()
            if not field.auto_created \
                and (not hasattr(field,'auto_now_add') or not field.auto_now_add) \
                and (not hasattr(field,'auto_now') or not field.auto_now) \
                :
                all_model_fields.append(field.name)
        if request.user.is_superuser:
            return self.readonly_fields
        elif self.has_perm(request.user,'change'):
            return self.readonly_fields
        elif self.has_perm(request.user,'view'):
            return all_model_fields
        return self.readonly_fields

    def change_view(self, request, object_id, extra_context=None):
        """
            Disable buttons for `viewers` in `change_view`
        """
        if request.user.is_superuser:
            pass
        elif self.has_perm(request.user,'change'):
            pass
        elif self.has_perm(request.user,'view'):
            extra_context = extra_context or {}
            extra_context['hide_save_buttons'] = True
        return super(AdminViewMixin, self).change_view(request, object_id, extra_context=extra_context)

示例admin:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
@admin.register(models.ExampleModel)
class ExampleAdmin(AdminViewMixin):
    list_display = ('name',)
    pass

最后,只需将特定模型的view权限分配给Django Admin中的任何用户或组。

票数 6
EN

Stack Overflow用户

发布于 2015-10-19 04:30:08

我认为这应该行得通:

1.添加查看权限,参见https://stackoverflow.com/a/23411901/1266258

2.自定义更改权限:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
class FooAdmin(ModelAdmin):
    def has_change_permission(self, request, obj=None):
        # user can view the change list
        if not obj and request.user.has_perm('myapp.view_foo'):
            return True
        # user can view the change form and change the obj
        return request.user.has_perm('myapp.change_foo')
票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/33206304

复制
相关文章
Django官方为什么没有标准项目结构
Django官方并没有提供标准的项目结构,于是网上众说纷纭,百花齐放,一千个读者有一千个哈姆雷特。那我们该怎么设计项目结构呢?在回答这个问题之前,先了解一下Django原生的目录和文件都是干嘛的。
dongfanger
2020/12/10
1.1K0
Django官方为什么没有标准项目结构
[Python学习] Django 权限
本文为大家讲解 Django 框架里自带的权限模型,从理论到实战演练,带领大家了解 Django 里权限是怎么一回事。
py3study
2020/01/07
1.1K0
为什么查看的ARP表项中没有VLAN信息?
如果ARP表项没有VLAN信息,那么代表这条表项中的接口处于三层模式,是一个三层口;
网络工程师笔记
2021/05/17
1.9K0
为什么查看的ARP表项中没有VLAN信息?
django rbac权限
> startapp rbac models.py from django.db import models class User(models.Model): name=models.CharField(max_length=32) pwd=models.CharField(max_length=32) roles=models.ManyToManyField(to="Role") def __str__(self): return self.name class R
py3study
2020/01/19
8000
mysql查看用户的权限(sql查看用户拥有的权限)
mysql数据库授权链接如下: https://blog.csdn.net/GX_1_11_real/article/details/81200566
全栈程序员站长
2022/07/30
3.5K0
mysql查看用户的权限(sql查看用户拥有的权限)
linux查看权限命令
查看权限命令 查看目录的相关权限可以采用命令ls -lD,或者直接用ls -la 如 ls -l wwwt //这里表示查看www目录 修改权限命令 chmod 777 文件名 1.chmod 577 /home/stuser -R 2.umask -p 0200 3.chown XXXX YYYY (XXXX 为用户名 YYYY为文件名) 将当前前目录下的所有文件与子目录的拥有者皆设为 runoob,群体的使用者 runoobgroup: chown -R runoob:runoobgroup *
全栈程序员站长
2022/08/28
11.8K0
django自带权限机制
权限机制能够约束用户行为,控制页面的显示内容,也能使API更加安全和灵活;用好权限机制,能让系统更加强大和健壮。因此,基于Django的开发,理清Django权限机制是非常必要的。
人生不如戏
2018/09/27
1.5K0
五表权限_表格设置查看权限和编辑权限
设计基础:用户、角色、权限三大核心表,加上用户角色、角色权限两个映射表(用于给用户表联系上权限表)。这样就可以通过登录的用户来获取权限列表,或判断是否拥有某个权限。
全栈程序员站长
2022/11/11
3.9K0
五表权限_表格设置查看权限和编辑权限
DJANGO权限和分组
在使用authenticate进行验证后,如果验证通过了。那么会返回一个user对象,拿到user对象后,可以使用django.contrib.auth.login进行登录。示例代码如下:
用户2200417
2022/04/06
9410
mac查看、修改文件权限
在mac添加环境变量时,会发现使用sudo vim etc/profile 对该文件进行编辑完毕,保存时提示:
青山师
2023/05/04
1.6K0
Django Rest Framework 权限(下)
像 Django进阶篇 Rest framework (七) 一样进入,request 的请求流程,进入源码查看具体权限的操作。
小团子
2019/07/18
4160
Django Rest Framework 权限(下)
Django Rest Framework 权限(上)
为了更好的管理各个功能组件,在 django rest framework 认证中,可以将认证类单独的拿出来,放在其它目录下,然后导入到 views.py 文件中,在权限环节也可以这么做。
小团子
2019/07/18
9510
Django Rest Framework 权限(上)
Django REST Framework-权限
Django REST Framework(DRF)为开发人员提供了一种灵活的权限系统,该系统可让您轻松地在API中管理和保护敏感数据。权限系统基于“允许访问的用户”和“访问用户的操作”进行配置,使您可以完全控制API的访问级别。
玖叁叁
2023/04/25
6610
django权限管理(Permission)
什么是权限管理 权限管理,一般指根据系统设置的安全规则或者安全策略,用户可以访问而且只能访问自 己被授权的资源 权限管理好比如钥匙,有了钥匙就能把门打开,但是权限设置是有级别之分的,假如这个 系统有多个权限级别就如一间屋有多个门,想要把所有门都打开您必须要取得所有的钥 匙,就如系统一样。 django权限机制 django权限机制能够约束用户行为,控制页面的显示内容,也能使API更加安全和灵活;用好权限机制,能让系统更加强大和健壮 django权限控制 Django用user,group和permis
程序员同行者
2018/07/02
6.7K1
Django权限机制的实现
权限机制能够约束用户行为,控制页面的显示内容,也能使API更加安全和灵活;用好权限机制,能让系统更加强大和健壮。因此,基于Django的开发,理清Django权限机制是非常必要的。 1.1 Django的权限控制
菲宇
2019/06/13
1.1K0
Django权限机制的实现
Django内置权限扩展案例
overmind项目使用了Django内置的权限系统,Django内置权限系统基于model层做控制,新的model创建后会默认新建三个权限,分别为:add、change、delete,如果给用户或组赋予delete的权限,那么用户将可以删除这个model下的所有数据。
37丫37
2019/03/14
8930
Django内置权限扩展案例
使用show effective grants查看权限
用户 show grants 显示只有连接权限,但该用户却能执行 sbtest.*下的所有操作
GreatSQL社区
2023/08/11
2460
使用show effective grants查看权限
Ubuntu 文件文件夹查看权限和设置权限
-rw-r--r-- (644) 只有所有者才有读和写的权限,组群和其他人只有读的权限
用户5005176
2021/08/25
13.3K0
django权限管理例子_创建django项目的命令
上一篇我们分析了认证的源码,一个请求认证通过以后,第二步就是查看权限了,drf默认是允许所有用户访问
全栈程序员站长
2022/09/19
3960
为什么没有运营的SaaS没有未来?
来源:大虫运营心经  作者 : 花大虫 ---- 职业生涯前几年一直在做C端互联网相关的工作,这两年突然转做B端了,感受有很大的差异,但是却又有很大的相似性,To C的运营经验对To B的运营有巨大的帮助。越做越觉得To B行业有意思,大有可为。 最近我会把近2年亲身经历的一些To B行业运营经验分享给大家。 万信是我现在创业在做的一家餐饮SaaS公司,后面文章中会有涉及。 ✎✎✎ 大家谈To B都会讲产品、讲销售,很少人会讲到运营。殊不知一个To B产品的运营非常关键,因为这直接决定了一个非常重要
腾讯SaaS加速器
2020/06/09
9550

相似问题

Django 2.1查看权限

20

Django模型只读/查看权限+行级权限

12

Django内联用户权限+仅查看-权限问题

10

如何修改django以创建“查看”权限?

64

Django admin -通过权限限制用户查看

12
添加站长 进交流群

领取专属 10元无门槛券

AI混元助手 在线答疑

扫码加入开发者社群
关注 腾讯云开发者公众号

洞察 腾讯核心技术

剖析业界实践案例

扫码关注腾讯云开发者公众号
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
查看详情【社区公告】 技术创作特训营有奖征文