以下是本人最近对NopCommerce和SmartStore.net部分代码的研究和总结,主要集中于:依赖注入、异常处理、对象映射、系统缓存、日志这些方面,供大家参考。

NOP 3.8

/// <summary>
/// 在NOP的运动环境中 进行组件、插件初始化、依赖注入、任务启动
/// </summary>
/// <param name="config">Config</param>

public void Initialize(NopConfig config)
{  

//依赖注入
RegisterDependencies(config);

//注册对象映射关系
RegisterMapperConfiguration(config);

//startup tasks启动任务
if (!config.IgnoreStartupTasks)
{
RunStartupTasks();
}

}

一、全局异常捕获处理:Global.asax.cs>>Application_Error     

二、依赖注入

调用位置:Nop.Core.Infrastructure>NopEngine方法中调用了RegisterDependencies()方法

1.Nop.Web.Framework\DependencyRegistrar.cs

2.Nop.Web.Infrastructure\DependencyRegistrar.cs

3.Nop.Admin.Infrastructure\DependencyRegistrar.cs

4.其他插件类库中也有

三、AutoMapper对象映射转换工具

位置:Nop.Admin.Infrastructure.Mapper.AdminMapperConfiguration类中GetConfiguration()方法。

功能:

  实现了Nop.Core.Domain.Common领域层中各实体类到Nop.Admin.Models.Common表示层各Model模型的对象映射。

  (1)使用Ignore忽略一些字段的映射。

  (2)对领域层中实体可以为null的字段作判断,映射到模型类为相应的值

  (3)MappingExtensions类根据GetConfiguration中的配置,进行映射(类型转换)

  (4)ADMIN和web层相应有各自的model,所以需要不同的MappingExtensions进行相应转换,而GetConfiguration()配置则只有一处。

  (5)NOP 4.10开始MappingExtensions代码中使用了泛型方法,简化了各类型的转换工作。

    public static TModel ToModel<TEntity, TModel>(this TEntity entity, TModel model)

初始化:Nop.Core.Infrastructure.NopEngine引擎类中的RegisterMapperConfiguration(NopConfig config)方法进行了AutoMapper的初始化。

对象如何转换

(1)\Presentation\Nop.Web\Extensions\MappingExtensions.cs调用MapTo()方法

(2)\Presentation\Nop.Web\Administration\Extensions\MappingExtensions.cs调用MapTo()方法

四、缓存

(1)以下几个类分别实现了Nop.Core.Caching.ICacheManager接口

  RedisCasheManager:数据存在于Redis中(缓存使用范围更加广泛,包括Azure或者其他服务器的站点)

  MemoryCacheManager:数据缓存在内存中(表示用于在HTTP请求(长期缓存)之间进行缓存的管理器)

  PerRequestCacheManager:数据缓存于HttpContextBase.Items的键值集合中(表示在HTTP请求(短期缓存)期间缓存的管理器,比如一个页面中多次请求一个方法)

  NopNullCache:是用于测试项目的,并没有实现缓存功能。

    

(2)对实现类进行依赖注入:Nop.Web.Framework.DependencyRegistrar()方法中进行了短期缓存、长期缓存(RedisCacheManager或者MemoryCacheManager)的注册。

(3)Nop.Core.Caching.CacheExtensions类(4.0以上版本无此类)对实现了ICacheManager的类(PerRequestCacheManager、RedisCacheManager、MemoryCacheManager)进行了扩展,实现了Get方法。Get方法中缓存存在时会立刻返回数据,不存在时会通过Func<T>代理方法,自动添加到缓存列表中,缓存默认时间为60秒。

  

(4)系统调用了CacheExtensions中的Get()方法对系统数据进行了缓存(存在则返回,不存在则加入缓存列表)

(5)系统调用了MemoryCacheManager中的RemoveByPattern方法对系统数据在指定持续时间(60秒)过后逐出缓存项,另外系统主要在服务层、表示层、插件层调用了这些缓存的相关方法。

 五、系统日志

(1)Nop.Web.Framework.DependencyRegistrar.Register()方法中对日志组件进行了注入

    builder.RegisterType<DefaultLogger>().As<ILogger>().InstancePerLifetimeScope();

(2)DefaultLogger类实现了日志的增、删、查功能。(nop默认将日志记录在了数据中)

(3)Nop.Services.Logging.LoggingExtensions类又对上面的类进行了扩展,系统调用了这个类里面以下方法记录日志。

  

 六、EF多表联查、分页功能(商品销售排行报表)

