基于.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

相关文章

SpringBoot中@Value注入静态变量方式

《SpringBoot中@Value注入静态变量方式》SpringBoot中静态变量无法直接用@Value注入,需通过setter方法,@Value(${})从属性文件获取值,@Value(#{})用... 目录项目场景解决方案注解说明1、@Value("${}")使用示例2、@Value("#{}"php

基于 Cursor 开发 Spring Boot 项目详细攻略

《基于Cursor开发SpringBoot项目详细攻略》Cursor是集成GPT4、Claude3.5等LLM的VSCode类AI编程工具,支持SpringBoot项目开发全流程,涵盖环境配... 目录cursor是什么?基于 Cursor 开发 Spring Boot 项目完整指南1. 环境准备2. 创建

javacv依赖太大导致jar包也大的解决办法

《javacv依赖太大导致jar包也大的解决办法》随着项目的复杂度和依赖关系的增加,打包后的JAR包可能会变得很大,:本文主要介绍javacv依赖太大导致jar包也大的解决办法,文中通过代码介绍的... 目录前言1.检查依赖2.更改依赖3.检查副依赖总结 前言最近在写项目时,用到了Javacv里的获取视频

C#使用Spire.Doc for .NET实现HTML转Word的高效方案

《C#使用Spire.Docfor.NET实现HTML转Word的高效方案》在Web开发中,HTML内容的生成与处理是高频需求,然而,当用户需要将HTML页面或动态生成的HTML字符串转换为Wor... 目录引言一、html转Word的典型场景与挑战二、用 Spire.Doc 实现 HTML 转 Word1

PHP应用中处理限流和API节流的最佳实践

《PHP应用中处理限流和API节流的最佳实践》限流和API节流对于确保Web应用程序的可靠性、安全性和可扩展性至关重要,本文将详细介绍PHP应用中处理限流和API节流的最佳实践,下面就来和小编一起学习... 目录限流的重要性在 php 中实施限流的最佳实践使用集中式存储进行状态管理(如 Redis)采用滑动

Python中logging模块用法示例总结

《Python中logging模块用法示例总结》在Python中logging模块是一个强大的日志记录工具,它允许用户将程序运行期间产生的日志信息输出到控制台或者写入到文件中,:本文主要介绍Pyt... 目录前言一. 基本使用1. 五种日志等级2.  设置报告等级3. 自定义格式4. C语言风格的格式化方法

Three.js构建一个 3D 商品展示空间完整实战项目

《Three.js构建一个3D商品展示空间完整实战项目》Three.js是一个强大的JavaScript库,专用于在Web浏览器中创建3D图形,:本文主要介绍Three.js构建一个3D商品展... 目录引言项目核心技术1. 项目架构与资源组织2. 多模型切换、交互热点绑定3. 移动端适配与帧率优化4. 可

sky-take-out项目中Redis的使用示例详解

《sky-take-out项目中Redis的使用示例详解》SpringCache是Spring的缓存抽象层,通过注解简化缓存管理,支持Redis等提供者,适用于方法结果缓存、更新和删除操作,但无法实现... 目录Spring Cache主要特性核心注解1.@Cacheable2.@CachePut3.@Ca

深入浅出Spring中的@Autowired自动注入的工作原理及实践应用

《深入浅出Spring中的@Autowired自动注入的工作原理及实践应用》在Spring框架的学习旅程中,@Autowired无疑是一个高频出现却又让初学者头疼的注解,它看似简单,却蕴含着Sprin... 目录深入浅出Spring中的@Autowired:自动注入的奥秘什么是依赖注入?@Autowired

Spring 依赖注入与循环依赖总结

《Spring依赖注入与循环依赖总结》这篇文章给大家介绍Spring依赖注入与循环依赖总结篇,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录1. Spring 三级缓存解决循环依赖1. 创建UserService原始对象2. 将原始对象包装成工