Solucionado (ver solução)
Solucionado
(ver solução)
4
respostas

Maven Tomcat8 erro 500

No meu aqui esta acontencendo um erro quando eu do http://localhost:8080/ dá esse erro "Não foi possível encontrar a página deste localhost". http://localhost:8080/lojaweb/ dá esse erro: "HTTP Status 500 - java.lang.LinkageError: loader constraint violation: loader (instance of org/apache/jasper/servlet/JasperLoader) previously initiated loading for a different type with name "javax/servlet/http/HttpServletRequest""

Meu arquivo 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>br.com.msm</groupId>
    <artifactId>lojaweb</artifactId>
    <packaging>war</packaging>
    <version>0.0.1-SNAPSHOT</version>
    <name>lojaweb Maven Webapp</name>
    <url>http://maven.apache.org</url>
    <dependencies>
        <dependency>
            <groupId>junit</groupId>
            <artifactId>junit</artifactId>
            <version>3.8.1</version>
            <scope>test</scope>
        </dependency>

        <dependency>
            <groupId>javax.servlet</groupId>
            <artifactId>javax.servlet-api</artifactId>
            <version>3.1.0</version>
        </dependency>
    </dependencies>

    <build>
        <finalName>lojaweb</finalName>

        <plugins>
            <plugin>
                <groupId>org.apache.tomcat.maven</groupId>
                <artifactId>tomcat7-maven-plugin</artifactId>
                <version>2.2</version>
            </plugin>

        </plugins>

    </build>
</project>
4 respostas

acho que pode ter a ver com a versão do java instalado... mas é apenas um chute, ta com a 7 ou com a 8? se tiver com a 8, pode tentar com a 7?

ou tenta atualizar o plugin do tomcat, para um mais novo.

solução!

O meu java é o 8, e eu olhei em alguns fóruns que para o java 8 pode ser esse tomcat7-maven-plugin mesmo, e para resolver esse erro "HTTP Status 500 - java.lang.LinkageError: loader constraint violation: loader (instance of org/apache/jasper/servlet/JasperLoader) previously initiated loading for a different type with name "javax/servlet/http/HttpServletRequest"", eu coloquei desse jeito:

        <dependency>
            <groupId>javax.servlet</groupId>
            <artifactId>javax.servlet-api</artifactId>
            <version>3.1.0</version>
            <scope>provided</scope>
        </dependency>

Colocando o provided dentro da dependência da servlet, depois disso funcionou perfeitamente.

que estranho, parece que o tomcat estava usando a versão da servlet api que vc tinha especificado no pom.xml.. tinha me passado que não estava provided, que é o recomendado mesmo... mas achei que não ia impactar, pq o tomcat sempre ia escolher a versão da api dele. Bom, fica de aprendizado.