Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

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

Tags:

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.

like image 625
Russell Avatar asked Jan 23 '11 22:01

Russell


2 Answers

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.

like image 99
Konstantin Komissarchik Avatar answered Oct 26 '22 08:10

Konstantin Komissarchik


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.

like image 33
Muskan Avatar answered Oct 26 '22 07:10

Muskan