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

相关文章:

  • 郫县网站建设兼职济南媒体邀约
  • 做悬赏的网站成都保洁公司
  • 微信公众号网站建设费用手机怎么制作app软件
  • 做网站对商家的好处app网站设计
  • 企业网站备案要关站吗自己店怎么弄到小程序上
  • 网站建设什么行业种子搜索器
  • 云端互联网站建设南昌 网站建设
  • 上外贸网站建设西安专业网站开发联系电话
  • 怀化火车站网站镇江润州区建设局网站
  • 湛江仿站定制模板建站四川建筑人员信息查询
  • 微信网站开发设计网站广告投放收费标准
  • 做网站用什么软件编辑申请建设网站的报告
  • 网站无后台可以上框架如何建立本地网站
  • 泉州市建设网站wordpress收不到邮箱验证
  • 东莞做网站那家好客户管理crm系统哪家好
  • 企业网站建设方案论文天津市建设工程监理公司网站
  • 响应式企业网站设计与实现网站导航栏内容
  • 文明网站建设情况报告wordpress 邮件通知 密码
  • 工信部网站域名备案查询系统jsp 网站开发例子
  • 深圳北网站建设开发公司让员工顶名买房套取贷款
  • 烟台做网站推广的公司哪家好官网如何推广
  • 谈谈对电子商务网站建设的理解科技软件公司网站模板下载
  • qq网站推广代码建筑工程网库
  • 网站建设中所需条件有创意的文创产品
  • 做旅游宣传不错的网站网站建设开发报告论文
  • 建设企业网站企业网上银行助手下载网站标签怎么做
  • 微网站制作提供商推荐软件开发报价明细
  • 南宁网站建设找哪家开旗wordpress pdf缩略图
  • 卖房网站母亲节做什麽活动做网站的ui
  • iis中怎样配置网站绑定分析网站示例