我有OwinStartup配置代码完美地工作,然后它停止工作。不幸的是,我不确定我到底做了什么来让它停止工作,我有一个非常困难的时间来弄清楚。

为了确保我掌握了基本知识,我反复检查以确保我掌握了

[assembly:OwinStartup(typeof(WebApplication.Startup))] 

属性正确分配,并确保我没有一个appSetting为owin:AutomaticAppStartup,设置为false,所以我做了一个设置为true,以确保安全,因为之前没有什么。

<add key="owin:AutomaticAppStartup" value="true" />

我还尝试特别调用appSetting:

<add key="owin:appStartup" value="WebApplication.Startup" />

在它停止工作之前,我将microsoft . owen . security NuGet包升级到2.0.2,所以我尝试将它们恢复到2.0.1(这很痛苦),但它没有改变任何东西。我在项目上安装了WebActivator,并使用它来引导其他东西,但我已经在一个新的WebApplication模板上进行了测试,它在那里工作,所以我不认为这是罪魁祸首。

我还尝试删除我的启动类,并使用Visual Studio在添加新项目中使用OWIN启动类类型添加一个新的,并且也没有被调用。接下来,我尝试添加第二个Startup类,因为我知道如果定义了多个OwinStartup属性,它将抛出异常,但它没有抛出任何异常。

不知道还能试什么。任何想法吗?

更新

原来Resharper删除了对Microsoft.Owin.Host.SystemWeb的引用,当我使用它删除未使用的引用时。


当前回答

对我来说,这是因为它们不在同一个命名空间中。在我删除我的AppStart从“项目。启动。并让它们同时包含Startup.cs和Startup.Auth.cs和project. auth。“Startup”命名空间,一切都恢复了正常。

我希望它能有所帮助!

其他回答

在这篇文章中,我把很多建议都搞砸了。

我有以下,但仍然不能降落在断点。抛出异常证明正在输入代码。

<appSettings>
...
  <add key="owin:AutomaticAppStartup" value="true" />
  <add key="owin:appStartup" value="SSOResource.Startup, SSOResource" />
...
</appSettings>

最后出于绝望,我看了project->属性,然后在WEB部分下,我还检查了NATIVE CODE复选框(ASP。NET应该已经检查过了)。

这终于帮我解决了问题。

注意:我使用的是Visual Studio 2017 Professional。

在将类库转换为Web应用程序项目后,我遇到了这个问题,并变得固执起来。结果,在我的.csProj文件中,我有这样的:

<PropertyGroup Condition=" '$(Configuration)|$(Platform)' == 'Debug|AnyCPU' ">
  <DebugSymbols>true</DebugSymbols>
  <DebugType>full</DebugType>
  <Optimize>false</Optimize>
  <OutputPath>bin\Debug\</OutputPath>
  <DefineConstants>DEBUG;TRACE</DefineConstants>
  <ErrorReport>prompt</ErrorReport>
  <WarningLevel>4</WarningLevel>
</PropertyGroup>
<PropertyGroup Condition=" '$(Configuration)|$(Platform)' == 'Release|AnyCPU' ">
  <DebugType>pdbonly</DebugType>
  <Optimize>true</Optimize>
  <OutputPath>bin\Release\</OutputPath>
  <DefineConstants>TRACE</DefineConstants>
  <ErrorReport>prompt</ErrorReport>
  <WarningLevel>4</WarningLevel>
</PropertyGroup>

因此,将各种dll构建到bin文件夹的子文件夹中(ifc。不会工作)。解决方案是将OutputPath的文本内容都更改为bin\。

我有一个类似的问题,这和清算临时ASP。NET Files修复了它。希望这能帮助到一些人。

我不确定这是否还能帮助别人,但我已经做了上面所有的解决方案(以及其他一些帖子),但都无济于事。

什么固定的问题在我的结束是把一个反斜杠的RedirectUri值在web的结束。config(很疯狂,我知道!)RedirectUri是UseOpenIdConnectAuthentication中的参数。

所以,与其:

<add key="ida:RedirectUri" value="https://www.bogussite.com/home" />

这样做:

<add key="ida:RedirectUri" value="https://www.bogussite.com/home/" />

并更新了Azure应用程序设置上的回复URL。

这以某种方式使Startup按预期运行(可能清除了一些缓存),并且现在触发了断点。

仅供参考。我从这里建模代码:https://github.com/microsoftgraph/aspnet-connect-sample

如果您在调试Startup类中的代码时遇到了麻烦,那么我也遇到了这个问题——或者我认为我遇到了这个问题。代码正在触发,但我相信它发生在调试器附加之前,所以你不能在代码上设置断点,看看发生了什么。

您可以通过在Startup类的Configuration方法中抛出异常来证明这一点。