.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
Из предупреждения в вашем лог-файле
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