Microsoft MVP성태의 닷넷 이야기
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 

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





[이 글에 대해서 여러분들과 의견을 공유하고 싶습니다. 틀리거나 미흡한 부분 또는 의문 사항이 있으시면 언제든 댓글 남겨주십시오.]







[최초 등록일: ]
[최종 수정일: 10/26/2022]

Creative Commons License
이 저작물은 크리에이티브 커먼즈 코리아 저작자표시-비영리-변경금지 2.0 대한민국 라이센스에 따라 이용하실 수 있습니다.
by SeongTae Jeong, mailto:techsharer at outlook.com

비밀번호

댓글 작성자
 




... 181  182  183  184  185  186  187  188  [189]  190  191  192  193  194  195  ...
NoWriterDateCnt.TitleFile(s)
265정성태6/1/200625462디버깅 기술: 3. 원격 컴퓨터 디버깅 - VPC 설정
314정성태8/11/200622739    답변글 디버깅 기술: 3.1. Managed 원격 디버깅과 WinDBG 원격 디버깅
264정성태6/1/200631744오류 유형: 6. [VC++ 컴파일] already defined in ntdll.lib(ntdll.dll)
263정성태6/1/200632809디버깅 기술: 2. 커널 구조체 살펴보기 [5]
262정성태6/1/200625299오류 유형: 5. [설치] WinFX Beta2 - 설치시 문제점 해결
261정성태6/1/200621537웹: 3. IIS 6.0 - AppPool을 활용하여 실 서버(운영 서버)에서 디버깅
258정성태6/1/200629473디버깅 기술: 1. 디버깅 방법 - CLR 프로파일러 [1]파일 다운로드1
274정성태6/7/200622519    답변글 디버깅 기술: 1.1. 디버깅 방법 - CLR 프로파일러 ( on Vista )
254정성태6/1/200618851개발 환경 구성: 2. VPC에 Vista 설치하는 방법 [2]
255정성태6/1/200618698    답변글 개발 환경 구성: 2.1. msconfig 설정과 Windows Activation
259정성태6/1/200617641    답변글 개발 환경 구성: 2.2. Vista VPC에 터미널 서비스 - 원격 접속
253정성태6/1/200615804기타: 14. .NET 2.0 이 지원되는 NDoc 2.0 을 배포합니다.
251정성태6/1/200618873오류 유형: 4. [OS 지원 API] SHParseDisplayName과 Windows 2000
252정성태6/1/200618546    답변글 오류 유형: 4.1. NET BCL 에서 제공되는 FolderBrowserDialog [2]
249정성태6/1/200618206.NET Framework: 71. VB.NET 이외의 언어에서 My 네임스페이스 사용
250정성태6/1/200620999    답변글 .NET Framework: 71.1. VB.NET 이외의 언어에서 My 네임스페이스 사용
248정성태6/1/200619294기타: 13. Code Center Premium에서 Win32 API 소스 찾기
245정성태6/1/200626699오류 유형: 3. [C# / VC++] error C2146: syntax error : missing ';' before identifier 'GetType'
247정성태5/3/200623906    답변글 .NET Framework: 3.1. Interface를 사용하면. [1]
242정성태6/1/200624458오류 유형: 2. [COM+] CreateObject 와 HTTP 500 - Internal server error
243정성태6/1/200621844    답변글 오류 유형: 2.1. [COM+] Resolve Partial Assembly failed for Microsoft.VC80.CRT.mui
244정성태6/1/200623287    답변글 오류 유형: 2.2. [COM+] Server object error 'ASP 0178 : 80070005'
240정성태6/1/200621233스크립트: 9. setTimeout 과 jscript/vbscript 혼용 문제
239정성태6/1/200622348COM 개체 관련: 18. Internet Explorer는 Out-of-process COM 개체입니다.
238정성태6/1/200624252개발 환경 구성: 1. batch 파일에서 실행한 exe에서 batch 실행 문맥의 환경 변수 설정 [3]
236정성태6/1/200645007오류 유형: 1. [.NET COM+] UnauthorizedAccessException: 레지스트리 키 HKEY_CLASSES_ROOT\.... 에 대한 액세스가 거부되었습니다
... 181  182  183  184  185  186  187  188  [189]  190  191  192  193  194  195  ...