Por que estou recebendo o erro "401 Unauthorized" no Maven?
Este é o erro que recebo ao chamar mvn deploy
(registros completos na parte inferior):
[INFO] BUILD FAILURE
[ERROR] Failed to execute goal org.apache.maven.plugins:maven-deploy-plugin:2.7:deploy (default-deploy) on project xbnjava: Failed to deploy artifacts: Could not transfer artifact com.github.aliteralmind:xbnjava:pom:0.1.2 from/to sonatype-nexus-staging (https://oss.sonatype.org/service/local/staging/deploy/maven2/): Failed to transfer file: https://oss.sonatype.org/service/local/staging/deploy/maven2/com/github/aliteralmind/xbnjava/0.1.2/xbnjava-0.1.2.pom. Return code is: 401, ReasonPhrase: Unauthorized. -> [Help 1]
De acordo com esta página de suporte de tipo de som :
"Se você está recebendo um 401 é porque o maven está enviando as credenciais de login erradas ou nenhuma credencial."
Abaixo estão as etapas que tomei, abaixo estão meus arquivos settings.xml
e completos pom.xml
, e abaixo estão os logs completos de mvn deploy
e mvn deploy -e
.
Todas as idéias seriam apreciadas. Estou batendo em uma parede após a outra com Maven.
Segui a lista de verificação da sonatype ao receber um erro 401:
Item 1 da lista de verificação . Certifique-se de que seu nome de usuário / senha está correto fazendo login na interface do usuário do Nexus. Se curl estiver instalado em sua máquina, você pode tentar implantar um artefato com ...
- Eu entrei e saí com sucesso do site sonatype.org, usando o usuário / pass in
settings.xml
. - I tentativa de usar
curl
para implantar manualmente um artefato, com o comando
[C:\]curl -u MY_SONATYPE_DOT_COM_USERNAME:MY_SONATYPE_DOT_COM_PASSWORD https://oss.sonatype.org/content/repositories/snapshots/com/github/aliteralmind/xbnjava/0.1.2-SNAPSHOT/xbnjava-0.1.2-20140716.224928-1.pom --request PUT --data @pom.xml
mas tenho este erro:
Warning: Couldn't read data from file "pom.xml", this makes an empty POST.
curl: (60) SSL certificate problem, verify that the CA cert is OK. Details:
error:14090086:SSL routines:SSL3_GET_SERVER_CERTIFICATE:certificate verify failed
More details here: http://curl.haxx.se/docs/sslcerts.html
curl performs SSL certificate verification by default, using a "bundle"
of Certificate Authority (CA) public keys (CA certs). If the default
bundle file isn't adequate, you can specify an alternate file
using the --cacert option.
If this HTTPS server uses a certificate signed by a CA represented in
the bundle, the certificate verification probably failed due to a
problem with the certificate (it might be expired, or the name might
not match the domain name in the URL).
If you'd like to turn off curl's verification of the certificate, use
the -k (or --insecure) option.
Eu executei novamente com a -k
opção, e desta vez consegui apenas esta:
Couldn't read data from file "pom.xml", this makes an empty POST.
Nunca usei o curl antes, então não sei o que fazer com essa informação.
Item 2 da lista de verificação . Se não houver saída de erro, certifique-se de que seus privilégios de usuário estejam configurados corretamente no servidor. Certifique-se de descartar o repositório que você acabou de criar.
Não sei o que significa "cair". Acredito que meus privilégios estejam instalados corretamente, pois recebi esta mensagem do sonatype:
- A configuração foi preparada, agora você pode:
- Implante artefatos de instantâneo no repositório https://oss.sonatype.org/content/repositories/snapshots
- Implante artefatos de lançamento no repositório de teste https://oss.sonatype.org/service/local/staging/deploy/maven2
- Promova artefatos encenados em 'Releases' do repositório
- Baixe o instantâneo e libere artefatos do grupo https://oss.sonatype.org/content/groups/public
- Baixe instantâneo, libere e artefatos de teste do grupo de teste https://oss.sonatype.org/content/groups/staging
e coloquei com sucesso esses itens no servidor via mvn deploy
nos últimos dias.
As configurações do projeto:
Item 3 da lista de verificação . Certifique-se de ter configurado um servidor
settings.xml
e de que o id do servidor seja idêntico ao id do repositório de distribuição em pom.xml.
- Em
settings.xml
configurações / servidores / servidor / id é igual aossrh
- Em
pom.xml
, DistributionManagement / snapshotRepository / id equalsossrh
(os arquivos completos estão na parte inferior)
Item 4 da lista de verificação . Certifique-se de que seu settings.xml esteja no lugar correto (normalmente é _ ~ / .m2 / settings.xml). Você pode verificar isso executando mvn help: effective-settings.
De acordo com a referência de configurações do Maven , settings.xml deve estar em um dos dois locais:
- A instalação do Maven:
$M2_HOME/conf/settings.xml
- Instalação de um usuário:
${user.home}/.m2/settings.xml
Esta é minha configuração:
settings.xml
:C:\applications\programming\apache-maven-3.2.2\conf\settings.xml
M2_HOME
éC:\applications\programming\apache-maven-3.2.2
Saída para mvn help:effective-settings
:
[C:\applications\utilities\curl]
[INFO] Scanning for projects...
[INFO]
[INFO] ------------------------------------------------------------------------
[INFO] Building Maven Stub Project (No POM) 1
[INFO] ------------------------------------------------------------------------
[INFO]
[INFO] --- maven-help-plugin:2.2:effective-settings (default-cli) @ standalone-pom ---
[INFO]
Effective user-specific configuration settings:
<?xml version="1.0" encoding="UTF-8"?>
<!-- ====================================================================== -->
<!-- -->
<!-- Generated by Maven Help Plugin on 2014-07-18T12:48:19 -->
<!-- See: http://maven.apache.org/plugins/maven-help-plugin/ -->
<!-- -->
<!-- ====================================================================== -->
<!-- ====================================================================== -->
<!-- -->
<!-- Effective Settings for 'jeffy' on 'kermit-the-frog' -->
<!-- -->
<!-- ====================================================================== -->
<settings xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:sc
hemaLocation="http://maven.apache.org/SETTINGS/1.1.0 http://maven.apache.org/xsd/settings-1.1.0.xsd">
<localRepository xmlns="http://maven.apache.org/SETTINGS/1.1.0">C:\Users\jeffy\.m2\repository</localRepository
>
<servers xmlns="http://maven.apache.org/SETTINGS/1.1.0">
<server>
<username>MY_SONATYPE_DOT_COM_USERNAME</username>
<password>***</password>
<id>ossrh</id>
</server>
</servers>
<pluginGroups xmlns="http://maven.apache.org/SETTINGS/1.1.0">
<pluginGroup>org.apache.maven.plugins</pluginGroup>
<pluginGroup>org.codehaus.mojo</pluginGroup>
</pluginGroups>
</settings>
[INFO] ------------------------------------------------------------------------
[INFO] BUILD SUCCESS
[INFO] ------------------------------------------------------------------------
[INFO] Total time: 2.310 s
[INFO] Finished at: 2014-07-18T12:48:19-04:00
[INFO] Final Memory: 7M/17M
[INFO] ------------------------------------------------------------------------
Item 5 da lista de verificação . Se o servidor estiver usando https, mas a URL em seu POM for http, você poderá obter 401 também.
Não entendo a qual URL ele está se referindo.
Item 6 da lista de verificação . Use a versão mais recente do Maven, pois há um problema conhecido em relação ao 401: MNG-4469
Estou usando a versão mais recente:
[C:\]mvn -version
Apache Maven 3.2.2 (45f7c06d68e745d05611f7fd14efb6594181933e; 2014-06-17T09:51:42-04:00)
Maven home: C:\applications\programming\apache-maven-3.2.2
Java version: 1.7.0_51, vendor: Oracle Corporation
Java home: C:\applications\programming\jdk_7_51\jre
Default locale: en_US, platform encoding: Cp1252
OS name: "windows 7", version: "6.1", arch: "x86", family: "windows"
------------------
Completo settings.xml
e pom.xml
arquivos
(Registros completos para mvn deploy
e mvn deploy -e
abaixo)
settings.xml
:
<?xml version="1.0" encoding="UTF-8"?>
<settings xmlns="http://maven.apache.org/SETTINGS/1.0.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/SETTINGS/1.0.0 http://maven.apache.org/xsd/settings-1.0.0.xsd">
<servers>
<server>
<id>ossrh</id>
<username>MY_SONATYPE_DOT_COM_USERNAME</username>
<password>MY_SONATYPE_DOT_COM_PASSWORD</password>
</server>
</servers>
<pluginGroups></pluginGroups>
<proxies></proxies>
<mirrors></mirrors>
<profiles></profiles>
</settings>
pom.xml:
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/maven-v4_0_0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>com.github.aliteralmind</groupId>
<artifactId>xbnjava</artifactId>
<packaging>pom</packaging>
<version>0.1.2</version>
<name>XBN-Java</name>
<url>https://github.com/aliteralmind/xbnjava</url>
<inceptionYear>2014</inceptionYear>
<organization>
<name>Jeff Epstein</name>
</organization>
<description>XBN-Java is a collection of generically-useful backend (server side, non-GUI) programming utilities, featuring RegexReplacer and FilteredLineIterator. XBN-Java is the foundation of Codelet (http://codelet.aliteralmind.com).</description>
<parent>
<groupId>org.sonatype.oss</groupId>
<artifactId>oss-parent</artifactId>
<version>7</version>
</parent>
<licenses>
<license>
<name>Lesser General Public License (LGPL) version 3.0</name>
<url>https://www.gnu.org/licenses/lgpl-3.0.txt</url>
</license>
<license>
<name>Apache Software License (ASL) version 2.0</name>
<url>http://www.apache.org/licenses/LICENSE-2.0.txt</url>
</license>
</licenses>
<developers>
<developer>
<name>Jeff Epstein</name>
<email>[email protected]</email>
<roles>
<role>Lead Developer</role>
</roles>
</developer>
</developers>
<issueManagement>
<system>GitHub Issue Tracker</system>
<url>https://github.com/aliteralmind/xbnjava/issues</url>
</issueManagement>
<distributionManagement>
<snapshotRepository>
<id>ossrh</id>
<url>https://oss.sonatype.org/content/repositories/snapshots</url>
</snapshotRepository>
</distributionManagement>
<scm>
<connection>scm:git:[email protected]:aliteralmind/xbnjava.git</connection>
<url>scm:git:[email protected]:aliteralmind/xbnjava.git</url>
<developerConnection>scm:git:[email protected]:aliteralmind/xbnjava.git</developerConnection>
</scm>
<properties>
<java.version>1.7</java.version>
<jarprefix>R:\jeffy\programming\build\/${project.artifactId}-${project.version}/download/${project.artifactId}-${project.version}</jarprefix>
</properties>
<!--
<profiles>
<profile>
<id>default-tools.jar</id>
<activation>
<property>
<name>java.vendor</name>
<value>Sun Microsystems Inc.</value>
</property>
</activation>
<dependencies>
<dependency>
<groupId>com.sun</groupId>
<artifactId>tools</artifactId>
<version>1.4.2</version>
<scope>system</scope>
<systemPath>${java.home}/../lib/tools.jar</systemPath>
</dependency>
</dependencies>
</profile>
</profiles>
-->
<build>
<plugins>
<plugin>
<groupId>org.codehaus.mojo</groupId>
<artifactId>build-helper-maven-plugin</artifactId>
<version>1.8</version>
<executions>
<execution>
<id>attach-artifacts</id>
<phase>package</phase>
<goals>
<goal>attach-artifact</goal>
</goals>
<configuration>
<artifacts>
<artifact>
<file>${jarprefix}-all.jar</file>
<type>jar</type>
</artifact>
</artifacts>
</configuration>
</execution>
</executions>
</plugin>
</plugins>
</build>
<profiles>
<!--
This profile will sign the JAR file, sources file, and javadocs file using the GPG key on the local machine.
See: https://docs.sonatype.org/display/Repository/How+To+Generate+PGP+Signatures+With+Maven
-->
<profile>
<id>release-sign-artifacts</id>
<activation>
<property>
<name>release</name>
<value>true</value>
</property>
</activation>
</profile>
</profiles>
</project>
------------------
Registros completos para mvn deploy
emvn deploy -e
mvn deploy
resultado:
[INFO] Scanning for projects...
[INFO] ------------------------------------------------------------------------
[INFO] Building XBN-Java 0.1.2
[INFO] ------------------------------------------------------------------------
[INFO] --- maven-enforcer-plugin:1.0:enforce (enforce-maven) @ xbnjava ---
[INFO] --- build-helper-maven-plugin:1.8:attach-artifact (attach-artifacts) @ xbnjava ---
[INFO] --- maven-install-plugin:2.4:install (default-install) @ xbnjava ---
[INFO] Installing R:\jeffy\programming\sandbox\z__for_git_commit_only\xbnjava\pom.xml to C:\Users\jeffy\.m2\repository\com\github\aliteralmind\xbnjava\0.1.2\xbnjava-0.1.2.pom
[INFO] Installing R:\jeffy\programming\build\xbnjava-0.1.2\download\xbnjava-0.1.2-all.jar to C:\Users\jeffy\.m2\repository\com\github\aliteralmind\xbnjava\0.1.2\xbnjava-0.1.2.jar
[INFO] --- maven-deploy-plugin:2.7:deploy (default-deploy) @ xbnjava ---
Uploading: https://oss.sonatype.org/service/local/staging/deploy/maven2/com/github/aliteralmind/xbnjava/0.1.2/xbnjava-0.1.2.pom
2/6 KB
4/6 KB
6/6 KB
(Seção de falha :)
[INFO] ------------------------------------------------------------------------
[INFO] BUILD FAILURE
[INFO] ------------------------------------------------------------------------
[INFO] Total time: 3.204 s
[INFO] Finished at: 2014-07-18T11:25:17-04:00
[INFO] Final Memory: 7M/17M
[INFO] ------------------------------------------------------------------------
[ERROR] Failed to execute goal org.apache.maven.plugins:maven-deploy-plugin:2.7:deploy (default-deploy) on project xbnjava: Failed to deploy artifacts: Could not transfer artifact com.github.aliteralmind:xbnjava:pom:0.1.2 from/to sonatype-nexus-staging (https://oss.sonatype.org/service/local/staging/deploy/maven2/): Failed to transfer file: https://oss.sonatype.org/service/local/staging/deploy/maven2/com/github/aliteralmind/xbnjava/0.1.2/xbnjava-0.1.2.pom. Return code is: 401, ReasonPhrase: Unauthorized. -> [Help 1]
[ERROR]
[ERROR] To see the full stack trace of the errors, re-run Maven with the -e switch.
[ERROR] Re-run Maven using the -X switch to enable full debug logging.
[ERROR]
[ERROR] For more information about the errors and possible solutions, please read the following articles:
[ERROR] [Help 1] http://cwiki.apache.org/confluence/display/MAVEN/MojoExecutionException
mvn deploy -e
resultado:
[INFO] Error stacktraces are turned on.
[INFO] Scanning for projects...
[INFO] ------------------------------------------------------------------------
[INFO] Building XBN-Java 0.1.2
[INFO] ------------------------------------------------------------------------
[INFO] --- maven-enforcer-plugin:1.0:enforce (enforce-maven) @ xbnjava ---
[INFO] --- build-helper-maven-plugin:1.8:attach-artifact (attach-artifacts) @ xbnjava ---
[INFO] --- maven-install-plugin:2.4:install (default-install) @ xbnjava ---
[INFO] Installing R:\jeffy\programming\sandbox\z__for_git_commit_only\xbnjava\pom.xml to C:\Users\jeffy\.m2\repository\com\github\aliteralmind\xbnjava\0.1.2\xbnjava-0.1.2.pom
[INFO] Installing R:\jeffy\programming\build\xbnjava-0.1.2\download\xbnjava-0.1.2-all.jar to C:\Users\jeffy\.m2\repository\com\github\aliteralmind\xbnjava\0.1.2\xbnjava-0.1.2.jar
[INFO] --- maven-deploy-plugin:2.7:deploy (default-deploy) @ xbnjava ---
Uploading: https://oss.sonatype.org/service/local/staging/deploy/maven2/com/github/aliteralmind/xbnjava/0.1.2/xbnjava-0.1.2.pom
2/6 KB
4/6 KB
6/6 KB
(Seção de falha :)
[INFO] ------------------------------------------------------------------------
[INFO] BUILD FAILURE
[INFO] ------------------------------------------------------------------------
[INFO] Total time: 3.492 s
[INFO] Finished at: 2014-07-18T11:25:37-04:00
[INFO] Final Memory: 7M/17M
[INFO] ------------------------------------------------------------------------
[ERROR] Failed to execute goal org.apache.maven.plugins:maven-deploy-plugin:2.7:deploy (default-deploy) on project xbnjava: Failed to deploy artifacts: Could not transfer artifact com.github.aliteralmind:xbnjava:pom:0.1.2 from/to sonatype-nexus-staging (https://oss.sonatype.org/service/local/staging/deploy/maven2/): Failed to transfer file: https://oss.sonatype.org/service/local/staging/deploy/maven2/com/github/aliteralmind/xbnjava/0.1.2/xbnjava-0.1.2.pom. Return code is: 401, ReasonPhrase: Unauthorized. -> [Help 1]
org.apache.maven.lifecycle.LifecycleExecutionException: Failed to execute goal org.apache.maven.plugins:maven-deploy-plugin:2.7:deploy (default-deploy) on project xbnjava: Failed to deploy artifacts: Could not transfer artifact com.github.aliteralmind:xbnjava:pom:0.1.2 from/to sonatype-nexus-staging (https://oss.sonatype.org/service/local/staging/deploy/maven2/): Failed to transfer file: https://oss.sonatype.org/service/local/staging/deploy/maven2/com/github/aliteralmind/xbnjava/0.1.2/xbnjava-0.1.2.pom. Return code is: 401, ReasonPhrase: Unauthorized.
at org.apache.maven.lifecycle.internal.MojoExecutor.execute(MojoExecutor.java:216)
at org.apache.maven.lifecycle.internal.MojoExecutor.execute(MojoExecutor.java:153)
at org.apache.maven.lifecycle.internal.MojoExecutor.execute(MojoExecutor.java:145)
at org.apache.maven.lifecycle.internal.LifecycleModuleBuilder.buildProject(LifecycleModuleBuilder.java:116)
at org.apache.maven.lifecycle.internal.LifecycleModuleBuilder.buildProject(LifecycleModuleBuilder.java:80)
at org.apache.maven.lifecycle.internal.builder.singlethreaded.SingleThreadedBuilder.build(SingleThreadedBuilder.java:51)
at org.apache.maven.lifecycle.internal.LifecycleStarter.execute(LifecycleStarter.java:120)
at org.apache.maven.DefaultMaven.doExecute(DefaultMaven.java:347)
at org.apache.maven.DefaultMaven.execute(DefaultMaven.java:154)
at org.apache.maven.cli.MavenCli.execute(MavenCli.java:584)
at org.apache.maven.cli.MavenCli.doMain(MavenCli.java:213)
at org.apache.maven.cli.MavenCli.main(MavenCli.java:157)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
at java.lang.reflect.Method.invoke(Method.java:606)
at org.codehaus.plexus.classworlds.launcher.Launcher.launchEnhanced(Launcher.java:289)
at org.codehaus.plexus.classworlds.launcher.Launcher.launch(Launcher.java:229)
at org.codehaus.plexus.classworlds.launcher.Launcher.mainWithExitCode(Launcher.java:415)
at org.codehaus.plexus.classworlds.launcher.Launcher.main(Launcher.java:356)
Caused by: org.apache.maven.plugin.MojoExecutionException: Failed to deploy artifacts: Could not transfer artifact com.github.aliteralmind:xbnjava:pom:0.1.2 from/to sonatype-nexus-staging (https://oss.sonatype.org/service/local/staging/deploy/maven2/): Failed to transfer file: https://oss.sonatype.org/service/local/staging/deploy/maven2/com/github/aliteralmind/xbnjava/0.1.2/xbnjava-0.1.2.pom. Return code is: 401, ReasonPhrase: Unauthorized.
at org.apache.maven.plugin.deploy.DeployMojo.execute(DeployMojo.java:193)
at org.apache.maven.plugin.DefaultBuildPluginManager.executeMojo(DefaultBuildPluginManager.java:132)
at org.apache.maven.lifecycle.internal.MojoExecutor.execute(MojoExecutor.java:208)
... 19 more
Caused by: org.apache.maven.artifact.deployer.ArtifactDeploymentException: Failed to deploy artifacts: Could not transfer artifact com.github.aliteralmind:xbnjava:pom:0.1.2 from/to sonatype-nexus-staging (https://oss.sonatype.org/service/local/staging/deploy/maven2/): Failed to transfer file: https://oss.sonatype.org/service/local/staging/deploy/maven2/com/github/aliteralmind/xbnjava/0.1.2/xbnjava-0.1.2.pom. Return code is: 401, ReasonPhrase: Unauthorized.
at org.apache.maven.artifact.deployer.DefaultArtifactDeployer.deploy(DefaultArtifactDeployer.java:143)
at org.apache.maven.plugin.deploy.AbstractDeployMojo.deploy(AbstractDeployMojo.java:167)
at org.apache.maven.plugin.deploy.DeployMojo.execute(DeployMojo.java:149)
... 21 more
Caused by: org.eclipse.aether.deployment.DeploymentException: Failed to deploy artifacts: Could not transfer artifact com.github.aliteralmind:xbnjava:pom:0.1.2 from/to sonatype-nexus-staging (https://oss.sonatype.org/service/local/staging/deploy/maven2/): Failed to transfer file: https://oss.sonatype.org/service/local/staging/deploy/maven2/com/github/aliteralmind/xbnjava/0.1.2/xbnjava-0.1.2.pom. Return code is: 401, ReasonPhrase: Unauthorized.
at org.eclipse.aether.internal.impl.DefaultDeployer.deploy(DefaultDeployer.java:337)
at org.eclipse.aether.internal.impl.DefaultDeployer.deploy(DefaultDeployer.java:268)
at org.eclipse.aether.internal.impl.DefaultRepositorySystem.deploy(DefaultRepositorySystem.java:413)
at org.apache.maven.artifact.deployer.DefaultArtifactDeployer.deploy(DefaultArtifactDeployer.java:139)
... 23 more
Caused by: org.eclipse.aether.transfer.ArtifactTransferException: Could not transfer artifact com.github.aliteralmind:xbnjava:pom:0.1.2 from/to sonatype-nexus-staging (https://oss.sonatype.org/service/local/staging/deploy/maven2/): Failed to transfer file: https://oss.sonatype.org/service/local/staging/deploy/maven2/com/github/aliteralmind/xbnjava/0.1.2/xbnjava-0.1.2.pom. Return code is: 401, ReasonPhrase: Unauthorized.
at org.eclipse.aether.connector.wagon.WagonRepositoryConnector$6.wrap(WagonRepositoryConnector.java:1016)
at org.eclipse.aether.connector.wagon.WagonRepositoryConnector$6.wrap(WagonRepositoryConnector.java:1004)
at org.eclipse.aether.connector.wagon.WagonRepositoryConnector$PutTask.run(WagonRepositoryConnector.java:895)
at org.eclipse.aether.connector.wagon.WagonRepositoryConnector.put(WagonRepositoryConnector.java:522)
at org.eclipse.aether.internal.impl.DefaultDeployer.deploy(DefaultDeployer.java:331)
... 26 more
Caused by: org.apache.maven.wagon.TransferFailedException: Failed to transfer file: https://oss.sonatype.org/service/local/staging/deploy/maven2/com/github/aliteralmind/xbnjava/0.1.2/xbnjava-0.1.2.pom. Return code is: 401, ReasonPhrase: Unauthorized.
at org.apache.maven.wagon.providers.http.AbstractHttpClientWagon.put(AbstractHttpClientWagon.java:573)
at org.apache.maven.wagon.providers.http.AbstractHttpClientWagon.put(AbstractHttpClientWagon.java:493)
at org.apache.maven.wagon.providers.http.AbstractHttpClientWagon.put(AbstractHttpClientWagon.java:474)
at org.apache.maven.wagon.providers.http.AbstractHttpClientWagon.put(AbstractHttpClientWagon.java:454)
at org.eclipse.aether.connector.wagon.WagonRepositoryConnector$PutTask.run(WagonRepositoryConnector.java:871)
... 28 more
[ERROR]
[ERROR] Re-run Maven using the -X switch to enable full debug logging.
[ERROR]
[ERROR] For more information about the errors and possible solutions, please read the following articles:
[ERROR] [Help 1] http://cwiki.apache.org/confluence/display/MAVEN/MojoExecutionException
Respostas:
Eu tive erros semelhantes ao tentar implantar um artefato Gradle em um repositório Nexus Sonatype. Você obterá um erro 401 Unauthorized se fornecer as credenciais incorretas (senha, etc.). Você também obtém um erro (e no topo da minha cabeça também é um 401) se você tentar publicar algo em um repositório de lançamentos e essa versão já existir no repositório. Portanto, você pode descobrir que, publicando a partir da linha de comando, funciona, mas quando o faz a partir de um script, ele falha (porque não existia no repositório da primeira vez). Publique usando um número de versão diferente ou exclua o artefato antigo no servidor e publique novamente.
O repositório SNAPSHOTS (ao contrário do repositório de releases) permite que você sobrescreva uma versão numerada de forma semelhante, mas o número da sua versão deve ter "-SNAPSHOT" no final dele.
fonte
0.1.2-SNAPSHOT
que já foi criado atrapalha minha nova0.1.2
versão, como você sugere. Alterá-lo para0.1.0
("anterior"), ou0.1.2a
, ou0.1.3
("posterior") resulta no erro com o qual estava lidando antes deste:[ERROR] Failed to execute goal org.apache.maven.plugins:maven-install-plugin:2.4:install (default-install) on project xbnjava: Failed to install artifact com.github.aliteralmind:xbnjava:jar:0.1.3: R:\jeffy\programming\build\xbnjava-0.1.3\download\xbnjava-0.1.3-all.jar (The system cannot find the path specified) -> [Help 1]
. Eu não acho que fiz qualquer alteração, mas obviamente eliminar isso-SNAPSHOT
da versão foi uma coisa ruim.Um dos motivos para esse erro é quando repositoryId não é especificado ou especificado incorretamente. Conforme já mencionado, deve ser o mesmo da seção em settings.xml. Algumas dicas ... Execute mvn com as opções -e -X e verifique a saída de depuração. Ele dirá qual repositoryId está usando:
Neste caso, ele usa o valor padrão "remote-repository", o que significa que algo deu errado.
Aparentemente, especifiquei -DrepositoryID (observe o ID em maiúsculo) em vez de -DrepositoryId.
fonte
settings.xml
, tornei os dois repo IDs idênticos novamente (instantâneo e release), mas adicionei outra declaração com um ID exclusivo para nosso mesmo repo de release (basicamente um alias). Isso permitiu projetos que exigiam um nome exclusivo para se referir a isso, e os projetos mais antigos que usavam nomes idênticos para se referir a eles. Nosso master-pom refere-se ao idêntico.apenas altere em settings.xml estes como aliteralmind diz:
você provavelmente precisará obter o nome de usuário / senha do sonatype ponto com.
fonte
Eu coloquei uma senha não criptografada no settings.xml.
Eu testei a chamada com curl
e recebi o erro:
Recuperei minha senha criptografada clicando em meu perfil artifactory e desbloqueando-o.
fonte
code curl -u username:password --request PUT --data target/api-1.0-SNAPSHOT.jar http://url/artifactory/libs-snapshot-local/com/myproject/api/1.0-SNAPSHOT/api-1.0-20160128.114425-1.jar
em vezTambém tinha 401 da Nexus. Depois de tentar todas as sugestões acima e outras sem sucesso, acabei descobrindo que era uma configuração do Jenkins que estava errada.
Na configuração do Jenkins para o projeto com falha, temos uma seção nas ações 'Pós-construção' intitulada 'Implementar artefatos no repositório Maven'. Isso tem um campo 'ID do repositório' que foi definido com o valor errado. Deve ser igual ao ID do repositório em settings.xml para que o Jenkins leia os campos de usuário e senha:
fonte
Conforme afirmado na resposta de @John, o fato de já existir um
0.1.2-SNAPSHOT
interferiu na minha nova versão não SNAPSHOT0.1.2
. Como o401 Unauthorized
erro é nebuloso e inútil - e normalmente associado a problemas de usuário / senha - não é surpresa que eu não tenha conseguido descobrir isso sozinho.Alterar a versão para
0.1.3
me traz de volta ao meu erro original:[ERROR] Failed to execute goal org.apache.maven.plugins:maven-install-plugin:2.4:install (default-install) on project xbnjava: Failed to install artifact com.github.aliteralmind:xbnjava:jar:0.1.3: R:\jeffy\programming\build\xbnjava-0.1.3\download\xbnjava-0.1.3-all.jar (The system cannot find the path specified) -> [Help 1].
Uma pessoa de suporte de sonatipo também recomendou que eu removesse o
<parent>
bloco do meu POM (ele só está lá porque está no do ez-vcard , que é o que eu comecei) e substitua meu<distributionManagement>
bloco porDepois de fazer isso,
mvn deploy
executei o upload de um dos meus jars pela primeira vez !!!Resultado:
(Parte do sucesso :)
Aqui está o POM atualizado completo:
Esse é um grande problema do Maven que está fora do caminho. Apenas mais 627 para ir.
fonte
Alguns usuários podem ter inserido o endereço de e-mail em vez do nome do usuário por engano. Isso pode acontecer inconscientemente quando o nome no endereço de e-mail for igual ao nome do usuário.
fonte
Esta é a explicação oficial da equipe sonatype nexus sobre 401 - Unauthorized
Recomendo que você leia Solucionando problemas de falhas de implantação de artefato para obter mais informações.
fonte
no meu caso, depois de criptografar a senha, esqueci de colocar
settings-security.xml
em ~ / .m2。fonte
Tivemos esse problema recentemente e descobrimos que tinha a ver com a versão do Maven que estávamos usando. Estávamos usando 3.1.0 e não podíamos fazer upload para o Nexus, continuamos recebendo 401's, voltamos para 3.0.3 e o problema foi embora.
A maneira mais fácil de confirmar é trabalhar com as versões do maven e executar "mvn deploy" em seu projeto.
Mais detalhes podem ser encontrados aqui: https://issues.apache.org/jira/browse/WAGON-421
fonte
Eu estava lidando com este Artifactory executando a versão 5.8.4. A função "Configure-me" geraria settings.xml da seguinte forma:
Depois de usar o switch mvn deploy -e -X, percebi que as credenciais não eram precisas. Removi o $ {security.getCurrentUsername ()} e o substituí pelo meu nome de usuário e removi $ {security.getEscapedEncryptedPassword ()! ""} E apenas coloquei minha senha criptografada que funcionou para mim:
Espero que isto ajude!
fonte
Na versão 3.13.0-01 do Nexus, o
id
nadistributionManagement/repository
seção do POM DEVE corresponder aoservers/server/id
emirrors/mirror/id
nas configurações do maven.xml. Acabei de substituir o nexus v3.10.4 (com 3.13.0-01) e não era necessário corresponder ao 3.10.4.fonte
Teve um problema semelhante. Tive que fixar o plug-in de implantação do maven em uma versão específica em pom.xml:
Esta versão é o que quebrou minhas construções:
fonte
Eu tive o mesmo erro. Tentei e verifiquei tudo novamente. Eu estava tão focado no rastreamento de pilha que não li as últimas linhas do build antes do resumo do Reactor e do rastreamento de pilha:
Esta era a chave: "Não foi possível encontrar metadados" . Embora tenha dito que foi um erro de autenticação, na verdade, ele foi corrigido fazendo uma "reconstrução de metadados" no repositório Nexus.
Espero que ajude.
fonte
Além disso, depois de atualizar seus ids de repositório, certifique-se de executar o clean, pois
release:prepare
continuará de onde parou. Então você pode fazer:mvn release:prepare -Dresume=false
oumvn release:clean release:prepare
fonte
Existem dois setting.xml no windows.
%MAVEN_HOME%\conf\
%userprofile%\.m2\
Se
%userprofile%\.m2\setting.xml
entrar em vigor, o maven não acessará%MAVEN_HOME%\conf\setting.xml
.fonte
Pode ser causado por versão errada, você pode verificar a versão do pai e a versão da lib , para ter certeza de que estão corretas e não duplicadas, eu tive o mesmo problema
fonte
Recebi um
401
erro quando usei omvn gpg:sign-and-deploy-file
comando e o motivo foi que<MVN_HOME>/conf/settings.xml
não inclui a<server>
tag que você pode obter porhttps://oss.sonatype.org/#profile;User%20Token
onde<id>
é o mesmo que-DrepositoryId
Para
<MVN_HOME>
corrermvn --version
fonte
No meu caso, removi as credenciais de logon do servidor para central da minha configuração.
Não sei por que fiz isso, mas é completamente errado, já que o repositório central do maven pode ser acessado anonimamente. Veja minha saída de depuração que levou à minha identificação e resolução de erros.
fonte
Solução:
Neste caso, você precisa alterar a versão no arquivo pom e tentar usar uma nova versão.
Aqui já existe 01.16.03 então estava falhando e quando tentei com a versão 01.16.04 o trabalho foi bem sucedido.
fonte
Recebi o mesmo erro ao tentar implantar em um repositório Artifactory, o seguinte resolveu o problema para mim:
Vá para a configuração do repositório no artifactory e habilite o ponto " Forçar autenticação Maven " e o erro 401 "Não autorizado" deve desaparecer. (Claro que você precisa fornecer suas credenciais no arquivo settings.xml, na melhor das hipóteses, em texto simples para evitar problemas )
Acho que por padrão, mesmo que você forneça as credenciais corretas no arquivo settings.xml, elas não são usadas e você obtém a exceção não autorizada.
fonte