SmartStore.net 3.x

Global.asas.cs中的Application_Start()方法中进行环境初始化,依赖注入、组件初始化

一、依赖注入:

SmartStore.Core.Infrastructure.EngineContext.CreateEngineInstance()方法,最后调用SmartStoreEngine()方法

(1)SmartStore.Core.Infrastructure.SmartStoreEngine类中RegisterDependencies()方法

(2)SmartStore.Core.Logging.LoggingModule (继承了 Autofac.Module)调用了Autofac.Module.Load()方法进行注册。

(3)SmartStore.Web.Framework.DependencyRegistrar(继承了IDependencyRegistrar)中的Register()方法,注册了所有的模块(这些模块都继承了Autofac.Module)

二、全局异常捕获:

(1)MVC:SmartStore.Web.Framework.Filters中的HandleExceptionFilter

(2)WebApi:SmartStore.Web.Framework.Filters.WebApiExceptionFilterAttribute(只能实现对Action\Controllers方法异常的过滤功能)

    (1)SmartStore.Web.Framework.DependencyRegistrar类(661行)Load(ContainerBuilder builder)方法增加了builder.RegisterApiControllers(foundAssemblies),实现了对WebApiControllers的注册。

    (2)SmartStore.Web.Framework.WebApi.WebApiStartupTask的Execute()方法增加了WebApiExceptionFilterAttribute、WebApiExceptionLogger、WebApiExceptionHandler,对新增过虑器进行注册。

(3)WebApi全局异常捕获(针对HandleExceptionFilter捕获不到的异常)

    (1)SmartStore.Web.Framework.WebApi.WebApiExceptionLogger类

    (2)SmartStore.Web.Framework.WebApi.WebApiExceptionLogger.WebApiExceptionHandler类

三、AutoMapper对象映射转换工具

位置:SmartStore.Admin.Infrastructure.AutoMapperAdminProfile类中AutoMapperAdminProfile()方法。

功能:实现了SmartStore.Core.Domain.Common领域层中各实体类到SmartStore.Admin.Models.Common表示层各Model模型的对象映射。

初始化:Global.asas.cs中调用了RegisterClassMaps(IEngine engine)方法中进行了AutoMapper初始化工作

对象如何转换

(1)\Presentation\SmartStore.Web\Extensions\MappingExtensions.cs调用MapTo()方法

(2)\Presentation\SmartStore.Web\Administration\Extensions\MappingExtensions.cs调用MapTo()方法

四、WebApi

(1)SmartStore.Web.Framework.WebApi.WebApiStartupTask类实现了IStartupTask接口(会在系统初始化时调用)

(2)WebApiStartupTask类中Execute方法实现了WebApi路由注册

(3)SmartStore.Web.Controllers.ValuesController为自己在web层新建立的webapi控制器

(3)在类名、方法名加属性[WebApiAuthenticate(Permission = "ManageImports")]以实现对Api的客户端认证。

(5)具体WebApi实现代码请查看SmartStore.WebApi插件项目(可以用SmartStore.WebApi.Client工具进行客户端调试)

六、实体验证-FluentValidation

示例代码-自己增加了一个正则表达式的验证-具体请参考系统(SmartStore.Web.Validators.Customer.RegisterValidator)

RuleFor(x => x.Email).NotEmpty().WithMessage(localizationService.GetResource("Account.Fields.Email.Required"));
RuleFor(x => x.Email).EmailAddress().WithMessage(localizationService.GetResource("Common.WrongEmail"));
RuleFor(x => x.FirstName).NotEmpty().WithMessage(localizationService.GetResource("Account.Fields.FirstName.Required"));
RuleFor(x => x.LastName).NotEmpty().WithMessage(localizationService.GetResource("Account.Fields.LastName.Required"));
RuleFor(x => x.Username).Matches(@"^[a-zA-Z0-9_-]{4,16}$").WithMessage("4到16位(字母,数字,下划线,减号)");

