码迷,mamicode.com
首页 > Windows程序 > 详细

WebApi 的三种寄宿方式 (二)

时间:2018-04-09 17:19:00      阅读:804      评论:0      收藏:0      [点我收藏+]

标签:wait   create   star   tco   sde   override   routes   object   引用   

 

程序集和宿主不在一个程序集

新建一个类库:

技术分享图片

SelfHost:

方法一:

1.添加对MyControllers类库的引用.

2.在控制台代码中加入一行代码:

技术分享图片

当然,可以添加多个程序集.(记得引用)

技术分享图片
            var config = new HttpSelfHostConfiguration("http://localhost:9527");
            config.Routes.MapHttpRoute(
                "API Default",
                "api/{controller}/{action}/{id}",
                new { id = RouteParameter.Optional });

            //加载外部程序集
            Assembly.Load("MyControllers");

            using (var server = new HttpSelfHostServer(config))
            {
                server.OpenAsync().Wait();
                Console.WriteLine("请开始您的表演");
                Console.ReadLine();
            }
View Code

3.测试结果:

技术分享图片

方法二:

1.新建自定义的 AssembliesResolver 类

技术分享图片

技术分享图片View Code

2.修改控制台代码:

技术分享图片

 

技术分享图片
            var config = new HttpSelfHostConfiguration("http://localhost:9527");
            config.Routes.MapHttpRoute(
                "API Default",
                "api/{controller}/{action}/{id}",
                new { id = RouteParameter.Optional });

            //加载外部程序集
            //Assembly.Load("MyControllers");
            //Assembly.Load("TestControllers");

            config.Services.Replace(typeof(IAssembliesResolver), new MyAssembiesResolver());

            using (var server = new HttpSelfHostServer(config))
            {
                server.OpenAsync().Wait();
                Console.WriteLine("请开始您的表演");
                Console.ReadLine();
            }
View Code

实际上就添了一行代码...

3.测试:

技术分享图片

 

上面的方法将程序集写死在代码里,这肯定不符合要求.

方法三:

新建3个类,如下:

    public class AppConfigSetting
    {
        public static string AssembliesLoadFrom => GetValue();

        public static string GetValue([CallerMemberName]string key = null)
        {
            return System.Configuration.ConfigurationManager.AppSettings[key];
        }
    }

 

    public class AssembliesLoad : ConfigurationSection
    {

        [ConfigurationProperty("", IsDefaultCollection = true)]
        public AssemblyElementCollection AssemblyNames
        {
            get { return (AssemblyElementCollection)this[""]; }
        }

        public static AssembliesLoad GetSection()
        {
            return ConfigurationManager.GetSection(AppConfigSetting.AssembliesLoadFrom) as AssembliesLoad;
        }
    }
    public class AssemblyElementCollection : ConfigurationElementCollection
    {
        protected override ConfigurationElement CreateNewElement()
        {
            return new AssemblyElement();
        }
        protected override object GetElementKey(ConfigurationElement element)
        {
            AssemblyElement serviceTypeElement = (AssemblyElement)element;
            return serviceTypeElement.AssemblyName;
        }
    }

    public class AssemblyElement : ConfigurationElement
    {
        [ConfigurationProperty("assemblyName", IsRequired = true)]
        public string AssemblyName
        {
            get { return (string)this["assemblyName"]; }
            set { this["assemblyName"] = value; }
        }
    }

 

    public class WebApiResolver : DefaultAssembliesResolver
    {
        public override ICollection<Assembly> GetAssemblies()
        {
            AssembliesLoad settings = AssembliesLoad.GetSection();
            if (null != settings)
            {
                try
                {
                    foreach (AssemblyElement element in settings.AssemblyNames)
                    {
                        AssemblyName assemblyName = AssemblyName.GetAssemblyName(element.AssemblyName);
                        if (!AppDomain.CurrentDomain.GetAssemblies().Any(assembly => AssemblyName.ReferenceMatchesDefinition(assembly.GetName(), assemblyName)))
                        {
                            AppDomain.CurrentDomain.Load(assemblyName);
                        }
                    }
                }
                catch (Exception e)
                {

                }
            }
            return base.GetAssemblies();
        }
    }

 

修改配置文件:

<configuration>
  <configSections>
    <section name="test1" type="SelfHost.AssembliesLoad,SelfHost"/>
    <section name="test2" type="SelfHost.AssembliesLoad,SelfHost"/>
  </configSections>

  <appSettings>
    <add key="AssembliesLoadFrom" value="test1"/>
  </appSettings>

  <test1>
    <add assemblyName="MyControllers.dll" />
    <add assemblyName="TestControllers.dll" />
  </test1>

  <test2>
    <add assemblyName="Wjire.Controllers.dll" />
  </test2>

  <startup>
    <supportedRuntime version="v4.0" sku=".NETFramework,Version=v4.5" />
  </startup>
</configuration>

 

修改控制台代码:

技术分享图片

 

测试结果就不贴了.

OwinSelfHost:

目前不知道怎么使用配置文件的方式,因为只要添加了程序集的引用,Owin就能找到里面的控制器,

就算采用上面的方法三也没有什么用,还是全部都能访问到

 

额外:

1.如果不同的程序集中有相同名字的控制器,那么会报错

技术分享图片

 

WebApi 的三种寄宿方式 (二)

标签:wait   create   star   tco   sde   override   routes   object   引用   

原文地址:https://www.cnblogs.com/refuge/p/8760990.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!