Работает ли веб-приложение ASP.NET Core с полной платформой dotnet в IIS?

Я пытаюсь опубликовать приложение ASP.NET Core, разработанное поверх полной структуры (4.6.1) для IIS. В настоящий момент код - это только код базового шаблона, созданный с использованием опции Visual Studio "ASP.NET Core (.NET Framework). Кодекс компилируется отлично, но когда я публикую его в Local IIS, он не запускается. Я получаю ошибку, /p >

Unhandled Exception: System.TypeInitializationException: The type initializer for 'Microsoft.Extensions.PlatformAbstractions.PlatformServices' threw an exception. ---> System.IO.FileNotFoundException: Could not load file or assembly 'System.Reflection.TypeExtensions, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a' or one of its dependencies. The system cannot find the file specified.
   at Microsoft.Extensions.PlatformAbstractions.ApplicationEnvironment.GetEntryAssembly()
   at Microsoft.Extensions.PlatformAbstractions.ApplicationEnvironment..ctor()
   at Microsoft.Extensions.PlatformAbstractions.PlatformServices..ctor()
   at Microsoft.Extensions.PlatformAbstractions.PlatformServices..cctor()
   --- End of inner exception stack trace ---
   at Microsoft.AspNetCore.Hosting.WebHostBuilder.BuildHostingServices()
   at Microsoft.AspNetCore.Hosting.WebHostBuilder.Build()

Мой project.json выглядит следующим образом

    {
  "dependencies": {
    "Microsoft.AspNetCore.Mvc": "1.0.0",
    "Microsoft.AspNetCore.Server.IISIntegration": "1.0.0",
    "Microsoft.AspNetCore.Server.Kestrel": "1.0.0",
    "Microsoft.Extensions.Configuration.EnvironmentVariables": "1.0.0",
    "Microsoft.Extensions.Configuration.FileExtensions": "1.0.0",
    "Microsoft.Extensions.Configuration.Json": "1.0.0",
    "Microsoft.Extensions.Logging": "1.0.0",
    "Microsoft.Extensions.Logging.Console": "1.0.0",
    "Microsoft.Extensions.Logging.Debug": "1.0.0",
    "Microsoft.Extensions.Options.ConfigurationExtensions": "1.0.0"
  },

  "tools": {
    "Microsoft.AspNetCore.Server.IISIntegration.Tools": "1.0.0-preview2-final"
  },

  "frameworks": {
    "net461": { }
  },

  "buildOptions": {
    "emitEntryPoint": true,
    "preserveCompilationContext": true
  },

  "publishOptions": {
    "include": [
      "wwwroot",
      "Views",
      "Areas/**/Views",
      "appsettings.json",
      "web.config"
    ]
  },

  "scripts": {
    "postpublish": [ "dotnet publish-iis --publish-folder %publish:OutputPath% --framework %publish:FullTargetFramework%" ]
  }
}

То же приложение, если оно нацелено на dotnetcore вместо dotnet461, отлично работает. Вся документация MS, похоже, говорит, что этот сценарий возможен и поддерживается. Что-то изменилось в RTM?

Ответ 1

Если вы сначала опубликовали одно таргетинг на приложение netcoreapp1.0, а затем версию net4x, то я думаю, что это ошибка в Web Deploy. Я столкнулся с аналогичной проблемой при публикации в Azure - https://github.com/aspnet/Hosting/issues/801#issuecomment-227920473. Я исправил это, сначала вручную удалив все содержимое целевой папки, а затем снова опубликовывая таргетинг приложения net4x (https://github.com/aspnet/Hosting/issues/801#issuecomment-228123238). Я думаю, что Web Deploy оставляет некоторые DLL позади или не обновляется, если имена совпадают, и они затем подхватываются, но терпят неудачу, потому что они не соответствуют целевой структуре и их зависимости отсутствуют. Я также обнаружил, что проверка флажка в Web Deploy для удаления файлов в месте назначения не устраняет проблему и открыла проблему.