SmartStore.Net、NopCommerce 全局异常处理、依赖注入、代码研究的更多相关文章

  1. 利用Lombok编写优雅的spring依赖注入代码,去掉繁人的@Autowired

    大家平时使用spring依赖注入,都是怎么写的? @Servicepublic class OrderService {@Autowiredprivate UserService userServic ...

  2. ASP.NET Core 中间件的使用(三):全局异常处理机制

    前言 我们经常听到"秒修复秒上线",觉得很厉害的样子. 其实不然,这只是一个调侃而已,出现问题的方式很多(逻辑漏洞.代码异常.操作方式不正确等). 我们今天来说代码异常问题怎么快速 ...

  3. 细数Javascript技术栈中的四种依赖注入

    作为面向对象编程中实现控制反转(Inversion of Control,下文称IoC)最常见的技术手段之一,依赖注入(Dependency Injection,下文称DI)可谓在OOP编程中大行其道 ...

  4. go语言依赖注入实现

    最近做项目中,生成对象还是使用比较原始的New和简单工厂的方式,使用过程中感觉不太爽快(依赖紧密,有点改动就比较麻烦),还是比较喜欢使用依赖注入的方式. 然后网上没有找到比较好用的依赖注入包,就自己动 ...

  5. 基于DDD的.NET开发框架 - ABP依赖注入

    返回ABP系列 ABP是“ASP.NET Boilerplate Project (ASP.NET样板项目)”的简称. ASP.NET Boilerplate是一个用最佳实践和流行技术开发现代WEB应 ...

  6. 基于.NET平台的分层架构实战(六)——依赖注入机制及IoC的设计与实现[转]

    原文:http://www.cnblogs.com/leoo2sk/archive/2008/06/19/1225223.html 我们设计的分层架构,层与层之间应该是松散耦合的.因为是单向单一调用, ...

  7. Spring Boot 2.x 系列教程:WebFlux REST API 全局异常处理 Error Handling

    摘要: 原创出处 https://www.bysocket.com 「公众号:泥瓦匠BYSocket 」欢迎关注和转载,保留摘要,谢谢! 本文内容 为什么要全局异常处理? WebFlux REST 全 ...

  8. 第六节:SignalR完结篇之依赖注入和分布式部署

    一. SignalR中DI思想的应用 DI,即依赖注入,它是一种不负责创建其自己的依赖项对象的一种模式,通常用来降低代码之间的耦合性,广泛应用于架构设计,是必不可少的一种思想. 下面结合一个需求来说一 ...

  9. ABP的依赖注入

    目录 说说ABP的依赖注入 代码追踪 说说ABP的依赖注入 上篇abp运行机制分析分析了ABP在启动时,都做了那些事:这篇我们来说说ABP的最核心的一部分:依赖注入(DependencyInjecti ...

随机推荐

  1. 带参数的sigmoid

    $y=\frac{1}{1+e^{-(\alpha\times x+\beta)}}$ alpha越大,曲线越陡峭,beta控制平移 import numpy as np import pylab a ...

  2. [转]ssh和SSH服务(包含隧道内容)

    本文对SSH连接验证机制进行了非常详细的分析,还详细介绍了ssh客户端工具的各种功能,相信能让各位对ssh有个全方位较透彻的了解,而不是仅仅只会用它来连接远程主机. 另外,本人翻译了ssh客户端命令的 ...

  3. 开源配置管理平台-Apollo

    Apollo(阿波罗)是携程框架部门研发的配置管理平台,能够集中化管理应用不同环境.不同集群的配置,配置修改后能够实时推送到应用端. Apollo官网地址

  4. 服务端怎样暴露IBinder接口对象

    服务端怎样暴露IBinder接口对象: package com.example.mydownload; import android.app.Service; import android.conte ...

  5. C# 给枚举类型增加一个备注特性

    /// <summary> /// 备注特性 /// </summary> public class RemarkAttribute : Attribute { /// < ...

  6. Python序列化之Json基础

    python的序列化就是将python的基本对象转换为字符串的过程,反之则是反序列化. 序列化类型: -> import json import pickle 序列化定义: 序列化:对象.列表. ...

  7. Numpy合并矩阵

    横向合并:hstack 纵向合并:vstack

  8. 【emWin】例程二十六:窗口对象——Listbox

    简介: 列表框用于选择列表的一个元素.创建的列表框可以没有环绕的框架窗口,或者作为 FRAMEWIN 小工具的子窗口建立列表框中的项目被选定后,会突出显示. 触摸校准(上电可选择是否进入校准界面) 示 ...

  9. graph radar 界面开发笔记

    首先需要了解odoo图表视图的实现是采用了前端nvd3框架,nvd3是一个以复用为目的,基于d3框架的前端框架,官方地址:nvd3.org.从官网可见,目前nvd3可以用来画的图表并不包含雷达图. 第 ...

  10. .NET DLL 加密工具

    最近发现了一个软件叫 DotfuscatorPro 混淆加密工具 设置方式如下 1. Settings->Global Options Disable String Encryption 设为  ...