Еще один из них - MapBox
. В их видеоролике было показано, что в качестве пользователя показано четыре пользователя.
Я хочу, чтобы jar находился в директории 3rdparty в исходном элементе управления и ссылался на него по относительному пути из файла pom.xml.
blockquote>Если вы действительно этого хотите (понимаете, если вы не можете использовать корпоративный репозиторий), то мой совет будет заключаться в использовании «репозитория файлов», который является локальным для проекта, и не использовать зависимую область
system
. Следует избегать областиsystem
, такие зависимости не работают хорошо во многих ситуациях (например, в сборке), они вызывают больше проблем, чем преимуществ.Итак, вместо этого, объявите репозиторий локальным для проекта:
<repositories> <repository> <id>my-local-repo</id> <url>file://${basedir}/my-repo</url> </repository> </repositories>
Установите свою стороннюю библиотеку там, используя
install:install-file
с помощьюlocalRepositoryPath
:
mvn install:install-file -Dfile=<path-to-file> -DgroupId=<myGroup> \ -DartifactId=<myArtifactId> -Dversion=<myVersion> \ -Dpackaging=<myPackaging> -DlocalRepositoryPath=<path>
Обновление: Похоже, что
install:install-file
игнорируетlocalRepositoryPath
при использовании версии 2.2 плагина. Однако он работает с версией 2.3 и более поздними версиями плагина. Поэтому используйте полное имя плагина для указания версии:mvn org.apache.maven.plugins:maven-install-plugin:2.3.1:install-file \ -Dfile=<path-to-file> -DgroupId=<myGroup> \ -DartifactId=<myArtifactId> -Dversion=<myVersion> \ -Dpackaging=<myPackaging> -DlocalRepositoryPath=<path>
Документация maven-install-plugin
Наконец, объявите ее как любой другая зависимость (но без области
system
):<dependency> <groupId>your.group.id</groupId> <artifactId>3rdparty</artifactId> <version>X.Y.Z</version> </dependency>
Это ИМХО лучшее решение, чем использование области
system
, поскольку ваша зависимость будет рассматриваться как хороший гражданин (например, это будет включены в сборку и т. д.).Теперь я должен упомянуть, что «правильный путь» для решения этой ситуации в корпоративной среде (возможно, не так) должен был бы использовать корпоративный репозиторий.
Одно небольшое дополнение к решению, отправленное Pascal
Когда я следил за этим маршрутом, я получил ошибку в maven при установке ojdbc jar.
[INFO] --- maven-install-plugin:2.5.1:install-file (default-cli) @ validator ---
[INFO] pom.xml not found in ojdbc14.jar
После добавления -DpomFile , проблема была решена.
$ mvn install:install-file -Dfile=./lib/ojdbc14.jar -DgroupId=ojdbc \
-DartifactId=ojdbc -Dversion=14 -Dpackaging=jar -DlocalRepositoryPath=./repo \
-DpomFile=~/.m2/repository/ojdbc/ojdbc/14/ojdbc-14.pom
мы перешли на граду, и это работает намного лучше в градуировке;). мы просто указываем папку, в которую мы можем поместить банки для временных ситуаций. У нас все еще есть большинство наших банок, которые определяют типичный раздел управления зависимостями (т. Е. Тот же, что и maven). Это еще одна зависимость, которую мы определяем.
, поэтому в основном теперь мы можем просто отбросить любую банку, которую мы хотим, в наш каталог lib для временного тестирования, если он где-то не находится в репозитории maven.
В принципе, добавьте это в pom.xml:
...
<repositories>
<repository>
<id>lib_id</id>
<url>file://${project.basedir}/lib</url>
</repository>
</repositories>
...
<dependencies>
...
<dependency>
<groupId>com.mylibrary</groupId>
<artifactId>mylibraryname</artifactId>
<version>1.0.0</version>
</dependency>
...
</dependencies>
Я ранее написал о шаблоне для этого.
Он очень похож на решение, предложенное Pascal, хотя он перемещает все такие зависимости в выделенный репозиторий модуль, чтобы вам не пришлось повторять его везде, где используется зависимость, если это сборка с несколькими модулями.
Использование области system
. ${basedir}
- это каталог вашего pom.
<dependency>
<artifactId>..</artifactId>
<groupId>..</groupId>
<scope>system</scope>
<systemPath>${basedir}/lib/dependency.jar</systemPath>
</dependency>
Однако рекомендуется установить вашу банку в репозиторий, а не передавать ее SCM - после этого все, что maven пытается устранить.
Это работает для меня: предположим, что у меня есть эта зависимость
<dependency>
<groupId>com.company.app</groupId>
<artifactId>my-library</artifactId>
<version>1.0</version>
<scope>system</scope>
<systemPath>${project.basedir}/lib/my-library.jar</systemPath>
</dependency>
Затем добавьте путь к вашей системной зависимости вручную, как это
<Class-Path>libs/my-library-1.0.jar</Class-Path>
Full config:
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-jar-plugin</artifactId>
<version>2.4</version>
<configuration>
<archive>
<manifestEntries>
<Build-Jdk>${jdk.version}</Build-Jdk>
<Implementation-Title>${project.name}</Implementation-Title>
<Implementation-Version>${project.version}</Implementation-Version>
<Specification-Title>${project.name} Library</Specification-Title>
<Specification-Version>${project.version}</Specification-Version>
<Class-Path>libs/my-library-1.0.jar</Class-Path>
</manifestEntries>
<manifest>
<addClasspath>true</addClasspath>
<mainClass>com.company.app.MainClass</mainClass>
<classpathPrefix>libs/</classpathPrefix>
</manifest>
</archive>
</configuration>
</plugin>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-dependency-plugin</artifactId>
<version>2.5.1</version>
<executions>
<execution>
<id>copy-dependencies</id>
<phase>package</phase>
<goals>
<goal>copy-dependencies</goal>
</goals>
<configuration>
<outputDirectory>${project.build.directory}/libs/</outputDirectory>
</configuration>
</execution>
</executions>
</plugin>
Вы можете использовать eclipse для создания исполняемого файла Jar: Export / Runnable Jar
localRepositoryPath
... – Jake 27 May 2010 в 02:32basedir/./my-local-repo
с помощью одного.
. – Brian 13 September 2013 в 07:29