Warning: file_get_contents(/data/phpspider/zhask/data//catemap/1/asp.net/31.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181

Warning: file_get_contents(/data/phpspider/zhask/data//catemap/4/video/2.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
C#MVC 5中的用户权限/类型逻辑_C#_Asp.net_Model View Controller_Partial Views - Fatal编程技术网

C#MVC 5中的用户权限/类型逻辑

C#MVC 5中的用户权限/类型逻辑,c#,asp.net,model-view-controller,partial-views,C#,Asp.net,Model View Controller,Partial Views,我正在做一个使用MVC5的小项目。我有一个项目/详细信息页面,显示给定项目的信息。每个项目都有多个成员,可以有3种成员类型。这些类型在页面上具有不同的信息和功能。我当前的临时解决方案是基本的,在我看来,我有一个if语句来检查登录用户的类型,并相应地显示部分视图。对我来说,这个解决方案感觉有点“黑客”,我相信还有更好的方法。所以我的问题是:您将如何实现这些功能 谢谢。您可以通过三种方式来实现这一点 1) 即使你认为你提出的解决方案是“黑客式”的,其实这不是一个坏主意。我个人是在一个项目中做的。我根

我正在做一个使用MVC5的小项目。我有一个项目/详细信息页面,显示给定项目的信息。每个项目都有多个成员,可以有3种成员类型。这些类型在页面上具有不同的信息和功能。我当前的临时解决方案是基本的,在我看来,我有一个if语句来检查登录用户的类型,并相应地显示部分视图。对我来说,这个解决方案感觉有点“黑客”,我相信还有更好的方法。所以我的问题是:您将如何实现这些功能


谢谢。

您可以通过三种方式来实现这一点

1) 即使你认为你提出的解决方案是“黑客式”的,其实这不是一个坏主意。我个人是在一个项目中做的。我根据用户的角色创建了部分视图;但是,您将向视图中添加额外的业务逻辑。尝试试用它,看看它在部署时的性能如何。这应该是你的第一次尝试,因为这实际上是你的想法,通过实验你会学到很多

2) 您是否尝试在控制器中检查用户角色,并根据该角色返回特定视图?在这种情况下,业务逻辑将保留在控制器中,这被认为是一种良好的做法

3) 即使我不知道您是在使用ORM(实体框架)还是直接连接到SQL数据库,也可以尝试使用存储过程检索成员的角色,并在DB处理程序类中检查其角色

如您所见,有三个选项可用于检查成员的角色

最后,我建议您阅读有关基于声明/角色的授权的内容。它可能会在未来的项目中帮助您:


有三种方法可供您使用

1) 即使你认为你提出的解决方案是“黑客式”的,其实这不是一个坏主意。我个人是在一个项目中做的。我根据用户的角色创建了部分视图;但是,您将向视图中添加额外的业务逻辑。尝试试用它,看看它在部署时的性能如何。这应该是你的第一次尝试,因为这实际上是你的想法,通过实验你会学到很多

2) 您是否尝试在控制器中检查用户角色,并根据该角色返回特定视图?在这种情况下,业务逻辑将保留在控制器中,这被认为是一种良好的做法

3) 即使我不知道您是在使用ORM(实体框架)还是直接连接到SQL数据库,也可以尝试使用存储过程检索成员的角色,并在DB处理程序类中检查其角色

如您所见,有三个选项可用于检查成员的角色

最后,我建议您阅读有关基于声明/角色的授权的内容。它可能会在未来的项目中帮助您:


我已经在使用声明,这就是我当前在视图中检查用户类型的方式。我完全忘记了选项2,我对默认路由(操作名称和视图名称相同,并返回视图(模型))非常固定,我甚至没有考虑为特定角色返回特定视图。感谢您的回答,我将使用选项2。我已经在使用声明,这就是我当前在视图中检查用户类型的方式。我完全忘记了选项2,我对默认路由(操作名称和视图名称相同,并返回视图(模型))非常固定,我甚至没有考虑为特定角色返回特定视图。谢谢你的回答,我选择第二种。