当前位置: 首页 > news >正文

上海网站制作的二手书籍交易网站开发方式

上海网站制作的,二手书籍交易网站开发方式,视频剪辑公司,1688货源网一件代发拼多多asp.net core 使用 AccessControlHelper 控制访问权限Intro由于项目需要#xff0c;需要在基于 asp.net mvc 的 Web 项目框架中做权限的控制#xff0c;于是才有了这个权限控制组件#xff0c;最初只是支持 netframework#xff0c;后来 dotnetcore 2.0 发布了之后添加了对… asp.net core 使用 AccessControlHelper 控制访问权限Intro由于项目需要需要在基于 asp.net mvc 的 Web 项目框架中做权限的控制于是才有了这个权限控制组件最初只是支持 netframework后来 dotnetcore 2.0 发布了之后添加了对 asp.net core 的支持在 dotnetcore 3.0 发布之后也增加了对 asp.net core 3.0 的支持(1.9.0及之后版本)目前对于 asp.net core 支持的更多一些asp.net core 可以使用 TagHelper 来控制页面上元素的权限访问也可以通过 Policy 来控制权限访问同时支持通过中间件也可以实现对静态资源的访问。安装 AccessControlHelper nuget 包安装 nuget 包 WeihanLi.AspNetMvc.AccessControlHelperdotnet add package WeihanLi.AspNetMvc.AccessControlHelper实现自己的访问策略资源访问策略/API访问策略以下代码定义了一个简单的访问策略需要登录且拥有 Admin 角色可以根据自己需要调整优化public class AdminPermissionRequireStrategy : IResourceAccessStrategy { private readonly IHttpContextAccessor _accessor; public AdminPermissionRequireStrategy(IHttpContextAccessor accessor) { _accessor accessor; } public bool IsCanAccess(string accessKey) { var user _accessor.HttpContext.User; return user.Identity.IsAuthenticated user.IsInRole(Admin); } public IActionResult DisallowedCommonResult new ContentResult { Content No Permission, ContentType text/plain, StatusCode 403 }; public IActionResult DisallowedAjaxResult new JsonResult(new JsonResultModel { ErrorMsg No Permission, Status JsonResultStatus.NoPermission }); }页面元素访问策略定义页面元素/控件访问策略public class AdminOnlyControlAccessStrategy : IControlAccessStrategy { private readonly IHttpContextAccessor _accessor; public AdminOnlyControlAccessStrategy(IHttpContextAccessor httpContextAccessor) _accessor httpContextAccessor; public bool IsControlCanAccess(string accessKey) { if (Never.Equals(accessKey, System.StringComparison.OrdinalIgnoreCase)) { return false; } var user _accessor.HttpContext.User; return user.Identity.IsAuthenticated user.IsInRole(Admin); } }服务注册配置在 Startup 里注册服务services.AddAccessControlHelper() .AddResourceAccessStrategyFilters.AdminPermissionRequireStrategy() .AddControlAccessStrategyFilters.AdminOnlyControlAccessStrategy() ;如果你只是 web api 不涉及到页面元素的权限控制可以只注册 ResourceAccessStrategyservices.AddAccessControlHelper() .AddResourceAccessStrategyFilters.AdminPermissionRequireStrategy();默认访问策略的生命周期是单例的如果需要注册为Scoped可以指定默认的生命周期services.AddAccessControlHelper() .AddResourceAccessStrategyFilters.AdminPermissionRequireStrategy(ServiceLifetime.Scoped);API/资源的权限控制对于 asp.net core 应用推荐使用 Policy 来控制权限的访问可以在需要权限控制的 Action 或者 Controller 上设置 [Authorize(AccessControl)] 或者 [Authorize(AccessControlHelperConstants.PolicyName)][Authorize(AccessControlHelperConstants.PolicyName)] public class SystemSettingsController : AdminBaseController { // ... }[Authorize(AccessControlHelperConstants.PolicyName)] public ActionResult UserList() { return View(); }页面元素的权限控制引用 TagHelper在 Views 目录下的 _ViewImports.cshtml 文件中导入 AccessControlHelper 的 TagHelperusing ActivityReservation using WeihanLi.AspNetMvc.AccessControlHelper using WeihanLi.AspNetMvc.MvcSimplePager addTagHelper *, Microsoft.AspNetCore.Mvc.TagHelpers addTagHelper *, WeihanLi.AspNetMvc.AccessControlHelper详见: https://github.com/WeihanLi/ActivityReservation/blob/dev/ActivityReservation/Areas/Admin/Views/_ViewImports.cshtml页面元素配置在需要权限控制的元素上增加 asp-access 的 attribute 就可以了如果需要 access-key 通过 asp-access-key 来配置ul classlist-group asp-access asp-access-keyAdminOnly li roleseparator classlist-unstyled br / /li li classlist-group-itemHtml.ActionLink(用户管理, UserList, Account)/li li classlist-group-itemHtml.ActionLink(操作日志查看, Index, OperationLog)/li li classlist-group-itemHtml.ActionLink(系统设置管理, Index, SystemSettings)/li li classlist-group-item Html.ActionLink(微信设置管理, Index, new { controller Config, area Wechat }) /li /ul这样就可以了有权限访问的时候才会正常渲染没有权限访问的时候这一段 ul 并不会渲染输出在客户端浏览器查看源代码也不会看到对应的代码Referencehttps://github.com/WeihanLi/ActivityReservationhttps://github.com/WeihanLi/AccessControlHelper
http://www.sadfv.cn/news/3730/

相关文章:

  • 安徽中兴建设工程有限公司网站合肥网站建设新手
  • 网站静态化 好处广州公司注册场地要求
  • 推广网站推荐培训网站项目ppt怎么做
  • 网站备案 超链接网站规划的主要任务是什么
  • 河南省大型项目建设办公室网站wordpress外贸主题免费
  • 网站设计术语网站建设方案免费下载
  • 创新建设资金网站wordpress标签加标题
  • 广州网站建设哪个好徐州做网站的设计师
  • 高校网站如何建设查找网站开发者
  • 网站设计集团首页优化公司
  • 在线做gif图网站深圳 网站设计公司
  • 响应式网站的登录设置二手车网站开发数据库设计
  • 旅游网站哪个做的好wordpress支持pdf
  • 网站建立与推广手机兼职赚钱一单一结学生
  • 模板网站 怎么做优化怎么做磁力网站
  • 榆林网站开发长沙门户网站建设公司
  • 电气工程WordPress模板福建seo排名
  • 网站 宣传方案网站后台分析图怎么做
  • 教做吃的网站辽宁省建设信息网
  • 期刊类网站建设中山网站建设企业
  • 如何搭建一个购物网站企业网站前端模板下载
  • 网站开发公司地址深圳网站设计服
  • 深圳网站设计公司电wordpress文章商品导购
  • 怎么做创业网站免费下载android
  • 网站漂浮图片律师在哪个网站做推广好
  • 做网站文件夹都起什么名字商城网站建设实例需求
  • 如何做美发店网站蒙特网站建设公司
  • 网站dns解析设置有哪些专做旅游定制的网站
  • 长沙制作网站公司哪家好wordpress客户留言插件
  • 盗号和做钓鱼网站那个罪严重蓝色企业网站手机版织梦模板