NopCommerce 3. Controller 分析
1. 继承关系,3个abstract类
System.Web.Mvc.Controller
Nop.Web.Framework.Controllers.BaseController
Nop.Admin.Controllers.BaseAdminController
2. BaseController
1. RenderPartialViewToString()
将Viewname对应的页面加载成string
a. IViewEngine.FindPartialView() 来获取ViewEngineReult,够着viewcontext 实例,作为Render()的参数
b.IView.Render() 来加载到streamwriter中
c. streamwriter.Tostring()返回数据
可以扩展下压缩html的方法
html=Regex.Replace(html,”\\n+\\s+”,string.empty);
html=Regex.Replace(html,”\\n+”,string.empty);
html=html.trim();
2. 各种发送消息的方法,主要是配合View来显示后台的消息
是利用ViewData,TempData来传递数据,然后来View中读取循环显示
3. AddLocales()
3. BaseAdminController
1. 无权限访问返回错误的方法
a. ActionResult AccessDeniedView();
b. JsonResult AccessDeniedKendoGridJson();
4. StoreAddressAttribute
做各种判断,如果不符合则return
只记录Get请求的Ip地址,更新Customer表中LastIpAddress字段
5. CustomerLastActivityAttribute
记录最后登录的时间
更新最后活动时,1分钟内数据不更新,防止频繁修改,更新Customer表中LastActivityDateUtc字段
6. StoreLastVisitedPageAttribute
记录最后查看的页面
保存在GenericAttribute表中,需要单独启动是否记录
7. ValidatePasswordAttribute
检验用户是不是需要定时修改密码,默认过期时间在setting表中的PasswordLifetime 字段中设置,默认是90天
如果未设置密码的用户,则下次请求时立即要求修改密码
修改密码就是强制调整到/CustomerChangePassword页面中
8. NopHttpsRequirementAttribute
对get请求判断强制跳转ssl的地址,在setting表中ForceSslForAllPages中设置是否启用对所有页面强制跳转ssl
先判断当前请求是否是ssl,再查看当前的店是否支持ssl,如果支持的话,则跳转到ssl地址
如果setting中未启用该选项,则使用301跳转到当前页面,这不是多此一举吗?301 应该有玄机.
9. AdminValidateIpAddress
限制Admin后台网页不被其他ip访问,保护后台安全
在setting表中的AdminAreaAllowedIpAddresses属性中设置允许访问的ip地址,如果AdminAreaAllowedIpAddresses不为空,此时判断当前request的ip地址是否在其中,不在其中则跳转到/admin/security/accessdenied
10. AdminAuthorizeAttribute:IAuthorizationFilter
继承自IAuthorizationFilter 接口,需要实现void OnAuthorization(AuthorizationContext filterContext);
可以在构造函数中指定bool 来跳过验证
核心方法OnAuthorization方法中,首先在IsAdminPageRequested()方法中判断Controller或Action上是否定义了AdminAuthorize属性,
如果没有权限访问该页面,则返回401 HandleUnauthorizedRequest
权限是定义在PermissionRecord 中,根据sysname 和roleId 来判断权限
首先是每个customer和role有一个多对多的关联
然后是每个role和permissionrecord有一个多对多的关联
验证权限就是遍历该用户的每一个role,然后判断这个role对应的permissionrecord集合中是否包含当前这个页面访问所需要的权限
相关的表有
- Customer-客户信息表
- CustomerRole-客户角色表
- Customer_CustomerRole_Mapping-用户角色表映射
- PermissionRecord-权限记录表
- PermissionRecord_Role_Mapping-角色权限记录关系表
11. AdminAntiForgeryAttribute:IAuthorizationFilter
是对ValidateAntiForgeryTokenAttribute属性的封装,但是新增了配置的功能
可以在setting表中的EnableXsrfProtectionForAdminArea中配置
这个封装的不错,有灵活性,还能有效利用系统原有代码
12. AdminVendorValidation:IAuthorizationFilter
阻止非商户角色的用户登录后台
五种角色,每种角色对应不同的permissionrecord,就可以决定哪些页面可以访问了
- 管理员
- 论坛版主
- 注册用户
- 访客
- 商户
NopCommerce 3. Controller 分析的更多相关文章
- k8s replicaset controller分析(1)-初始化与启动分析
replicaset controller分析 replicaset controller简介 replicaset controller是kube-controller-manager组件中众多控制 ...
- k8s replicaset controller分析(2)-核心处理逻辑分析
replicaset controller分析 replicaset controller简介 replicaset controller是kube-controller-manager组件中众多控制 ...
- k8s replicaset controller 分析(3)-expectations 机制分析
replicaset controller分析 replicaset controller简介 replicaset controller是kube-controller-manager组件中众多控制 ...
- k8s endpoints controller分析
k8s endpoints controller分析 endpoints controller简介 endpoints controller是kube-controller-manager组件中众多控 ...
- kube-controller-manager源码分析-AD controller分析
kubernetes ceph-csi分析目录导航 概述 kube-controller-manager组件中,有两个controller与存储相关,分别是PV controller与AD contr ...
- kube-controller-manager源码分析-PV controller分析
kubernetes ceph-csi分析目录导航 概述 kube-controller-manager组件中,有两个controller与存储相关,分别是PV controller与AD contr ...
- NopCommerce源码分析ContainerBuilder builder.Update(container)
/// <summary> /// Register dependencies /// </summary> /// <param name="config&q ...
- k8s deployment controller源码分析
deployment controller简介 deployment controller是kube-controller-manager组件中众多控制器中的一个,是 deployment 资源对象的 ...
- k8s statefulset controller源码分析
statefulset controller分析 statefulset简介 statefulset是Kubernetes提供的管理有状态应用的对象,而deployment用于管理无状态应用. 有状态 ...
随机推荐
- 201521123020 《Java程序设计》第6周学习总结
本周学习总结 书面作业 1.clone方法 1.1 Object对象中的clone方法是被protected修饰,在自定义的类中覆盖clone方法时需要注意什么? 答:需要将protected改为pu ...
- Java多态总结
面向对象的三大特性:封装.继承.多态.从一定角度来看,封装和继承几乎都是为多态而准备的.这是我们最后一个概念,也是最重要的知识点. 1.定义: 多态:指允许不同类的对象对同一消息做出响应.即同一消息可 ...
- Bitbucket 触发内网 Jenkins Build
为了保证安全性多数的持续集成系统都会部署在公司内部的局域网中,这样如果代码部署在 Bitbucket 等环境中就只能通过轮询的方式来触发 Build.那么有没有办法通过 Bitbucket 的 Web ...
- npm run build生成路径问题
vue项目中可以使用npm run build 命令生成静态文件夹dist,开发者可以直接点击dist文件夹下面的index.html问价来访问自己的项目,但是用vue-cli生成的项目,当运行npm ...
- 升级Linux tar &&解决某用tar解压失败的tar包
今天解压个文件,出来很多这样的: /bin/tar: Ignoring unknown extended header keyword `SCHILY.dev'/bin/tar: Ignoring u ...
- 《Java从入门到放弃》JavaSE入门篇:网络编程(入门版)
要进行网络编程,首先要搞清楚目的是什么. 网络编程说简单点就是在网络上的计算机进行数据的交互. 既然要进行数据交互,那就需要有一个发送方和一个接受方. 按网络上的说法,就是一个攻一个受· 当然,现阶段 ...
- 根据HttpServletRequest获取用户真实IP地址
原因: 当我们通过request获取客户端IP时,自身服务器通常会为了保护信息或者负载均衡的目的,对自身服务器做反向代理.此时如果我们通过request.getRemoteAddr();可能获取到的是 ...
- 纯css隐藏移动端滚动条解决方案(ios上流畅滑动)
纯css隐藏移动端滚动条解决方案(ios上流畅滑动) html代码展示(直接复制代码保存至本地文件运行即可): <!DOCTYPE html> <html lang="en ...
- Spring + Spring MVC + MyBatis 整合
1.所需要Jar包 ? <!-- Spring3.0.1包 --> org.springframework.web-3.0.1 系列 <!-- 公共包 --> sl ...
- StringBuffer的替换和反转和截取功能
A:StringBuffer的替换功能 * public StringBuffer replace(int start,int end,String str): * 从start开始到end用str替 ...