HTTP状态500 - servlet fitTrackerServlet的Servlet.init()抛出异常

时间:2015-09-05 18:45:51

标签: java spring jsp spring-mvc servlets

这是我第一次使用Spring,我正在关注PluralSight的教程。运行第一个示例,我遇到标题中列出的错误。在我的控制台中,我收到这样的错误。我正在使用旧版本的依赖项来完成本课程。我已经确保密切关注这个教程,所以不确定我是否搞砸了某个地方或某些东西被弃用了。我正在使用http://localhost:8080/FitnessTracker/greeting.html

SEVERE: Context initialization failed
java.lang.IllegalArgumentException
SEVERE: StandardWrapper.Throwable
java.lang.IllegalArgumentException
SEVERE: Allocate exception for servlet fitTrackerServlet
java.lang.IllegalArgumentException

HelloController.java

package com.pluralsight.controller;

import org.springframework.stereotype.Controller;
import org.springframework.ui.Model;
import org.springframework.web.bind.annotation.RequestMapping;

@Controller
public class HelloController {

    @RequestMapping(value = "/greeting")
    public String sayHello(Model model) {
        model.addAttribute("greeting", "Hello World");
        return "hello";
    }
}

servlet的config.xml中

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    xmlns:context="http://www.springframework.org/schema/context"
    xmlns:mvc="http://www.springframework.org/schema/mvc"
    xmlns:p="http://www.springframework.org/schema/p"
    xsi:schemaLocation="http://www.springframework.org/schema/mvc http://www.springframework.org/schema/mvc/spring-mvc-3.2.xsd
        http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd
        http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-3.2.xsd">

    <mvc:annotation-driven />
    <context:component-scan base-package="com.pluralsight.controller" />

    <bean class="org.springframework.web.servlet.view.InternalResourceViewResolver" 
    p:prefix="/WEB-INF/jsp/" p:suffix=".jsp"/>

</beans>

的hello.jsp

<%@ page language="java" contentType="text/html; charset=ISO-8859-1"
    pageEncoding="ISO-8859-1"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=ISO-8859-1">
<title>Insert title here</title>
</head>
<body>
    <h1>${greeting}</h1>
</body>
</html>

的web.xml

<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns="http://java.sun.com/xml/ns/javaee" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" version="2.5" xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd">
  <servlet>
    <servlet-name>fitTrackerServlet</servlet-name>
    <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
    <init-param>
        <param-name>contextConfigLocation</param-name>
        <param-value>/WEB-INF/config/servlet-config.xml</param-value>
    </init-param>
  </servlet>

  <servlet-mapping>
    <servlet-name>fitTrackerServlet</servlet-name>
    <url-pattern>*.html</url-pattern>
  </servlet-mapping>

  <display-name>Archetype Created Web Application</display-name>
</web-app>

的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.pluralsight</groupId>
  <artifactId>FitnessTracker</artifactId>
  <packaging>war</packaging>
  <version>0.0.1-SNAPSHOT</version>
  <name>FitnessTracker 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>org.springframework</groupId>
        <artifactId>spring-webmvc</artifactId>
        <version>3.2.0.RELEASE</version>
    </dependency>


    <dependency>
        <groupId>javax.servlet</groupId>
        <artifactId>servlet-api</artifactId>
        <version>2.5</version>
        <scope>provided</scope>
    </dependency>
    <dependency>
        <groupId>javax.servlet</groupId>
        <artifactId>jstl</artifactId>
        <version>1.2</version>
        <scope>provided</scope>
    </dependency>
  </dependencies>
  <build>
    <finalName>FitnessTracker</finalName>
  </build>
</project>

6 个答案:

答案 0 :(得分:8)

我在同一个PluralSight教程中遇到了同样的问题。我安装了Java 1.7和Java 1.8。该项目显然抛出了Java 1.8的异常。要纠正这种情况,您需要确保将Spring STS环境设置为使用Java 1.7。

  1. 右键单击该项目,然后选择属性
  2. 属性对话框中,选择 Java编译器
  3. 在对话框底部,选择用于配置已安装的JRE 的链接。
  4. 添加定义以指向JRE 1.7并选择此作为默认值。
  5. PluralSight教程现在适合我。我自己是Java和Spring MVC的初学者,所以我不确定这是否是解决问题的最佳方法。

