ClassNotFoundException DispatcherServlet when launching Tomcat (Maven dependencies not copied to wtpwebapps)

30,569

Solution 1

Take a look at "Deployment Assembly" section under project properties. The content of this page specify how your project is to be assembled into a running application. In particular, this is the place where you can control which of the libraries that your project references, should be packaged with it. Select Add -> Java Build Path Entries. You will be able to pick among your existing build path entries to include in the assembly.

The quick fix that you found did the same thing for you. If you are curious about what happens under the covers, take a look at your .classpath file before and after the quick fix. The quick fix tags the classpath entry with some assembly information.

Solution 2

Check .class file and replace the following entry

    <classpathentry kind="con" path="org.maven.ide.eclipse.MAVEN2_CLASSPATH_CONTAINER" />

with Below:-

    <classpathentry kind="con" path="org.maven.ide.eclipse.MAVEN2_CLASSPATH_CONTAINER">
      <attributes>
        <attribute name="org.eclipse.jst.component.dependency" value="/WEB-INF/lib"/>
      </attributes>
    </classpathentry>

It worked for me.

Solution 3

It seems, you have to additionally install Maven Integration for WTP plugin. Its description can be found at issues.sonatype.org.

Share:
30,569

Related videos on Youtube

Russell
Author by

Russell

I LIKE PROGRAMMING.

Updated on September 22, 2020

Comments

  • Russell
    Russell over 3 years

    I've run into this problem a few times and only just stumbled upon a (semi-) reliable solution, so thought I would post it here in case it helps anyone else, or in case I forget it, and also to ask if anyone has any idea what the underlying cause is and why my fix works.

    The problem - I have a spring 3 webapp that I want to use the Run on Server option in Eclipse to run on a Tomcat 7 server. With some projects this just works, but some seem to get in a broken state whereby every time the server starts up I get a class not found: org.springframework.web.servlet.DispatcherServlet.

    After some investigation I found out that the project's maven dependencies had not been copied to WEB-INF/lib in ${PROJECT_LOCATION}/.metadata/.plugins/org.eclipse.wst.server.core/tmp0/wtpwebapps/

    I tried a lot of things before finally noticing that the project had a warning in the Problems panel:

    Classpath entry org.maven.ide.eclipse.MAVEN2_CLASSPATH_CONTAINER 
    will not be exported or published. Runtime ClassNotFoundExceptions may result.
    

    Perhaps I should have noticed this sooner.

    Anyway, selecting this and performing the "Quick Fix" fixes the issue and I can happily run my project. The quick fix is to: "Mark the associated raw classpath entry as a publish/export dependency".

    Trouble is, although this works, I don't know what it means. I can't see any obvious changes in my project configuration after it's done. I would quite like to know what the actual problem is and if I can avoid it happening again. I would also like to know if there is something I could have done myself (other than performing the quick fix) that would have fixed it, because I feel like I tried pretty much everything else.

    Thanks for your help.

  • Russell
    Russell over 13 years
    Thanks! I find it impossible to remember stuff if I don't understand how it works, so this will most likely save me a great deal of pain in future.
  • fforw
    fforw about 12 years
    Awesome. This really helped me after my Eclipse suddenly exploded for no reason yesterday.
  • chrisjleu
    chrisjleu about 12 years
    It's unlikely that you would want to export the entire Maven classpath as this will likely result in conflicts on the application server that provides some jars by default (like for instance servlet-api-2.5.jar, jsp-api-2.1.jar, jstl-1.2.jar). Instead each jar should be selected one by one in the Deployment Assembly section of Eclipse as mentioned in the accepted answer by Konstantin.
  • Dipanshu Verma
    Dipanshu Verma almost 7 years
    For me <attribute name="org.eclipse.jst.component.dependency" value="/WEB-INF/lib"/> is already present, but still I am getting NoClassDefFoundError, , but when I go to the location .metadata/.plugins/org.eclipse.wst.server.core/tmp0, I do not find my maven dependency in Lib, any hints?
  • ScottSummers
    ScottSummers over 4 years
    You might have to restart the tomcat server after this.