我有一个Owin中间件身份验证项目,它作为IIS 7.5中的Web应用程序部署,但问题是没有调用Startup.cs。
[assembly: OwinStartup(typeof(Authorization.Startup))]
namespace Authorization
{
public partial class Startup
{
public void Configuration(IAppBuilder app)
{
//Logger.Write(string.Format("Authorizations->frist Configuration "), LoggingCategoryNames.PRESENTATION_LAYER_LOGGING_CATEGORY);
ConfigureAuth(app);
}
}
}
此代码未执行。当我们将其部署为根网站时,一切正常。
因此,我们在哪里出错了,可以做些什么来使其工作。我们不能将身份验证项目部署为单独的网站,它只能是一个Web应用程序。
谢谢
我发现了类似的东西。我的Configuration
方法正在运行,但是作为子Web应用程序托管时,身份验证中间件(在本例中为OpenIdConnect)似乎未在Owin管道中执行。作为根网站托管时,它运行良好。
在深入研究调试管道本身之前,我尝试了一些使用其他令牌服务(ADFS用于)的问题。可以肯定的是,它就是其中之一。
旧的斜杠问题。
客户端应用程序中的我的OpenIdConnect配置看起来像以前一样
app.UseOpenIdConnectAuthentication(new OpenIdConnectAuthenticationOptions
{
Authority = "https://idserver/identity",
ClientId = "Client",
RedirectUri = "https://clients/mvcclientapp"
...
});
客户端只是不处理传入令牌。中间件似乎根本不在管道中执行。
我在RedirectUrl的末尾添加了一个额外的“ /”,它开始起作用。
app.UseOpenIdConnectAuthentication(new OpenIdConnectAuthenticationOptions
{
Authority = "https://idserver/identity",
ClientId = "Client",
RedirectUri = "https://clients/mvcclientapp/"
...
});
当作为根网站托管在IIS中时,这不是必需的。
本文收集自互联网,转载请注明来源。
如有侵权,请联系[email protected] 删除。
我来说两句