我有一个非常基本的WebAPI设置,带有令牌认证
在申请开始我做:
protected void Application_Start()
{
DependencyConfig.RegisterDependecis();
//...
//...
}
哪个电话:
public class DependencyConfig
{
private static ServiceContainer _LightInjectContainer;
public static ServiceContainer LightInjectContainer
{
get { return _LightInjectContainer; }
}
public static void RegisterDependecis()
{
var container = new LightInject.ServiceContainer();
container.RegisterApiControllers();
container.ScopeManagerProvider = new PerLogicalCallContextScopeManagerProvider();
container.EnableWebApi(GlobalConfiguration.Configuration);
container.Register<IRegistrationManager, RegistrationManager>(new PerScopeLifetime());
_LightInjectContainer = container;
}
}
现在,当客户端调用令牌端点(请求令牌)时,我在此处定义的提供程序:
OAuthOptions = new OAuthAuthorizationServerOptions
{
//...
//...
Provider = new SimpleAuthorizationServerProvider()
//...
//...
};
正在使用此方法:
public class SimpleAuthorizationServerProvider : OAuthAuthorizationServerProvider
{
//...
public override async Task GrantResourceOwnerCredentials(OAuthGrantResourceOwnerCredentialsContext context)
{
//...
// Here I get the exception!
var registrationManager = DependencyConfig.LightInjectContainer.GetInstance<IRegistrationManager>();
//...
}
//...
}
当我尝试让实例出现以下错误时:
尝试创建没有当前作用域的作用域实例。
我知道LightInject有一个每个请求的开始/结束范围的概念,它实际上告诉我没有启动范围。但我似乎无法确定究竟是什么,需要修复。
答案 0 :(得分:1)
通过阅读this问题中的最后答案,我提出了这个解决方案:(手动启动范围)
using(DependencyConfig.LightInjectContainer.BeginScope())
{
IRegistrationManager manager = DependencyConfig.LightInjectContainer.GetInstance<IRegistrationManager>();
}
技术上它可行,但我不确定它是否是关于幕后发生的正确解决方案。
答案 1 :(得分:0)
我是LightInject的作者
您可以在处理程序(SimpleAuthorizationServerProvider)
中尝试此操作
request.GetDependencyScope().GetService(typeof(IRegistrationManager)) as IRegistrationManager;
实际上没有理由将容器暴露为静态公共成员,因为这样可以很容易地开始使用服务定位器反模式。
请查看此博客文章以获取更多信息。
http://www.strathweb.com/2012/11/asp-net-web-api-and-dependencies-in-request-scope/