ChatGPT解决这个技术问题 Extra ChatGPT

Maven: Failed to read artifact descriptor

I am hoping someone can help me with a problem I am struggling with.

When I try to build my project from the terminal I get this error:

Failed to read artifact descriptor for com.morrislgn.merchandising.common:test-data-utils:jar:0.3b-SNAPSHOT: Could not find artifact com.morrislgn.merchandising:merchandising:pom:0.3b-SNAPSHOT

The common.test-data-utils jar is created by a separate project and shared between this and another project (the other project doesn't build either, but that is down to another problem).

I am able to build com.morrislgn.merchandising.common:test-data-utils without issue, I can see the entry it makes in the .m2 local repository on my machine. I have reindexed my repository in Eclipse also.

The POM for my project has this entry:

<dependency>
    <groupId>com.morrislgn.merchandising.common</groupId>
    <artifactId>test-data-utils</artifactId>
    <version>0.3b-SNAPSHOT</version>
</dependency>

Which appears to be correct to me - the POM doesn't report any errors either when it is viewed in Eclipse.

Can some one tell me what I am missing here or doing wrong?

If someone (like me) encounters this error due to http repository in maven > 3.8.1, something like maven-default-http-blocker (http://0.0.0.0/): Blocked mirror for repositories:, refer this: stackoverflow.com/q/67001968/6346531
@aksh1618 Thanks. That was the resolution for my issue

M
Majid

You can always try mvn -U clean install

-U forces a check for updated releases and snapshots on remote repositories.


@MrPhi: If you have the m2e plugin, then you can use Maven -> "Update Project...". The next dialog will have an option to force updates of snapshots and releases.
@AaronDigulla It's that dialog box which is causing the error for me.
To make this works you should run command being inside of root dir of your project
I had a similar issue as well. This really helps, and in addition, if you are using private mvn repo, make sure to add that to your ~/.m2/setting.xml mirror section first, and then after running mvn -U clean install, make sure to Reimport (right click the project, then under the bottom Maven section there is a Reimport button).
@TomaszWaszczyk : Yes there is. 1. Windows-show view->Terminal. 2. Add local terminal 3. cd PomFilePath 4. Run the command
B
Ben Zuill-Smith

This problem can occur if you have some child projects that refer to a parent pom and you have not installed from the parent pom directory (run mvn install from the parent directory). One of the child projects may depend on a sibling project and when it goes to read the pom of the sibling, it will fail with the error mentioned in the question unless you have installed from the parent pom directory at least once.

I just ran into this problem when moving a project to a new computer. I was in the habit of running commands from the child project and didn't run install on the parent.


In addition, when running mvn install on parent you can also add -N for non-recursive operation. This will cause maven to skip all the modules (including one that fails) and just do install goal for the parent.
@JacekPrucia good to know that a pom artifact also needs to be installed (if your parent is a pom)
@bzuillsmith why would you need to run mvn install in the parent pom. Wouldn't this only be used so the sibling dependency can be downloaded? If you happen to have went to the sibling directory & ran mvn install from there so that the jar is in your local repository, doesn't this accomplish the same exact thing?
It's been a few years since I've used maven, but--Yes, I believe you can install the sibling dependencies one by one. Installing from the parent just tends to be less work (fewer commands to type and run). There may be cases in large projects where you don't want all child projects installed in which case you would need to run them individually.
My project like ch-multip-spring\simple-parent\simple-model\pom.xml, I do mvn clean install from root ch-multip-spring folder(not from simple-parent as well), it solved my the issue similar to the post title.
B
Basil Bourque

Had the same issue with IntelliJ IDEA and following worked.

Go to File

Select Settings

Select Build, Execution, Deployments

Select Build Tools from drop down

Select Maven from drop down

Tick the Always update snapshots check box

https://i.stack.imgur.com/NVfCJ.jpg


This worked for me, but I don't understand why - I was attempting to build from the command line. Was there something cached from IntelliJ?
Worked for me too! Can't believe how frustrating this was. Thanks!
@ goodOldFashioned: This "always update" overwrote the ....lastUpdated file from the local repository. -U does the same from the commandline. So intellij fixed your local repo, and then the commandline worked again.
Simple and effective
after browsing the whole internet, finally this worked for me
I
IamVickyAV

If you are using Eclipse, Right Click on your Project -> Maven -> Update Project. It will open Update Maven Project dialog box.

In that dialog box, check Force Update of Snapshots/Releases checkbox & click OK. (Please refer image below)

https://i.stack.imgur.com/gupF2.png

This worked for me !


L
Lii

If you're using Eclipse:

Right click on project > Properties > Maven

Make sure that Resolve dependencies from workspace projects is not clicked.


It works for me. But I dont understand why? Any explanation behind this?
this did not work for me, initially 12 decencies were missing, after doing this it is 74 now
r
rrs

I know I'm pretty late to the conversation, but I had this problem too. I think the issue was my company's firewall. My solution was to unplug from the network, connect to our open wireless and then force an update via Eclipse. This resolved everything.


You need to have put in proxy info into your .m2/settings.xml
D
Dean Hiller

I had the same issue with eclipse where the maven build command line worked just fine BUT try this

go into .m2/repository and wipe the directory associated

run update maven dependencies in eclipse

The error goes away....why my mvn command line worked with those directories and eclipse .m2eclipse could not, I have no idea and it kinda sucks. My project is now working in eclipse again.


on a side note, we switched to gradle....so much happier than ant and maven....extremely nice setup.
Not even sure it's anything Eclipse-related. I had the same issue with IntelliJ and deleting the problematic packages and re-running mvn clean install worked
r
rlopezo

I had same problem using IntelliJ. I solved with right click on pom.xml > Maven > Reimport


Yeah, like life is just that simple. Anyways, @prime answer worked for me.
1
17sprints

I solved this issue by deleting in the repository folders where this error was shown everything except the .jar and .pom files.


I have also solved the same issue by deleting related files in the maven local repository and then update the whole project.
R
Roshan Khandelwal

For me , it was related to setting the "User Setting.xml" inside

Window > preferences > Maven > User Settings > and then browsing to the user Settings inside the { maven unarchived directory / }/apache-maven-2.2.1/conf/settings.xml . 

e
eaykin

"Failed to read artifact descriptor" problems generally indicate a problem with the dependency's pom file in the maven repository. I would suggest you to double check if the pom file's name is the same with the name maven expects, and also to check if the pom file contents are valid.


The check of the pom.xml was useful. I found I had same dependency twice (copy & paste error). After cleanup everything was fine.
L
Léa Gris

Navigate via shell inside of your project folder and run following command:

mvn -U clean install

Usually this should already solve your problem.

If you see a message like this:

Could not resolve dependencies for project :war:0.0.1-SNAPSHOT: Failed to collect dependencies at com.sun.jersey:jersey-server:jar:1.9

Then execute:

export MAVEN_OPTS=-Dhttps.protocols=TLSv1,TLSv1.1,TLSv1.2

followed by:

mvn -U clean install

again to finally update your dependencies.

Afterwards perform clean maven build:

maven clean install

J
Jamie Counsell

I have a project

 A/
 |--a1
 |--a2

Now there is another project in our org

 B/
 |--b1
 |--b2
 |--b3

(Every module a1, b1 etc. and Parent projects A, B have their own pom.xml as per standard maven rules of parent and child)

Both projects are checked out on my local eclipse (from SVN). I am actively working on A.

I came to know that there is a good common functionality (b4) developed in B and I needed to use it.

 B/
 |--b1
 |--b2
 |--b3
 |--b4 (NEW)

Developer of b4 have deployed this b4 module as an artifact in our org's repository. I included the dependancy to my module's POM i.e. a2's pom.xml. Eclipse downloaded the reuqired artifact from repo and I could import the classes in it.

Now issue starts... I needed to check the source code of b4 for some purpose and as I already had B checked out on my local eclipse I updated it from SVN and checked out module b4. I also ran pom.xml of module b4 with targets like clean, package etc. After some time when I finishedd my coding I needed to create a JAR of my module a2. I ran "package" on a2's pom.xml and BAM!! errors n errors for a2 module.. These errors were also not very user friendly. Only thing is there was b4's name for sure in logs.

Solution: After trying for many solutions for many hours, I ran "mvn -U clean install" from console in my B's project directoty (i.e. in ../codebase/B). As B is the parent, clean install command ran for all modules including b4 and it ran successfully. After this I ran "mvn -U clean install" for my parent project which is A. And this worked! a2 module got compiled, installed, (packaged later) succesfully.

Here important point was if b4 is in your workspace do not only install b4. You will need to clean-install complete B. I came up to this solution after reading answer from Zuill

EDIT: One more thing here to note that if I didn't had B project checked out in Local environment then this issue might not have occurred for me. I tend to think that this happened cause I had B checked out in my local workspace.


Thanks for your help. I meet the same problem, project A add a dependency from project B's submodule B-IDL. I should mvn deploy whole B project, not just mvn deploy submodule B-IDL.
p
phlogratos

You mention two different groupIds, com.morrislgn.merchandising.common and com.johnlewis.jec.webpim.common. Maybe this is the problem.


Good spot - no, its not unfortunatly. I copied the wrong tag from the POM XML, that was the one above the tag I needed and didnt spot what I'd done. Ooops! I've edited the question to fix my stupidity!
P
Phil Rykoff

For me, it seems to actually have been a problem with the dependency POM.

I worked around it by using the jitpack virtual repository, with which you can include github repositories based on their URL instead of their own POM (which seems to have been erroneous in my case).

    <repository>
        <id>jitpack.io</id>
        <url>https://jitpack.io</url>
    </repository>

This worked for me. The repository section of the pom.xml file should be properly updated and the tag should be the name of the repository. Saved a lot of my time!
C
Community

Reference Maven error "Failure to transfer..."

find ~/.m2  -name "*.lastUpdated" -exec grep -q "Could not transfer" {} \; -print -exec rm {} \;

T
Toothless Seer

Did not have any luck updating via eclipse. Had to use mvn clean install -U (which resolved everything).


Gal Bracha answered this as well. Better to vote up a working answer and add comments if needed.
s
sakhoshdel

I had the same problem for a while and despite doing mvn -U clean install the problem was not getting solved!

I finally solved the problem by deleting the whole .m2 folder and then restarted my IDE and the problem was gone!

So sometimes the problem would rise because of some incompatibilities or problems in your local maven repository.


Tried doing a Maven resync while offline, and completely hosed IntelliJ. Followed your advice, deleted .m2, and now it's working like a charm! Thanks!
I
Ilya Serbis

In our case the error appeared because of the incorrect groupId renaming while some of the projects in multi-module Maven configuration references to others.

We had an aggregator project (billing-parent) with two modules (billing-api, billing):

com.company.team:billing-parent
|-com.company.team:billing-api
|-com.company.team:billing

Project billing depends on billing-api. So in its pom.xml it had:

<dependency>
    <groupId>com.company.team</groupId>
    <artifactId>billing-api</artifactId>
    <version>${project.version}</version>
</dependency>

We decided to rename groupId from com.company.team to com.company.team.billing. We replaced old value in parent's pom.xml and in <parent> sections of both modules. But forgot to update dependency above. So we had got configuration in which billing project references old billing-api artifact. Eventually it beaks build of the billing module after some time with the error like

[ERROR] Failed to execute goal on project billing: Could not resolve dependencies for project com.company.team.billing:billing:jar:3.5.1-SNAPSHOT: Failed to collect dependencies at com.company.team:billing-api:jar:3.5.1-SNAPSHOT: Failed to read artifact descriptor for com.company.team:billing-api:jar:3.5.1-SNAPSHOT: Failure to find <parent of the com.company.team:billing-parent project which is not available any more>

despite the fact that billing-api module builds without errors.

Solution 1: rename groupId in dependency as well.

Solution 2: replace groupId by the ${project.groupId} property like this:

<dependency>
    <groupId>${project.groupId}</groupId>
    <artifactId>billing-api</artifactId>
    <version>${project.version}</version>
</dependency>

Conclusion. So my advice in case you encountered with the error in multi-module configuration whould be: thoroughly check groupId and artifactId of the dependencies on neighbour modules.


W
William

I had a similar problem. In my case, the version of testng in my .m2/repositories folder was corrupt, but when I deleted it & did a maven update again, everything worked fine.


S
Sandoval0992

This error is basically saying that maven couldn't read a certain dependency from local repository. It might happend because a jar file didn't get downloaded correctly. So, go to your maven local repository and make sure there isn't any .lastUpdated extension file.


This was my issue. Once I deleted the lastUpdated file for the dependency which was failing it worked fine.
s
sjngm

I know I'm brave, nine years after the question...

For me it was a problem where sub-dependencies weren't found. I finally found the real issue by looking at the "Error Log"-view that held a An internal error occurred during: "Building".-line. Double-clicking it showed a pop-up with a stacktrace and the last cause finally disclosed a broken JAR in my local repository. I cleaned that up and Eclipse/m2e was able to work again.


g
gary69

I had this problem in eclipse, mvn -U clean install didn't work but right clicking the project and selecting Maven->Update Project fixed it.


M
Mogsdad

I just started using STS Eclipse with first time using Maven. The project I setup already had its own settings.xml. If this is the case, you'll want to update your settings.xml file in run configuration.

right click the pom.xml and "Run As" -> "Run Configurations..." where it says "User settings" click on the File button and add the settings.xml. I think this is specific to your project but my "Goals" is set to "clean install" and I checked on "Skip Tests."


N
Nhlanhla R.

This helped me:

From the IDE (Red Hat CodeReady Studio in my case).

Windows -> Show View -> Terminal -> Open/Add local terminal

Run commands as follows >

$ cd /pom-file-path/

$ mvn -U clean install