Gradle을 사용하여 전이적 종속성 제외
Gradle에서 애플리케이션 플러그인을 사용하여 jar 파일을 생성할 때 다음과 같은 전이적 종속성이 발생할 수 있습니다. 제외하고 싶을 수도 있습니다. 이를 달성하기 위해 제외 방법을 사용할 수 있습니다.
Exclude의 기본 동작
처음에는 org.slf4j:slf4j의 모든 인스턴스를 제외하려고 시도했습니다. 다음 코드를 사용하는 log4j12:
configurations { runtime.exclude group: "org.slf4j", name: "slf4j-log4j12" }
그러나 이로 인해 slf4j-api를 포함한 모든 org.slf4j 아티팩트가 제외되었습니다.
사용자 정의 제외
제외를 구체화하려면 그룹 및 모듈 속성을 활용할 수 있습니다.
configurations { runtime.exclude group: "org.slf4j", module: "slf4j-log4j12" }
이 접근 방식은 다른 slf4j에 영향을 주지 않고 org.slf4j:slf4j-log4j12만 성공적으로 제외합니다. 종속성.
개별 종속성에서 제외
특정 종속성을 제외하려는 경우 다음 구문을 사용할 수 있습니다.
dependencies { compile ('org.springframework.data:spring-data-hadoop-core:2.0.0.M4-hadoop22') { exclude group: "org.slf4j", module: "slf4j-log4j12" } }
Exclude 메서드의 제한 사항
제외에 임의의 속성을 지정할 수 있지만 개별 종속성에서 제외하는 경우에는 이것이 허용되지 않는다는 점에 유의하는 것이 중요합니다. 예를 들어, 다음 코드는 실패합니다.
dependencies { compile ('org.springframework.data:spring-data-hadoop-core:2.0.0.M4-hadoop22') { exclude group: "org.slf4j", name: "slf4j-log4j12" } }
다음 오류 메시지와 함께:
No such property: name for class: org.gradle.api.internal.artifacts.DefaultExcludeRule
Understanding Gradle Modules
In Gradle , 모듈 속성은 Maven 이슈 ID에 해당합니다. 따라서 특정 Maven 아티팩트의 모듈을 확인하려면 해당 ArtifactId를 검사하세요. 예를 들어 Maven 아티팩트 org.slf4j:slf4j-log4j12에는 slf4j-log4j12라는 Gradle 모듈이 있습니다.
위 내용은 Gradle에서 특정 전이적 종속성을 제외하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!