答案 1 :(得分:6)

嗯,spring 3.2需要java 7或更早版本。另一个解决方案是将pom.xml中的spring mvc的版本号更改为4.2.4.RELEASE而不是之前使用的3.2.0.RELEASE,而不是更改项目属性。 现在,您可以正常使用java 8。

下面,我展示整个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.pluralsight</groupId>
  <artifactId>FitnessTracker</artifactId>
  <packaging>war</packaging>
  <version>0.0.1-SNAPSHOT</version>
  <name>FitnessTracker 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>jstl</artifactId>
        <version>1.2</version>
        <scope>provided</scope>
    </dependency>
    <dependency>
        <groupId>javax.servlet</groupId>
        <artifactId>servlet-api</artifactId>
        <version>2.5</version>
        <scope>provided</scope>
    </dependency>
    <dependency>
        <groupId>org.springframework</groupId>
        <artifactId>spring-webmvc</artifactId>
        <version>4.2.4.RELEASE</version>
    </dependency>
  </dependencies>
  <build>
    <finalName>FitnessTracker</finalName>
  </build>
</project>

答案 2 :(得分:1)

尝试使用4.1.5。它对我有用。

<dependency>
        <groupId>org.springframework</groupId>
        <artifactId>spring-webmvc</artifactId>
        <version>4.1.5.RELEASE</version>
</dependency>

答案 3 :(得分:0)

    <dependency>
        <groupId>org.springframework</groupId>
        <artifactId>spring-webmvc</artifactId>
        <version>3.2.3.RELEASE</version>
    </dependency>        
    <dependency>
        <groupId>org.springframework</groupId>
        <artifactId>spring-jdbc</artifactId>
        <version>3.2.3.RELEASE</version>
    </dependency>
    <dependency>
        <groupId>org.springframework</groupId>
        <artifactId>spring-orm</artifactId>
        <version>3.2.3.RELEASE</version>
    </dependency>

尝试在任何有弹簧依赖性的地方使用3.2.3.RELEASE版本

答案 4 :(得分:0)

我遇到了同样的问题。 所以你要做的就是使用 Tomcat v7.0, 这是因为我使用的是Tomcat v9.0,它不适用于 JRE7 而是 JRE8 。 所以

  • 使用 Tomcat v7.0 设置应用程序,并使用 JRE7 设置STS或Eclipse默认构建路径。
  • 重新启动Tomcat服务器。
  • 转到您的浏览器并粘贴上面的链接,在这里你去! :)

答案 5 :(得分:0)

要解决此问题,只需将servlet容器的运行时环境更改为Java 7.在Eclipse中:

  1. 偏好设置 - &gt;服务器 - &gt;运行时环境
  2. 选择您正在运行项目的服务器,然后单击编辑...
  3. JRE部分,选择Java 7 JRE。请注意,为了能够执行此操作,首先需要下载并安装Java 7,并在Eclipse中提供Java 7 JRE。要在Eclipse中使Java 7 JRE可用:
    1. 下载Java 7并安装它。
    2. 在Eclipse中,选择首选项 - &gt; Java - &gt;安装JRE并单击搜索... 。如果已将Java 7安装到其默认路径,则Eclipse应该能够自动发现Java 7.
    3. 将Java 7添加到Eclipse后,您可以选择JRE 7作为servlet容器的运行时环境。
  4. 我还建议指出服务器名称中使用的运行时环境。例如,在Eclipse中,不要让服务器名称只是&#34; Apache Tomcat v7.0&#34;而是使它成为#34; Apache Tomcat v7.0-JRE 7&#34;。当然,如果稍后更改此服务器的运行时环境,则应更新此名称。

    来源:http://www.codejava.net/ides/eclipse/how-to-change-java-runtime-environment-for-tomcat-in-eclipse

    注意:此答案也适用于任何其他IDE。您只需要确保您的servlet容器在JRE 7下运行。