Указанный файл deps.json '$$$' не существует

Я довольно плохо знаком с.NET Core, и у меня есть проект.NET Core WebAPI MyWebApp,
Кроме того, у меня есть.Net Core Class Library проект MyLib с использованием EntityFrameworkCore

Когда я пытаюсь использовать Add-Migration, я получаю сообщение об ошибке
Указанный файл deps.json [...\MyWebApp\bin\Debug\netcoreapp1.1\MyWebApp.deps.json] не существует

Осматривая папку, я заметил, что у меня есть этот файл в [...\MyWebApp\bin\Debug\netcoreapp1.1\win10-x64\MyWebApp.deps.json]

но я действительно не могу понять, что я должен сделать, чтобы решить эту проблему.

myWebApi project.json:

{
  "dependencies": {
  "ShopManager": "1.0.0-*",
  "Microsoft.AspNetCore.StaticFiles": "1.1.0",
  "Microsoft.AspNetCore.Mvc": "1.1.0",
  "Microsoft.AspNetCore.Server.IISIntegration": "1.1.0",
  "Microsoft.AspNetCore.Server.Kestrel": "1.1.0",
  "Microsoft.Extensions.Configuration.EnvironmentVariables": "1.1.0",
  "Microsoft.Extensions.Configuration.FileExtensions": "1.1.0",
  "Microsoft.Extensions.Configuration.Json": "1.1.0",
  "Microsoft.Extensions.Logging": "1.1.0",
  "Microsoft.Extensions.Logging.Console": "1.1.0",
  "Microsoft.Extensions.Logging.Debug": "1.1.0",
  "Microsoft.Extensions.Options.ConfigurationExtensions": "1.1.0",
  "Microsoft.NETCore.App": "1.1.0"
  },

  "tools": {
    "Microsoft.AspNetCore.Server.IISIntegration.Tools": "1.0.0-preview2-final"
  },
  "runtimes": {
    "win10-x64": ""
  },
  "frameworks": {
    "netcoreapp1.1": {
      "imports": [
        "dotnet5.6",
        "portable-net45+win8"
      ]
    }
  },

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

  "runtimeOptions": {
    "configProperties": {
      "System.GC.Server": true
    }
  },

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

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

5 ответов

Решение

runtimes раздел в project.json выглядит подозрительно Как только вы соберете только одну среду выполнения, вам не нужно ее использовать.

Удалить его и переписать зависимость от "Microsoft.NETCore.App":"1.1.0" в "Microsoft.NETCore.App": { "type": "platform", "version": "1.1.0" },

Это изменит модель развертывания вашего приложения с "автономной" (может работать на конкретной платформе даже без фреймворка) на "зависящую от фреймворка" (может работать на любой платформе с установленной фреймворком). Подробности здесь.

У меня была эта проблема с Visual Studio 2017, я скопировал все файлы, включая DLL, из bin\Debug\netcoreapp1.0 в bin\MCD\Debug\netcoreapp1.0

Леса не работали правильно, пока я не скопировал файлы в папку bin. Я не уверен, что делает папка MCD, но по какой-то причине процесс создания леса выглядит в этой папке.

У меня была такая же проблема, и я понял, что это связано с несовместимостью целей сборки в проектах. Вот что исправило для меня:

  1. Удалить все bin а также obj папки
  2. Отредактируйте файлы проекта и файл решения, чтобы обеспечить совпадение целей сборки (например, иметь только debug|x64 а также release|x64 везде)
  3. Повторно открыть визуальную студию и перестроить

Я столкнулся с этим вопросом во время семинара конференции сегодня. После запуска dotnet ef database update -v чтобы получить подробный вывод и тщательно изучить пути, которые там были использованы, я обнаружил, что на моем Mac установлена ​​переменная окружения, которая и вызывала проблему.

Если у вас есть PROJECTDIR установить в вашей среде, dotnet Команда может использовать это для разрешения путей, и если это произойдет, она, скорее всего, сделает это неожиданным образом. Поэтому удалите эту переменную среды из оболочки / среды, в которой вы выполняете работу ядра.Net.

Возникла эта проблема, когда у меня было несколько проектов, хотя я выбрал свой проект Api в качестве проекта по умолчанию в PMC, он все равно не работал. Мне пришлось настроить несколько запускаемых проектов, и это было решено.