- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
一个很棒的问候社区
我的问题与 Django 中管理用户和模式用户的类型有关,一开始我向您道歉,以防万一我的问题太“新手”或没有意义,我开始与我联系与 Django 用户模式及其在项目中的不同工作可能性。
我有以下情况。
我正在构建一个应用程序,其中我将拥有三种不同的用户类型:
我正在使用默认的 Django 身份验证方案 (django.contrib.auth)。
最初,我确实认为在这种实体方案中,用户表是 Django 保存创建的用户的 auth_user
表:
我在用户表中有 is_patient
、is_medical
和 is_physiotherapist
字段,如 bool 属性。
像一个特定的细节,我知道在 Django 默认模型中,用户不可能修改或添加属性或字段。
这是我无法在 User 表中添加 is_patient
、is_medical
和 is_physiotherapist
bool 字段的一个重要而有力的原因。
一个经典的建议是使用 Userprofile 表扩展用户模型,我在其中通过 OneToOne 关系向用户模型添加字段或属性。基本示例如下:
通过这种方式,我可以让 Django 中的用户拥有实地照片并在给定时刻上传一张 ...
利用之前的优势,以下模式适合或可以替代管理用户角色(patient
、medical
和 physiotherapist
用户类型)?
我将有以下关系:
用户医疗和用户患者
用户物理治疗师和用户患者
所以在它们和其他表之间......
采用这种方法,这些关系不会受到影响吗?
不同的用户将保存在Users 和UserProfile 表之间。从可扩展性的角度来看,这是一个好的做法吗?我的表可能崩溃或我的数据库?
此外,我还看到了其他替代方案,例如:
我将有一个独立或独立的角色表/模型,这可以与 Django 用户模型相关(例如,一个用户可以有多个角色)当我想存储有关 specia 角色的独有信息时,这种方法会很有用吗?
我忽略或不知道让我工作的粒度等级。我已经看到权限和授权系统让我以一种方式进行创建、编辑和删除操作....
在这里,我可以看到群组创建吗?例如医疗组并为他们分配权限并将此权限链接到组成该组的用户?这是另一个好的选择吗?这个选项看起来比较单一,虽然我不知道用户是否可以根据具有的组权限进行一些操作......我不知道这个想法是否正确/正确
我对患者、医疗和理疗师用户的要求是否需要构建自定义用户模型?
最佳答案
在这种情况下,特别是如果您想为患者、医生和物理治疗师存储不同的信息,您可以为每个人创建一个模型,并为每个用户模型创建一个 OneToOne 字段。
class Medic(models.Model):
user = models.OneToOneField(User, primary_key=True)
# other fields
class Physio(models.Model):
user = models.OneToOneField(User, primary_key=True)
# other fields
class Patient(models.Model):
user = models.OneToOneField(User, primary_key=True)
# other fields
通过这种方式,您可以在应用程序逻辑中为每种类型的用户隐式赋予不同的权限/角色(如果您在特殊情况下需要 Django 提供的组和权限,例如 ChiefMedical...)。
你必须为你的应用程序逻辑定义一些方法,比如
def user_is_patient(user):
...
如果您遵循这条路径,最好进行良好的测试以确保您不会遇到意想不到的事情,例如用户是 Medic 和 Physio...
Django 还允许您对用户模型进行子类化。在幕后它会做与上面代码相同的事情,所以最好像上面所示那样明确地做它(这样你就不太可能访问该对象中不存在的属性!)
Taking advantage of the previous, The following schema can be suited or can be an alternative for manage user roles (patient, medical and physiotherapist user types) ?
您显示的架构不是很好,因为它让您将所有用户类型的信息存储在同一个表中(并且具有相同的字段)。例如,Medics 和 Physios 将有一个血型字段类型,如 Patients,它可能不会被定义。
The different users will be saved between the Users and UserProfile table. Is this a good practice in the scalability sense? My tables could be crash or my database?
此解决方案应该没有可伸缩性问题(只要您没有每天写入数百万个新条目)并且您始终可以在进一步优化数据库。但是,您必须确保您的应用不接受“禁止”条目(例如没有 Medic、Physio 或 Patient 资料的用户)
Here, can I see the groups creation? For example a medical group and allocate them permissions and linked this permissions to the users that compose the group ? Is this another good alternative? This option seem more single although I don't know if an user could make some operations according to the group privileges that have ... I don't know if this thinking is correct/right
您可以(应该)使用 Django 的权限系统来为您的用户授予权限。您可以使用它们为同一类型的用户授予不同的权限(例如,拥有比其他人更多权限的医生......或者拥有首席理疗师组......)
Django 允许您为组分配权限。
但我认为组不能取代每个用户的自定义模型,因为您要为他们存储信息。拥有自定义模型和组将是多余的,并且会使您的应用更难维护。
My requirements for patient, medical and physiotherapist users, require build a custom user model?
此选项不会很好(除非它是您唯一的选择),因为您的应用程序将不可重用,并且您可能还会遇到某些软件包的问题。
关于python - Django 上的用户角色架构,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34213066/
抱歉,问题标题含糊不清!我有一个 ASP.NET 应用程序,可与其他第三方软件配合使用(Burning Glass - 通过 tcp/ip 连接到 Web 应用程序,需要 - 正确配置的 dns 条目
我正在开展一个项目,将一个大型网站分解为更小、更具体的网站。我需要能够将对这些网站的访问限制为仅具有必要权限的用户,并且希望尽可能利用现有的成员资格/角色数据模型。 因此,理想情况下,我想将潜在的多个
抱歉,问题标题含糊不清!我有一个 ASP.NET 应用程序,可与其他第三方软件配合使用(Burning Glass - 通过 tcp/ip 连接到 Web 应用程序,需要 - 正确配置的 dns 条目
我对 FOSUserBundle 中的角色有点困惑。用户实体也有角色列,我们可以通过它为用户分配多个角色。根据发布在 Managing users/roles/groups in FOSUserBun
原谅我的新手问题,但我想按顺序执行三个任务并在剧本中使用两个角色: 任务 角色 任务 角色 任务 这是我到目前为止(任务,角色,任务): --- - name: Task Role Task ho
在触发器中,我想检查哪些角色对 USER() 有效,而不是 CURRENT_USER()。(认识到 CURRENT_USER() 返回触发器的 DEFINER)。 是否有任何类型的 USER_ROLE
我有一套Ansible playbooks 和主要的 yml 文件是这样的 - hosts: all roles: - common - install_nginx 我想在触发剧本
因此,我有以下代码输出安装的所有功能和角色: Import-Module ServerManager $Arr = Get-WindowsFeature | Where-Object {$_.Inst
我已经寻找了一段时间,并且已经手动完成了角色和权限的许多部署,但是有什么方法可以在Sitecore中为角色/权限创建一个程序包(或等效程序包)? 当您没有选择从一个环境到另一个环境进行完全部署时,使用
我想找到或创建一个与所有者或至少贡献者具有相同功能的 azure 角色。但此角色不应该有权创建 azure 资源。 我一直在浏览现有的预定义角色。 最佳答案 这在 Azure RBAC 上下文中没有任
我在文档中找不到答案,也找不到示例:是否可以在 role/defaults/ 中命名除 main.yml 之外的文件?我的意思是,main.yml 是具有默认值的文件的唯一有效名称吗? 最佳答案 根据
我尝试了kubectl get sa default命令,但只看到一些非常基本的值。在k8s中查看与特定服务帐户关联的权限/角色的命令是什么? 最佳答案 以下命令可能会有所帮助。它基本上获得RoleB
有没有办法告诉 Spring 在我制作的自定义用户 bean 中找到用户的角色? http://static.springsource.org/sprin...ns-config.html 因此,如果
在我的 playbook 中运行几次 Play 后,我想验证我的应用程序的部署。 在我的角色之一中,我有以下任务,将创建的 ec2 实例添加到“已启动”的主机: - name: Add new ins
我按如下方式将用户添加到角色(请注意,我在我的机器上运行下面显示的代码): Roles.AddUserToRole(oMU.UserName, "Role1"); 使用以下代码我检查用户是否在
我目前在为 postgresql 创建角色时遇到问题,这是我已经做过的,但自昨晚以来取得了任何进展 simplybel@simplybel:~$ sudo -u postgres createuser
一个项目现在有超过 200 个类,每个文件一个类,将它们划分到目录中似乎是恰当的。现在我正在考虑两种不同的策略; a) 按角色或层分组 repositories/ UserRepository
您如何为用户、角色和应用特定实体提供种子?似乎 IdentityModel 以它自己的上下文为目标? internal sealed class Configuration : DbMigration
摩尔庄园手游在六一儿童节上线之后,网上的争议声还是很多的,有夸赞的,称其找回了童年的回忆,也有吐槽的,觉得3d的设计很晕,没有以前的感觉,想要删除账号,那么大家知道怎么去注销吗,步骤流程是什么样的?
在 XP SP2 虚拟机中运行 Oracle 11gR1。完全披露:这是一项任务。 我试图在用户被授予 DBA 角色时进行审计,并在事件发生时发送电子邮件。 我相信命令 AUDIT DBA;将审核对
我是一名优秀的程序员,十分优秀!