Я работаю над проектом, который требует зависимости геоинструменты. Раньше я получал следующую ошибку:
Exception in thread "main" java.lang.IllegalStateException: cannot initilize transformation: Authority "EPSG" is unknown or doesn't match the supplied hints. Maybe it is defined in an unreachable JAR file?
at com.test.geometricutils.TransformProjection.initializeTransformer(TransformProjection.java:41)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
at java.lang.reflect.Method.invoke(Method.java:498)
at org.apache.spark.deploy.JavaMainApplication.start(SparkApplication.scala:52)
at org.apache.spark.deploy.SparkSubmit$.org$apache$spark$deploy$SparkSubmit$$runMain(SparkSubmit.scala:879)
at org.apache.spark.deploy.SparkSubmit$.doRunMain$1(SparkSubmit.scala:197)
at org.apache.spark.deploy.SparkSubmit$.submit(SparkSubmit.scala:227)
at org.apache.spark.deploy.SparkSubmit$.main(SparkSubmit.scala:136)
at org.apache.spark.deploy.SparkSubmit.main(SparkSubmit.scala)
Caused by: org.opengis.referencing.NoSuchAuthorityCodeException: Authority "EPSG" is unknown or doesn't match the supplied hints. Maybe it is defined in an unreachable JAR file?
at org.geotools.referencing.factory.ManyAuthoritiesFactory.noSuchAuthority(ManyAuthoritiesFactory.java:488)
at org.geotools.referencing.factory.ManyAuthoritiesFactory.getAuthorityFactory(ManyAuthoritiesFactory.java:466)
at org.geotools.referencing.factory.ManyAuthoritiesFactory.getCRSAuthorityFactory(ManyAuthoritiesFactory.java:547)
at org.geotools.referencing.factory.AuthorityFactoryAdapter.createCoordinateReferenceSystem(AuthorityFactoryAdapter.java:799)
at org.geotools.referencing.factory.ThreadedAuthorityFactory.createCoordinateReferenceSystem(ThreadedAuthorityFactory.java:730)
at org.geotools.referencing.DefaultAuthorityFactory.createCoordinateReferenceSystem(DefaultAuthorityFactory.java:179)
at org.geotools.referencing.CRS.decode(CRS.java:488)
at org.geotools.referencing.CRS.decode(CRS.java:416)
at
что было решено следующей зависимостью:
<dependency>
<groupId>xerces</groupId>
<artifactId>xercesImpl</artifactId>
<version>2.11.0</version>
</dependency>
И проект успешно построен без каких-либо ошибок. Теперь я пытаюсь упаковать свой проект в банку с помощью этой команды:
mvn assembly:assembly -DdescriptorId=jar-with-dependencies
Но я снова получаю то же сообщение об ошибке. Я не знаю, почему он запущен в intellij как проект, но не после выполнения команды package.
Любая помощь или подсказка будут оценены.
да, перед этой командой я использую mvn clean. Мне нужна исполняемая банка проекта scala для spark-submit, поэтому я использую эту команду.




Во-первых, вам понадобится одна из фабрик EPSG (а не xerces), чтобы исправить вашу первую проблему - см. Часто задаваемые вопросы по GeoTools для более подробной информации.
Во-вторых, при сборке толстой (или убер) банки нужно уделять особое внимание файлам управления spi, как описано в Часто задаваемые вопросы по GeoTools.
Вы можете проверить версию своего геоинструмента в репозитории maven. И вы должны убедиться, что все версии geotools подходят, особенно gt-epsg-hsql.
Вы пробовали очистить mvn перед сборкой mvn: assembly -DdescriptorId = jar-with-dependencies? И почему вы используете именно эту цель вместо пакета mvn?