ASP.NET MVC5实现芒果分销后台管理系统(一):系统结构设计,集成AutoMapper,Log4net

倖福魔咒の 提交于 2020-03-21 08:27:38

在构思完系统思维脑图后,小墨回到家中,便摩拳擦掌开始了开发工作。要想迅速完成系统开发,前期系统设计和准备尤其重要,因为小墨做过太多大大小小的业务系统,准备工作也是十分顺利。

系统结构

file

整个系统工程结构如上,基于传统的三层架构模式(不太懂的快去恶补一下)

  • Web: 基于MVC工程模板搭建,系统模型,视图,控制器
  • Service: 业务
  • Repository: 持久化层,集成EntityFramework
  • Tracking:日志组件集成Log4net
  • CommonUtils:公共工具,提供加密解密/序列化/Excel处理,提供Castle Ioc管理

话不多说,直接上干货

集成Log4net

虽说李老板的芒果业务系统是如此的简单,可一向有着强迫症的小墨仍然有板有眼的规划系统的各个架构功能,做事尽善尽美是小墨的一贯作风。日志能省吗,当然不能!以下集成Log4net.

Nuget下载

这里直接右键解决方案Nuget中搜索Log4net,安装最新版5.2.7

file

日志配置文件

            <configuration>
                <configSections>
                    <section name="log4net" type="log4net.Config.Log4NetConfigurationSectionHandler,log4net" />
                </configSections>

                <log4net debug="true">
                    <appender name="RollingLogFileAppender" type="log4net.Appender.RollingFileAppender">
                        <file value="Logs/Log" />
                        <appendToFile value="true" />
                        <rollingStyle value="Composite" />
                        <staticLogFileName value="false" />
                        <datePattern value="_yyyy.MM.dd.'log'" />
                        <maxSizeRollBackups value="20" />
                        <maximumFileSize value="5MB" />
                        <layout type="log4net.Layout.PatternLayout">
                            <conversionPattern value="%date [%thread] %-5level %logger - %message%newline" />
                        </layout>
                    </appender>
                    <root>
                        <level value="DUBEG" />
                        <appender-ref ref="RollingLogFileAppender" />
                    </root>
                </log4net>
            </configuration>

几点必要说明:

        <file value="Logs/Log" /> 配置logs打印路径
        <staticLogFileName value="false" />  配置Log文件名非静态,因为小墨想每天生成一个Log文件
        <datePattern value="_yyyy.MM.dd.'log'" /> 日志文件格式 Log_2020.03.20.log

Global.asax.cs里配置Log启动

        public class LoggerFactory
            {
                    public static void Config()
                    {
                            var baseDir = AppDomain.CurrentDomain.BaseDirectory;
                            var filePath = Path.Combine(baseDir, "Config\\Log4net.config");
                            var fileInfo = new FileInfo(filePath);
                            log4net.Config.XmlConfigurator.Configure(fileInfo);
                    }

            }

然后就可以优雅的使用日志啦!

//声明

    ILog logger = log4net.LogManager.GetLogger(typeof(MvcApplication));

//使用

    logger.Info("大青芒管理系统已启动.");

这里可以再将ILog包装下,支持参数化打印日志,可以在优化下。

集成AutoMapper

首先说明下整个系统的Model,Dto , Entity,根据业务需要定义比较简单,主要分为用户(代理表),订单表,所以就有
UserModel/UserInfo/UserEntity
OrderModel/OrdeDto/OrderEntity
file

file

这里不可避免的用到各个对象的互相转化,当然我们一定不会挨个字段赋值的,很弱,我们要用AutoMapper。这里我们优先介绍下AutoMapper,因为之后他广泛应用在我们之后的业务中。

Nuget引入AutoMapper

file

AutoMapper配置

file

这里因为,我的Dto与Entity都是简单类型,而且类型都是一致的,所以可以直接Map,但是一般在稍微复杂的业务中,Dto中经常会嵌套其他Dto,或者字段类型也是不匹配的,我们主要使用AutoMapper的两个方法去做转换,这里我不做举例了。

ForMember
ResolveUsing
    

Global.asax.cs系统启动时,启动Map配置。这里在Service层引入一个AutoMapperInit类,过渡一下调用Repository的Initialize方法,是为了不想再Service层引入AutoMapper包,所有Dto与Entity的转换在Repository里处理

    AutoMapperInit.Init();
    

使用AutoMapper
file

感谢阅读!

另外,也欢迎大家关注我的二维码。更多的职场生活,开发与运维方向的技术精华定期发布,希望您在这有所收获。

file

本文由博客群发一文多发等运营工具平台 OpenWrite 发布

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!