基于.net EF6 MVC5+WEB Api 的Web系统框架总结(3)-项目依赖注入

2024-04-10 13:08

本文主要是介绍基于.net EF6 MVC5+WEB Api 的Web系统框架总结(3)-项目依赖注入,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

简介
  依赖注入主要是一种结构性的模式,注重的是类与类之间的结构,它要达到的目的就是设计原则中最少知道和合成复用的原则,减少内部依赖,履行单一职责,最终就是强解耦。依赖注入目前最好的实现就是依赖注入容器。

Unity是微软Patterns & Practices团队所开发的一个轻量级的,并且可扩展的依赖注入(Dependency Injection)容器,它支持常用的三种依赖注入方式:构造器注入(Constructor Injection)、属性注入(Property Injection),以及方法调用注入(Method Call Injection).

本项目基于Unity,减少内部依赖,实现项目解耦。基于LGPL协议开源。

2.项目源码

复制代码
using Microsoft.Practices.Unity;
using Microsoft.Practices.Unity.Configuration;
using System;
using System.Collections.Generic;
using System.Configuration;
using System.Linq;
using System.Text;

namespace ShiQuan.Unity
{
///
/// Unity 辅助对象
///
public class UnityHelper
{
#region 单例

    private static readonly UnityHelper _instance = new UnityHelper();/// <summary>/// Unity 辅助对象/// </summary>public static UnityHelper Instance{get{return _instance;}}#endregionprivate readonly IUnityContainer _container = new UnityContainer();/// <summary>/// 获取容器/// </summary>public IUnityContainer Container{get { return _container; }}private UnityHelper(){var configuration = ConfigurationManager.GetSection(UnityConfigurationSection.SectionName) as UnityConfigurationSection;if (configuration != null){configuration.Configure(_container);}}#region 获取对应接口的具体实现类/// <summary>/// 获取实现类(默认映射)/// </summary>/// <typeparam name="T">接口类型</typeparam>/// <returns>接口</returns>public T GetResolve<T>(){return _container.Resolve<T>();}/// <summary>/// 获取实现类(默认映射)带参数的/// </summary>/// <typeparam name="T">接口类型</typeparam>/// <param name="parameter">参数</param>/// <returns>接口</returns>public T GetResolve<T>(params ParameterOverride[] parameter){return _container.Resolve<T>(parameter);}/// <summary>/// 获取实现类(指定映射)带参数的/// </summary>/// <typeparam name="T"></typeparam>/// <param name="name"></param>/// <param name="parameter"></param>/// <returns>接口</returns>public T GetResolve<T>(string name, params ParameterOverride[] parameter){return _container.Resolve<T>(name, parameter);}#endregion#region 判断接口是否被注册了/// <summary>/// 判断接口是否被实现了/// </summary>/// <typeparam name="T">接口类型</typeparam>/// <returns>bool</returns>public bool IsRegistered<T>(){return _container.IsRegistered<T>();}/// <summary>/// 判断接口是否被实现了/// </summary>/// <typeparam name="T">接口类型</typeparam>/// <param name="name">映射名称</param>/// <returns></returns>public bool IsRegistered<T>(string name){return _container.IsRegistered<T>(name);}#endregion
}

}
复制代码

源码地址:https://gitee.com/ShiQuan25/ShiQuan.Unity

3.调用示例

下面演示调用此程序示例:

首先我们创建数据操作基础项目,定义IDataBase接口,定义一获取名称的方法。

复制代码
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;

namespace ShiQuan.DataAccess
{
///
/// 定义接口
///
public interface IDatabase
{
string Name { get; }
}
}
复制代码

   创建SQLSERVER项目,定义SqlDataBase实现IDatabase接口。

复制代码
using ShiQuan.DataAccess;
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;

namespace ShiQuan.DataServer
{
///
/// 实现
///
public class SqlDataBase : IDatabase
{
public string Name
{
get { return “SqlDataBase”; }
}
}
}
复制代码

创建MySql 项目,定义MySqlDataBase实现IDatabase接口。

复制代码
using ShiQuan.DataAccess;
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;

namespace ShiQuan.DataMySql
{
///
/// 实现
///
public class MySqlDataBase : IDatabase
{
public string Name
{
get { return “MySqlDataBase”; }
}
}
}
复制代码
  创建数据操作工厂项目,定义DataFactory实现根据参数调用不同的实现类。

复制代码
using ShiQuan.DataAccess;
using ShiQuan.DataMySql;
using ShiQuan.DataServer;
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;

namespace ShiQuan.DataRepository
{
///
/// 数据工厂
///
public class DataFactory
{
///
/// 获取数据操作对象
///
///
///
public static IDatabase GetDataBase(string name)
{
switch (name)
{
case “MySql”:
{
return new MySqlDataBase();
}
case “SqlServer”:
default:
{
return new SqlDataBase();
}
}

    }
}

}
复制代码
  创建Console程序进行测试

复制代码
using ShiQuan.DataServer;
using ShiQuan.DataMySql;
using ShiQuan.Unity;
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using ShiQuan.DataAccess;
using ShiQuan.DataRepository;

namespace ConsoleApp
{
class Program
{
static void Main(string[] args)
{
Console.WriteLine(“实例并调用Sql Server…”);
IDatabase sqlserver = DataFactory.GetDataBase(“SqlServer”);
Console.WriteLine(sqlserver.Name);

        Console.WriteLine("实例并调用MySql...");IDatabase mysql = DataFactory.GetDataBase("MySql");Console.WriteLine(mysql.Name);Console.ReadLine();}}

}
复制代码
  项目结构大概是这样的:

