- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我正在尝试将 IoC 支持添加到我的 REST WCF 服务 (Windows Server 2008)。我是新手,正在按照以下视频中提供的说明进行操作:
http://www.dimecasts.net/Content/WatchEpisode/150
该视频介绍了一些类,这些类帮助我在公开 WCF 端点时启动并运行 StructureMap 的 IoC。我已在本文末尾发布了所有代码。
当我运行我的代码时,自定义类 StructureMapServiceHost 在 StructureMapServiceHost(Type serviceType, params Uri[] baseAddress ) 方法中抛出错误:
public class StructureMapServiceHost : ServiceHost
{
public StructureMapServiceHost() {}
public StructureMapServiceHost(Type serviceType, params Uri[] baseAddress)
: base(serviceType, baseAddress)
{
}
protected override void OnOpening()
{
Description.Behaviors.Add( new IoCServiceBehavior());
base.OnOpening();
}
}
有人告诉我:
提供的服务类型无法作为服务加载,因为它没有默认(无参数)构造函数。要解决此问题,请向类型添加默认构造函数,或将类型的实例传递给主机。
这是真的,它不是。但是视频示例也没有。以下是我的服务:
[ServiceBehavior(InstanceContextMode=InstanceContextMode.Single)]
public class UserService : IUserService
{
public UserService(IUserRepository specification)
{
Specification = specification;
}
public List<User> GetAllUsers()
{
return Specification.GetAllUsers();
}
public User GetUser(string userId)
{
return Specification.GetUserById(new Guid(userId));
}
private List<User> SearchForUsers(string searchString)
{
return Specification.SearchUsers(searchString);
}
public IUserRepository Specification { get; set; }
}
public class IoCServiceBehavior : IServiceBehavior
{
public void Validate(ServiceDescription serviceDescription, ServiceHostBase serviceHostBase)
{
}
public void AddBindingParameters(ServiceDescription serviceDescription, ServiceHostBase serviceHostBase,
Collection<ServiceEndpoint> endpoints, BindingParameterCollection bindingParameters)
{
}
public void ApplyDispatchBehavior(ServiceDescription serviceDescription, ServiceHostBase serviceHostBase)
{
foreach (ChannelDispatcherBase cdb in serviceHostBase.ChannelDispatchers)
{
new StructureMapInstanceProvider(serviceDescription.ServiceType);
}
}
}
public class StructureMapInstanceProvider : IInstanceProvider
{
private readonly Type _serviceType;
public StructureMapInstanceProvider(Type serviceType)
{
_serviceType = serviceType;
}
public object GetInstance(InstanceContext instanceContext)
{
return GetInstance(instanceContext, null);
}
public object GetInstance(InstanceContext instanceContext, Message message)
{
var instance = ObjectFactory.GetInstance(_serviceType);
return instance;
}
public void ReleaseInstance(InstanceContext instanceContext, object instance)
{
throw new NotImplementedException();
}
}
public class StructureMapServiceHostFactory : ServiceHostFactory
{
public StructureMapServiceHostFactory()
{
IoCBootstrap.SetupIoc();
}
protected override ServiceHost CreateServiceHost(Type serviceType, Uri[] baseAddresses)
{
return new StructureMapServiceHost(serviceType, baseAddresses);
}
}
有什么想法吗?谢谢。
编辑 ************ *************** *****
从我删除的 StructureMapServiceHost 中:
public StructureMapServiceHost(Type serviceType, params Uri[] baseAddress)
: base(serviceType, baseAddress) { }
并添加:
public StructureMapServiceHost(Object singletonInstance, params Uri[] baseAddress)
: base( singletonInstance, baseAddress) { }
然后从我的 UserService 构造函数中删除了参数。我没有收到错误消息:
The HTML document does not contain Web service discovery information.
最佳答案
您的服务使用 InstanceContextMode.SingleCall 并且 WCF 团队以他们无限的智慧决定,当 InstanceContextMode 为 SingleCall 时,不调用 IInstanceProvider 来创建实例(参见 https://learn.microsoft.com/en-us/archive/blogs/carlosfigueira/wcf-extensibility-iinstanceprovider - 接口(interface)声明标题下方的第二段)。
目前我在服务主机工厂中有一个不太理想的方法来解决这个问题:
using System;
using System.Collections.Generic;
using System.ServiceModel;
using System.ServiceModel.Activation;
using StructureMap;
using StructureMap.Pipeline;
using System.Linq;
using ServiceHostCreator = System.Func<System.Type, System.Uri[], System.ServiceModel.ServiceHost>;
namespace x.ServiceExtensions
{
public class xWebServiceHostFactory : ServiceHostFactory
{
private readonly IDictionary<InstanceContextMode, ServiceHostCreator> _serviceHostCreators;
public xWebServiceHostFactory()
{
ObjectFactory.Initialize( init =>
init.Scan( scan =>
{
scan.AssembliesFromApplicationBaseDirectory();
scan.IgnoreStructureMapAttributes();
scan.LookForRegistries();
} ) );
_serviceHostCreators = new Dictionary<InstanceContextMode, ServiceHostCreator>
{
{ InstanceContextMode.PerCall, ( t, a ) => PerCallServiceHostCreator( t, a ) },
{ InstanceContextMode.PerSession, ( t, a ) => PerSessionServiceHostCreator( t, a ) },
{ InstanceContextMode.Single, ( t, a ) => SingleInstanceServiceHostCreator( t, a ) }
};
}
protected override ServiceHost CreateServiceHost( Type serviceType, Uri[] baseAddresses )
{
var serviceInstanceContextMode = GetServiceInstanceContextMode( serviceType );
var serviceHostCreator = _serviceHostCreators[ serviceInstanceContextMode ];
return serviceHostCreator( serviceType, baseAddresses );
}
private static InstanceContextMode GetServiceInstanceContextMode( Type serviceType )
{
var serviceBehaviour = serviceType
.GetCustomAttributes( typeof ( ServiceBehaviorAttribute ), true )
.Cast<ServiceBehaviorAttribute>()
.SingleOrDefault();
return serviceBehaviour.InstanceContextMode;
}
private static ServiceHost PerCallServiceHostCreator( Type serviceType, Uri[] baseAddresses )
{
var args = new ExplicitArguments();
args.Set( serviceType );
args.Set( baseAddresses );
var serviceHost = ObjectFactory.GetInstance<TelaWebServiceHost>( args );
return serviceHost;
}
private static ServiceHost PerSessionServiceHostCreator( Type serviceType, Uri[] baseAddresses )
{
return PerCallServiceHostCreator( serviceType, baseAddresses );
}
private static ServiceHost SingleInstanceServiceHostCreator( Type serviceType, Uri[] baseAddresses )
{
var service = ObjectFactory.GetInstance( serviceType );
var args = new ExplicitArguments();
args.Set( typeof(object), service );
args.Set( baseAddresses );
var serviceHost = ObjectFactory.GetInstance<TelaWebServiceHost>( args );
return serviceHost;
}
}
}
这是一项正在进行的工作,可能有更好的方法,但目前我找不到。
关于c# - 尝试向我的 WCF 服务添加 IoC 支持,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/4736633/
我开始认真考虑使用 IoC 容器会引发创建过度设计的解决方案(至少它会促使我尝试使用各种不必要的功能:)。 是时候将我的“IoC”反模式列表与社区列表同步了。 我短暂的经验告诉我们,在启动时每个应用程
我一直在阅读有关控制反转框架的内容,而我只是在玩弄这个问题:“我到底为什么需要一个框架来做到这一点?” 不要误解我的问题...该模式是我们程序员经常使用的,但是...一个功能齐全的框架可以做到这一点?
想要改进这篇文章?提供这个问题的详细答案,包括引文和解释为什么你的答案是正确的。没有足够细节的答案可能会被编辑或删除。 我正在尝试确定是否需要付出额外的努力来封装我的 IoC 容器。经验告诉我,我应该
有人建议我,在使用 IOC 容器时,我应该改变这个: class Foobar: IFoobar, IDisposable {}; 进入这个: interface IFoobar: IDisposab
《畜牧代码》播客第 68 期有人,http://herdingcode.com/herding-code-68-new-year-shenanigans/ ,表示 IOC 容器不适合使用 Python
我们正在使用 NInject 框架在我们的应用程序中实现 IoC/DI。我们有具有内部方法的内部类。要实现 IoC/DI,我们必须提取接口(interface)。但是如果我们在一个内部类中只有内部方法
Spring IOC 相关接口分析 1.BeanFactory Spring 中 Bean 的创建是典型的工厂模式,这一系列的 Bean 工厂,即 IOC 容器,为开发者管理对象之间的依赖关系提供了很
MEF is not an IoC container .不过好像是差不多 一个 IoC 容器。似乎我可以很容易地让 MEF 表现得像一个 IoC 容器(见下面的例子),而且让 MEF 成为一个完整的
只是想继续了解 IOC 的原则。 Q1:静态方法 - 具有静态辅助方法的实用程序类是否应该与 IOC 连接? 例如,如果我有一个带有许多静态方法的 HttpUtils 类,我是否应该尝试通过 IOC
众所周知,在asp.net Startup 类中有一个方法ConfigureServices,我们可以添加自定义服务。服务通过依赖注入(inject)提供。 ASP.NET Core includes
所以..我一直在深入研究 IoC 容器和服务定位器。 我认为 IoC 容器是 IoC 容器,而不是服务定位器,因为 您使用它的方式。您将服务定位器传递给需要依赖项的类,然后通过容器检索依赖项。另一方面
阅读许多有关这三个成语之间差异的帖子。但是比较困惑,然后我遇到了这篇文章: http://martinfowler.com/articles/injection.html 只是想看看我是否做对了。如果
我正在寻找用于 asp.net webapi 的 ioc 容器。我们正在寻找的几个关键功能如下 自定义生命周期 对网络请求生命周期的内置支持 在管理依赖项注册方面与 Web API 的良好集成。 最佳
我很难跟随 FP。当人们说“更惯用的风格”时,我必须明白:99% 的 Java 库不适用于 Kotlin 和 Scala 的 FP 惯用风格,对吧?好吧,我需要 Spring Boot 来快速启动 V
目录 1、Spring 1.1、简介 1.2、优点 1.3、组成 1.4、扩展 2、IO
重要提示:请注意,我并不是说单例具有私有(private)构造函数和静态实例变量(或有人建议使用静态类),而是单例在应用程序生命周期内从控制容器的反转返回相同的实例。 许多容器默认使用较短的生命周期。
Closed. This question needs to be more focused。它当前不接受答案。 想要改善这个问题吗?更新问题,使它仅关注editing this post的一个问题。
松耦合当然很棒,但我经常想知道使用 IoC 容器(例如 CaSTLe Windsor)动态连接的开销对紧耦合系统有什么影响? 我知道详细的答案将取决于 IoC 的用途,但我真的只是想了解 IoC 工作
我正在努力让 IOC 在远程处理场景中工作。我将我的应用程序服务器设置为发布通过 XML 配置的服务(SingleCall)。 众所周知,这就像这样: RemotingConfiguration.Co
我使用 IoC (DI) 方法并且通常有参数,这些参数由最低层(数据库层等)从配置设置(即连接字符串、静态值等)中读取。最好的方法是什么? 直接在这个最底层读取,即: string sendGridA
我是一名优秀的程序员,十分优秀!