HTTP状态500-Servlet fitTrackerServlet的Servlet.ini()引发异常



这是我第一次使用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>

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

  1. 右键单击项目并选择属性
  2. 在"属性"对话框中,选择"Java编译器">
  3. 在对话框底部,选择链接以配置已安装的JRE
  4. 添加一个指向JRE 1.7的定义,并将其选择为默认值

PluralSight教程现在适用于我。我自己也是Java和Spring MVC的初学者,所以我不确定这是否是解决问题的最佳方法。

好吧,spring3.2需要java7或更早版本。另一种解决方案是将pom.xml中spring-mvc的版本号更改为4.2.4.RELEASE,而不是您之前使用的3.2.0.RELEASE。现在,您可以正常使用java8了。

下面,我展示了整个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>

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

<dependency>
        <groupId>org.springframework</groupId>
        <artifactId>spring-webmvc</artifactId>
        <version>4.1.5.RELEASE</version>
</dependency>
    <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版本

我也遇到了同样的问题。因此,您必须使用Tomcatv7.0,这是因为我使用的是Tomcat v9.0,它不适用于JRE7,但JRE8。所以

  • 使用Tomcat v7.0设置应用程序,并使用JRE7来设置STS或Eclipse默认构建路径
  • 重新启动Tomcat服务器
  • 转到你的浏览器并粘贴上面的链接,然后点击这里!!:(
要解决此问题,只需将servlet容器的运行时环境更改为Java7即可。在Eclipse中:
  1. 首选项->服务器->运行时环境
  2. 选择正在运行项目的服务器,然后单击"编辑…">
  3. JRE部分中,选择Java 7 JRE。请注意,为了能够做到这一点,您首先需要下载并安装Java 7,并在Eclipse中提供Java 7 JRE。要使Java 7 JRE在Eclipse中可用,请执行以下操作:
    1. 下载Java 7并安装它
    2. 在Eclipse中,选择Preferences->Java->Installed JRE,然后单击Search。如果您已经将Java7安装到其默认路径,Eclipse应该能够自动发现Java7
    3. 将Java 7添加到Eclipse后,可以选择JRE 7作为servlet容器的运行时环境

我还建议在服务器的名称中指明正在使用的运行时环境。例如,在Eclipse中,不要让服务器名称简单地为"Apache Tomcat v7.0",而是将其设置为"Apache Tomcatv7.0-JRE 7"。当然,如果以后更改此服务器的运行时环境,则应该更新此名称。

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

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

最新更新