我无法找到通过Autofac解析服务的正确方法,该构建在构建 Owin上下文时使用,并且在请求端处理 。
由于此时OwinContext仍在构建中,因此无法通过调用HttpContext.Current.GetOwinContext().GetAutofacLifetimeScope()
找到LifetimeScope。此处尚未提供OwinContext。
在我的代码中,IAdfsAuthorizationProvider
服务直接在Container
处解析,但在请求之后不再处理,并且存活时间更长。
我可以通过调用container.BeginLifetimeScope()
创建一个新的LifeTimeScope,但现在LifeTime被分离了请求,并且可能会解析同一请求中的不同实例。并且无法在正确的时间自行处理lifeTimeScope。
public void Configure(IAppBuilder app)
{
var builder = new ContainerBuilder();
builder.RegisterType<AdfsAuthorizationProvider>().As<IAdfsAuthorizationProvider>().InstancePerLifetimeScope();
var container = builder.Build();
app.UseAutofacMiddleware(container);
// **Service that's not binding to the request lifetime.**
var service = container.Resolve<IAdfsAuthorizationProvider>();
app.UseOAuthAuthorizationServer(new OAuthAuthorizationServerOptions
{
Provider = new AuthorizationServerProvider(service),
});
}
有人有建议吗?
答案 0 :(得分:11)
OAuthAuthorizationServerProvider
是 singleton ,可以为所有请求调用方法。
此类尚未设计为注入。如果要解决一个请求的依赖关系,则必须使用每个方法提供的owinContext手动解析它
public class AuthorizationServerProvider : OAuthAuthorizationServerProvider
{
public override Task GrantAuthorizationCode(
OAuthGrantAuthorizationCodeContext context)
{
IAdfsAuthorizationProvider authorizationProvider =
context.OwinContext
.GetAutofacLifetimeScope()
.Resolve<IAdfsAuthorizationProvider>();
return base.GrantAuthorizationCode(context);
}
}