运行结果:

4.Unity调用

假设此时,如果我们需要实现其他数据库操作,实现IDatabase接口时,除了增加其他数据库操作项目,还得修改、调整数据操作工厂项目。

但是如果我们的数据操作工厂项目改用依赖注入的方式,工厂项目是不需要引用SQLSERVER项目、MySQL项目及其他数据库操作项目,可以不改动工厂项目的情况下,主程序直接在配置文件中添加相应的操作项目及类,以达到面向接口开发、减少内部依赖、实现项目解耦。

项目添加程序包

主程序配置文件(App.Config或Web.Config)增加配置

配置接口,接口实现对象

复制代码













复制代码
  工厂项目实例调用

复制代码
///
/// 获取数据操作对象
///
///
///
public static IDatabase GetDataBase(string name)
{
//switch (name)
//{
// case “MySql”:
// {
// return new MySqlDataBase();
// }
// case “SqlServer”:
// default:
// {
// return new SqlDataBase();
// }
//}
return ShiQuan.Unity.UnityHelper.Instance.GetResolve(name);
}
复制代码
深圳网站建设www.sz886.com

这篇关于基于.net EF6 MVC5+WEB Api 的Web系统框架总结(3)-项目依赖注入的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/891151

相关文章

IntelliJ IDEA2025创建SpringBoot项目的实现步骤

《IntelliJIDEA2025创建SpringBoot项目的实现步骤》本文主要介绍了IntelliJIDEA2025创建SpringBoot项目的实现步骤,文中通过示例代码介绍的非常详细,对大家... 目录一、创建 Spring Boot 项目1. 新建项目2. 基础配置3. 选择依赖4. 生成项目5.

golang程序打包成脚本部署到Linux系统方式

《golang程序打包成脚本部署到Linux系统方式》Golang程序通过本地编译(设置GOOS为linux生成无后缀二进制文件),上传至Linux服务器后赋权执行,使用nohup命令实现后台运行,完... 目录本地编译golang程序上传Golang二进制文件到linux服务器总结本地编译Golang程序

Linux系统性能检测命令详解

《Linux系统性能检测命令详解》本文介绍了Linux系统常用的监控命令(如top、vmstat、iostat、htop等)及其参数功能,涵盖进程状态、内存使用、磁盘I/O、系统负载等多维度资源监控,... 目录toppsuptimevmstatIOStatiotopslabtophtopdstatnmon

Java通过驱动包(jar包)连接MySQL数据库的步骤总结及验证方式

《Java通过驱动包(jar包)连接MySQL数据库的步骤总结及验证方式》本文详细介绍如何使用Java通过JDBC连接MySQL数据库,包括下载驱动、配置Eclipse环境、检测数据库连接等关键步骤,... 目录一、下载驱动包二、放jar包三、检测数据库连接JavaJava 如何使用 JDBC 连接 mys

Knife4j+Axios+Redis前后端分离架构下的 API 管理与会话方案(最新推荐)

《Knife4j+Axios+Redis前后端分离架构下的API管理与会话方案(最新推荐)》本文主要介绍了Swagger与Knife4j的配置要点、前后端对接方法以及分布式Session实现原理,... 目录一、Swagger 与 Knife4j 的深度理解及配置要点Knife4j 配置关键要点1.Spri

深度解析Java项目中包和包之间的联系

《深度解析Java项目中包和包之间的联系》文章浏览阅读850次,点赞13次,收藏8次。本文详细介绍了Java分层架构中的几个关键包:DTO、Controller、Service和Mapper。_jav... 目录前言一、各大包1.DTO1.1、DTO的核心用途1.2. DTO与实体类(Entity)的区别1

JavaSE正则表达式用法总结大全

《JavaSE正则表达式用法总结大全》正则表达式就是由一些特定的字符组成,代表的是一个规则,:本文主要介绍JavaSE正则表达式用法的相关资料,文中通过代码介绍的非常详细,需要的朋友可以参考下... 目录常用的正则表达式匹配符正则表China编程达式常用的类Pattern类Matcher类PatternSynta

Spring 框架之Springfox使用详解

《Spring框架之Springfox使用详解》Springfox是Spring框架的API文档工具,集成Swagger规范,自动生成文档并支持多语言/版本,模块化设计便于扩展,但存在版本兼容性、性... 目录核心功能工作原理模块化设计使用示例注意事项优缺点优点缺点总结适用场景建议总结Springfox 是

如何在Spring Boot项目中集成MQTT协议

《如何在SpringBoot项目中集成MQTT协议》本文介绍在SpringBoot中集成MQTT的步骤,包括安装Broker、添加EclipsePaho依赖、配置连接参数、实现消息发布订阅、测试接口... 目录1. 准备工作2. 引入依赖3. 配置MQTT连接4. 创建MQTT配置类5. 实现消息发布与订阅

springboot项目打jar制作成镜像并指定配置文件位置方式

《springboot项目打jar制作成镜像并指定配置文件位置方式》:本文主要介绍springboot项目打jar制作成镜像并指定配置文件位置方式,具有很好的参考价值,希望对大家有所帮助,如有错误... 目录一、上传jar到服务器二、编写dockerfile三、新建对应配置文件所存放的数据卷目录四、将配置文