.net core RC2 с использованием собственного локального пакета Nuget: папка netstandard1.5 содержит неверную версию

Я создаю новую базовую библиотеку классов.net со следующим файлом project.json:

{
  "version": "1.0.0-*",

  "dependencies": {
    "NETStandard.Library": "1.5.0-rc2-24027"
  },

  "frameworks": {
    "netstandard1.5": {
      "imports": "dnxcore50"
    }
  },
  "scripts": {
    "postcompile": [
      "dotnet pack --no-build --configuration %compile:Configuration%"
    ]
  }
}

С помощью "scripts" > "postcompile" я экспортирую пакет nuget для этой библиотеки, который выводит эти файлы и папку:

/netstandard1.5
Solid.Common.Log.1.0.0.nupkg
Solid.Common.Log.1.0.0.symbols.nupkg

После этого шага я копирую эти файлы в свою локальную папку nuget, которую я ранее настраивал в Visual Studio.

А вот файл project.json другого проекта (веб-приложение ядра.net), в который я хочу добавить пакет nuget выше.

{
  "dependencies": {
    "Microsoft.NETCore.App": {
      "version": "1.0.0-rc2-3002702",
      "type": "platform"
    },
    "Microsoft.AspNetCore.Server.IISIntegration": "1.0.0-rc2-final",
    "Microsoft.AspNetCore.Server.Kestrel": "1.0.0-rc2-final",
    "Solid.Common.Log": "1.0.0"
  },

  "tools": {
    "Microsoft.AspNetCore.Server.IISIntegration.Tools": {
      "version": "1.0.0-preview1-final",
      "imports": "portable-net45+win8+dnxcore50"
    }
  },

  "frameworks": {
    "netcoreapp1.0": {
      "imports": [
        "dotnet5.6",
        "dnxcore50",
        "portable-net45+win8"
      ]
    }
  },

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

  "runtimeOptions": {
    "gcServer": true
  },

  "publishOptions": {
    "include": [
      "wwwroot",
      "web.config"
    ]
  },

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

Все выглядит хорошо, но он говорит "Невозможно решить...". Вот вывод:

PATH=.\node_modules\.bin;C:\Program Files (x86)\Microsoft Visual Studio 14.0\Web\External;%PATH%;C:\Program Files (x86)\Microsoft Visual Studio 14.0\Web\External\git
C:\Program Files\dotnet\dotnet.exe restore "D:\Projects\Playground\Solid.Disaster\.vs\restore.dg"
log  : Restoring packages for D:\Projects\Playground\Solid.Disaster\src\Solid.Disaster.Web\project.json...
info :   CACHE https://api.nuget.org/v3-flatcontainer/microsoft.netcore.dotnethostresolver/index.json
info :   CACHE https://api.nuget.org/v3-flatcontainer/microsoft.netcore.dotnethost/index.json
warn : The folder 'D:\Projects\MyNuget\Solid.Common.Log\netstandard1.5' contains an invalid version.
info :   GET https://api.nuget.org/v3-flatcontainer/solid.common.log/index.json
info :   NotFound https://api.nuget.org/v3-flatcontainer/solid.common.log/index.json 923ms
error: Unable to resolve 'Solid.Common.Log (>= 1.0.0)' for '.NETCoreApp,Version=v1.0'.
log  : Restoring packages for tool 'Microsoft.AspNetCore.Server.IISIntegration.Tools' in D:\Projects\Playground\Solid.Disaster\src\Solid.Disaster.Web\project.json...
info : Committing restore...
log  : Writing lock file to disk. Path: D:\Projects\Playground\Solid.Disaster\src\Solid.Disaster.Web\project.lock.json
log  : D:\Projects\Playground\Solid.Disaster\src\Solid.Disaster.Web\Solid.Disaster.Web.xproj
log  : Restore failed in 1670ms.
Errors in D:\Projects\Playground\Solid.Disaster\src\Solid.Disaster.Web\Solid.Disaster.Web.xproj
    Unable to resolve 'Solid.Common.Log (>= 1.0.0)' for '.NETCoreApp,Version=v1.0'.
NuGet Config files used:
    C:\Users\SolidWrist\AppData\Roaming\NuGet\NuGet.Config
    C:\ProgramData\nuget\Config\Microsoft.VisualStudio.Offline.config
Feeds used:
    https://api.nuget.org/v3/index.json
    D:\Projects\MyNuget
    C:\Program Files (x86)\Microsoft SDKs\NuGetPackages\

В чем может быть проблема здесь? Почему он не может разрешить этот пакет nuget?

Если я добавлю проект Solid.Common.Log в веб-проект как существующий проект и буду ссылаться на него, все будет работать нормально. Но когда я пытаюсь добавить его как пакет nuget, я получаю эту ошибку.

Благодарю.

2 ответа

Решение

Вместо перемещения файлов вручную с помощью этой команды решается проблема:

nuget.exe add <nupkg> -Source C:\PathToLocalNuget

https://github.com/NuGet/Home/issues/2955

Из предупреждения в вашем лог-файле

warn : The folder 'D:\Projects\MyNuget\Solid.Common.Log\netstandard1.5' contains an invalid version.

Похоже, вы скопировали все Solid.Common.Log каталог в D:\Projects\MyNuget папка.

Вам нужно скопировать только .nupkg файлы в MyNuget папка, как описано здесь.

D:\Projects\MyNuget\Solid.Common.Log.1.0.0.nupkg

В качестве альтернативы, если вы хотите, вы можете использовать новый более быстрый альтернативный макет для NuGet 3.3, но он требует немного больше работы: http://blog.nuget.org/20150922/Accelerate-Package-Source.html.

Вместо того, чтобы копировать dll, запустите командлет PowerShell:

Publish-Package "c:\path\to\Solid.Common.Log.1.0.0.nupkg" -PackageSource "D:\Projects\MyNuget"

Который будет производить структуру папок, похожую на

D:\Projects\MyNuget
    Solid.Common.Log\
        1.0.0\
            Solid.Common.Log.1.0.0.nupkg
            Solid.Common.Log.nuspec
            Solid.Common.Log.1.0.0.nupkg.sha512
Другие вопросы по тегам