简单使用 Mvc 内置的 Ioc

简单使用 Mvc 内置的 Ioc  鉴于网上的文章理论较多,鄙人不才,想整理一份 Hello World(Demo)版的文章。 目录
  • 场景一:简单类的使用
  • 场景二:包含接口类的使用
  • 场景三:涉及引用类库的使用
  •  场景一:简单类的使用  类 DemoService.cs:
    复制代码
        public class DemoService
        {
            public string Test()
            {
                return Guid.NewGuid().ToString();
            }
        }
    复制代码
       控制器 DemoController.cs:
    复制代码
        public class DemoController : Controller
        {
            private readonly DemoService _demoService;
    
            public DemoController(DemoService demoService)
            {
                _demoService = demoService;
            }
    
            public IActionResult Index()
            {
                return Json(_demoService.Test());
            }
        }
    复制代码
       需要先在 Startup.cs 下的 ConfigureServices() 方法中进行注册才能使用,这里提供了三种方法,可以选择自己喜欢的方式进行注册。
    复制代码
        //方法一
        services.AddSingleton(typeof(DemoService), new DemoService());
    
        //方法二
        services.AddSingleton(typeof(DemoService));
    
        //方法三
        services.AddSingleton<DemoService>();
    复制代码
        执行输出结果,正常:   IOC 的容器目前有三种生命周期 Transient、Scoped 和 Singleton,使用方式大致相同,具体差异不在这里进行叙述:
        //范例
        services.AddTransient(typeof(DemoService));
    services.AddScoped<DemoService>();
     场景二:包含接口类的使用  接口 IDemo2Service.cs:
        public interface IDemo2Service
        {
            string Test();
        }
       接口实现 Demo2Service.cs:
    复制代码
        public class Demo2Service : IDemo2Service
        {
            public string Test()
            {
                return Guid.NewGuid().ToString();
            }
        }
    复制代码
       控制器 Demo2Controller.cs:
    复制代码
        public class Demo2Controller : Controller
        {
            private readonly IDemo2Service _demoService;
    
            public Demo2Controller(IDemo2Service demoService)
            {
                _demoService = demoService;
            }
    
            public IActionResult Index()
            {
                return Json(_demoService.Test());
            }
        }
    复制代码
       目前需要在类 Startup.cs 中的 ConfigureServices() 方法内新增的注册方法如下(可选其一):
    复制代码
        //方法一
        services.AddSingleton(typeof(IDemo2Service), new Demo2Service());
    
        //方法二
        services.AddSingleton(typeof(IDemo2Service), typeof(Demo2Service));
    
        //方法三
        services.AddSingleton<IDemo2Service, Demo2Service>();
    复制代码
        输出结果正常: 场景三:涉及引用类库的使用  我们先新增一个用于标识作用的接口 IServiceSupport.cs,该接口没有包含方法,只是一个标识作用,有点类似 DDD 的聚合根接口 IAggregateRoot: 
        public interface IServiceSupport
        {
        }
       接口 IDemo3Service.cs
        public interface IDemo3Service
        {
            string Test();
        }
       接口实现 Demo3Service.cs
    复制代码
        public class Demo3Service : IDemo3Service
        {
            public string Test()
            {
                return Guid.NewGuid().ToString();
            }
        }
    复制代码
       这次我们统一编写一个方法将该类库下的所有接口和实现进行注册:
    复制代码
            private static void AddSingletonServices(IServiceCollection services)
            {
                var asm = Assembly.Load(new AssemblyName("IocCoreDemo.Services"));
                var serviceTypes = asm.GetTypes()
                    .Where(x => typeof(IServiceSupport).IsAssignableFrom(x) && !x.GetTypeInfo().IsAbstract);
    
                foreach (var serviceType in serviceTypes)
                {
                    foreach (var serviceInterface in serviceType.GetInterfaces())
                    {
                        services.AddSingleton(serviceInterface, serviceType);
                    }
                }
            }
    复制代码
       因为使用了反射,所以需要 using System.Reflection;  这次我们在 Startup.cs 类中添加和修改的方法如图所示:    Startup.cs 类中使用的有效命名空间如下:
    复制代码
    using IocCoreDemo.Services;
    using Microsoft.AspNetCore.Builder;
    using Microsoft.AspNetCore.Hosting;
    using Microsoft.Extensions.Configuration;
    using Microsoft.Extensions.DependencyInjection;
    using System.Linq;
    using System.Reflection;
    复制代码
        如果注入失败,执行结果便会如图所示:   为什么会出现上图的情况呢?因为小编忘记把接口 IDemo3Service 继承自接口 IServiceSupport 了,接下来我们只需要做出一个继承的编写操作即可:   再次执行启动,结果便如你所料: 相关的文章:  《》  《》  《》  《》

    相关内容推荐