msbuild 에러 - error NETSDK1005: Assets file '...\project.assets.json' doesn't have a target for 'net5.0'. Ensure that restore has run and that you have included 'net5.0' in the TargetFrameworks for your project.
Self-Contained/SingleFile 빌드를 테스트하려고,
Self-Contained/SingleFile 유형의 .NET Core/5+ 실행 파일을 임베딩한다면?
; https://www.sysnet.pe.kr/2/0/12733
다음과 같은 구성으로 csproj를 만들고,
<Project Sdk="Microsoft.NET.Sdk">
<PropertyGroup>
<OutputType>Exe</OutputType>
<TargetFramework>net5.0</TargetFramework>
<Nullable>enable</Nullable>
<SelfContained>true</SelfContained>
<IncludeAllContentForSelfExtract>true</IncludeAllContentForSelfExtract>
<PublishSingleFile>true</PublishSingleFile>
<RuntimeIdentifier>win-x64</RuntimeIdentifier>
<RuntimeIdentifiers>win-x64;linux-x64</RuntimeIdentifiers>
</PropertyGroup>
</Project>
이것을 "msbuild"로 빌드했더니 이런 오류가 발생합니다.
C:\temp\ConsoleApp1\ConsoleApp1> msbuild ConsoleApp1.csproj
Microsoft (R) Build Engine version 16.11.2+f32259642 for .NET Framework
Copyright (C) Microsoft Corporation. All rights reserved.
Build started 2022-09-27 오전 10:40:12.
Project "C:\temp\ConsoleApp1\ConsoleApp1\ConsoleApp1.csproj" on node 1 (default targets).
C:\Program Files\dotnet\sdk\6.0.203\Sdks\Microsoft.NET.Sdk\targets\Microsoft.PackageDependencyResolution.targets(267,5): error NETSDK1005: Assets file 'C:\temp\ConsoleApp1\ConsoleApp1\obj\project.assets.json' doesn't have a target for 'net5.0'. Ensure that restore has run and that you have included 'net5.0' in the TargetFrameworks for your project. [C:\temp\ConsoleApp1\ConsoleApp1\ConsoleApp1.csproj]
Done Building Project "C:\temp\ConsoleApp1\ConsoleApp1\ConsoleApp1.csproj" (default targets) -- FAILED.
Build FAILED.
"C:\temp\ConsoleApp1\ConsoleApp1\ConsoleApp1.csproj" (default target) (1) ->
(ResolvePackageAssets target) ->
C:\Program Files\dotnet\sdk\6.0.203\Sdks\Microsoft.NET.Sdk\targets\Microsoft.PackageDependencyResolution.targets(267,5): error NETSDK1005: Assets file 'C:\temp\ConsoleApp1\ConsoleApp1\obj\project.assets.json' doesn't have a target for 'net5.0'. Ensure that restore has run and that you have included 'net5.0' in the TargetFrameworks for your project. [C:\temp\ConsoleApp1\ConsoleApp1\ConsoleApp1.csproj]
반면 동일한 프로젝트를 dotnet build로 하면 잘 됩니다. ^^
C:\temp\ConsoleApp1\ConsoleApp1> dotnet build
MSBuild version 17.3.0-preview-22306-01+1c045cf58 for .NET
Determining projects to restore...
Restored C:\temp\ConsoleApp1\ConsoleApp1\ConsoleApp1.csproj (in 10.67 sec).
C:\Program Files\dotnet\sdk\7.0.100-preview.5.22307.18\Sdks\Microsoft.NET.Sdk\targets\Microsoft.NET.RuntimeIdentifierInference.targets(219,5): message NETSDK1057: You are using a preview version of .NET. See: https://aka.ms/dotnet-support-policy [C:\temp\ConsoleApp1\ConsoleApp1\ConsoleApp1.csproj]
ConsoleApp1 -> C:\temp\ConsoleApp1\ConsoleApp1\bin\Debug\net5.0\win-x64\ConsoleApp1.dll
Build succeeded.
0 Warning(s)
0 Error(s)
(
동일한 오류 메시지가 전에도 있었는데, 이번에는 그것과는 다른 문제입니다. ^^)
그 이유는, dotnet build는 restore를 포함하지만 msbuild는 그렇지 않기 때문입니다. 만약, 굳이 msbuild로 빌드하는 것을 고집한다면, 다음과 같이 restore를 함께 수행하라고 옵션을 추가하면 빌드 오류를 해결할 수 있습니다.
C:\temp\ConsoleApp1\ConsoleApp1> msbuild -restore ConsoleApp1.csproj
...[생략]...
참고로, 한 번 restore가 되었다면 이후로는 그 절차가 필요하지 않습니다. 그래서 dotnet build든, msbuild -restore든 이후로는 그냥 msbuild를 수행해도 잘 됩니다.
만약, 이것을 초기화하고 테스트(?)하고 싶다면
예전 글에서처럼 bin, obj 폴더를 삭제하시면 됩니다. 또한, msbuild에서 배포를 위한 단일 파일을 만들고 싶다면 -target 옵션을 Publish로 설정해 빌드할 수 있습니다.
// "dotnet publish" 명령어의 효과
C:\temp\ConsoleApp1\ConsoleApp1> msbuild -target:Publish -restore ConsoleApp1.csproj
[이 글에 대해서 여러분들과 의견을 공유하고 싶습니다. 틀리거나 미흡한 부분 또는 의문 사항이 있으시면 언제든 댓글 남겨주십시오.]