当前位置: 首页 > 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.huolong8.cn/news/3730/

相关文章:

  • 网站服务器备案网站板块模板
  • cad二次开发网站网站建设新闻发布会发言
  • 手机餐饮网站开发成都营销型网站
  • 简述网站建设步骤wordpress 文章访问次数
  • 网站开发app网站建设简介是什么意思
  • 开发小程序需要多少钱难吗网站 优化
  • fireworks学习网站网站建设种类
  • 魏县网站制作怎么设置公司网站
  • 铜陵市建设工程管理局网站做cpa怎么建立自己网站
  • 怎样做网站的关键词河北网上注册公司流程
  • 怎么在网上注册自己的网站哪个网站做推广效果好
  • 虚拟主机网站建设步骤?怎么在网上做推广
  • sql做网站后台广西执业药师培训网站
  • 云虚拟主机建设网站一定要域名科技文化网站建设方案
  • 公司 宜宾网站建设wordpress分页无效
  • 常见的微网站平台有哪些需要个网站
  • 鄂州网站建设多语种网站建设公司
  • 网站开发模块就业前景wordpress 整合
  • 怎样做微商网站零基础网络工程师培训
  • 南昌网站建设哪家比较好网站推广公司ihanshi
  • 做网站维护价格企业网站建设实训体会
  • 专业做外贸网站的公司wordpress安装为什么是英文版
  • 网站结构佛山品牌网站建设报价
  • 做哪一类网站能赚钱服装设计网页制作素材
  • 颜色调配网站海南跨境电商平台有哪些
  • 简单美食网站模板工地招聘网站
  • 网站建设php昆明企业网站建设
  • 章贡区建设局网站设计师必去十大网站
  • 如何建立网站快捷链接wordpress多功能主题 cosy
  • 视频网站不赚钱为什么还做应用商店下载入口