【问题标题】:Getting servlet exception in Spring 3.0在 Spring 3.0 中获取 servlet 异常
【发布时间】:2014-09-10 09:00:56
【问题描述】:

尝试从此链接学习弹簧:

http://viralpatel.net/blogs/spring-3-mvc-create-hello-world-application-spring-3-mvc/

但出现以下错误:

    type Exception report

    message Servlet execution threw an exception

    description The server encountered an internal error that prevented it from fulfilling this request.

    exception

   javax.servlet.ServletException: Servlet execution threw an exception
    org.springframework.web.servlet.view.InternalResourceView.renderMergedOutputModel(InternalResourceView.java:238)
    org.springframework.web.servlet.view.AbstractView.render(AbstractView.java:250)
    org.springframework.web.servlet.DispatcherServlet.render(DispatcherServlet.java:1060)
    org.springframework.web.servlet.DispatcherServlet.doDispatch(DispatcherServlet.java:798)
    org.springframework.web.servlet.DispatcherServlet.doService(DispatcherServlet.java:716)
    org.springframework.web.servlet.FrameworkServlet.processRequest(FrameworkServlet.java:647)
    org.springframework.web.servlet.FrameworkServlet.doGet(FrameworkServlet.java:552)
    javax.servlet.http.HttpServlet.service(HttpServlet.java:617)
    javax.servlet.http.HttpServlet.service(HttpServlet.java:723)

在浏览器和 Eclipse 控制台上重复多次出现上述错误。

文件内容为: web.xml

<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    xmlns="http://java.sun.com/xml/ns/javaee"
    xmlns:web="http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd"
    xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd"
    id="WebApp_ID" version="2.5">
    <display-name>Spring3MVC</display-name>
    <welcome-file-list>
        <welcome-file>index.jsp</welcome-file>
    </welcome-file-list>

 <servlet>
 <servlet-name>spring</servlet-name>
 <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
 </servlet>
 <servlet-mapping>
 <servlet-name>spring</servlet-name>
 <url-pattern>/</url-pattern>
 </servlet-mapping>

</web-app>

spring-servlet.xml

   <beans xmlns="http://www.springframework.org/schema/beans"
    xmlns:context="http://www.springframework.org/schema/context"
    xmlns:mvc="http://www.springframework.org/schema/mvc" 
    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    xsi:schemaLocation="
        http://www.springframework.org/schema/beans     
        http://www.springframework.org/schema/beans/spring-beans-3.0.xsd
        http://www.springframework.org/schema/context 
        http://www.springframework.org/schema/context/spring-context-3.0.xsd
        http://www.springframework.org/schema/mvc
        http://www.springframework.org/schema/mvc/spring-mvc-3.0.xsd">


        <context:component-scan
            base-package="siso.springrolls.controller" />

        <bean id="viewResolver"
            class="org.springframework.web.servlet.view.UrlBasedViewResolver">
            <property name="viewClass"
                value="org.springframework.web.servlet.view.JstlView" />
            <property name="prefix" value="/" />
            <property name="suffix" value=".html" />
        </bean>
    </beans>

控制器是:

@Controller
public class HomeController {

    @RequestMapping("/StartPage")
    public ModelAndView springContoller(){
        String message = "Hey welcome to Spring 3.0!! ";
        System.out.println("in controller");
        return new ModelAndView("StartPage","message",message);
    }
}

index.jsp

</head>
<body>
<a href="StartPage.html">Click here </a>
</body>
</html>

【问题讨论】:

  • 服务器日志中有错误信息吗?
  • 应该有一个嵌套异常或者另一个日志文件中的另一个错误(可能在tomcat的catalina.out中?)。你能找到吗?因为您粘贴的异常没有提供有关您的应用程序的任何详细信息。
  • C:\apache-tomcat-6.0.37\logs 文件夹为空。在单击“单击此处”进行重定向时,我在浏览器(和 Eclipse 控制台)上收到此错误
  • 找出服务器日志的位置。也许你直接从你的 IDE 运行它?检查 IDE 上的日志。
  • 日志中的某处:根本原因 java.lang.StackOverflowError javax.servlet.http.HttpServletRequestWrapper.getSession(HttpServletRequestWrapper.java:216) javax.servlet.http.HttpServletRequestWrapper.getSession(HttpServletRequestWrapper.java: 216) javax.servlet.http.HttpServletRequestWrapper.getSession(HttpServletRequestWrapper.java:216) javax.servlet.http.HttpServletRequestWrapper.getSession(HttpServletRequestWrapper.java:216)

标签: java xml spring spring-mvc servlets


【解决方案1】:

浪费了 5 个小时 :(

谁能告诉我为什么下面的代码不起作用:

 <property name="prefix" value="/WEB-INF/html/" />
        <property name="suffix" value=".html" />

但如果我将其更改为:

   <property name="prefix" value="/WEB-INF/jsp/" />
        <property name="suffix" value=".jsp" />

效果很好。修改后的目录结构为:

为什么它没有拾取 html 文件并抛出 在 DispatcherServlet 中找不到带有 URI... 的 HTTP 请求的映射 以及带有 JSP 的工作文件。

【讨论】:

    【解决方案2】:

    尝试更新那部分代码并尝试

     <servlet-mapping>
     <servlet-name>spring</servlet-name>
    
     //Use this 
     <url-pattern>/*</url-pattern>
    
    That is not correct
    <url-pattern>/</url-pattern>
    
     </servlet-mapping>
    

    更新

    也试试添加这个

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

    【讨论】:

    • 使用 /* 出现以下错误:org.springframework.web.servlet.PageNotFound noHandlerFound 警告:在 DispatcherServlet 中找不到带有 URI [/SpringRolls/index.jsp] 的 HTTP 请求的映射,名称为“spring”使用'/',它与 StartPage.jsp 一起工作正常
    【解决方案3】:

    这个问题是由于 spring jars 混淆造成的。我遇到了同样的问题。从 pom.xml 中删除了一些 jar 并且它起作用了。 这是我原来的 pom.xml 。使用 Spring 4 Hibernate 4 的基本项目

        <properties>
            <java-version>1.7</java-version>
            <org.springframework-version>4.0.3.RELEASE</org.springframework-version>
            <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
        </properties>
    
        <dependencies>
            <dependency>
                <groupId>junit</groupId>
                <artifactId>junit</artifactId>
                <version>3.8.1</version>
                <scope>test</scope>
            </dependency>
            <dependency>
                <groupId>org.springframework</groupId>
                <artifactId>spring-context</artifactId>
                <version>${org.springframework-version}</version>
            </dependency>
    
            <dependency>
                <groupId>org.springframework</groupId>
                <artifactId>spring-webmvc</artifactId>
                <version>${org.springframework-version}</version>
            </dependency>
            <dependency>
                <groupId>org.springframework</groupId>
                <artifactId>spring-orm</artifactId>
                <version>${org.springframework-version}</version>
                <type>jar</type>
                <scope>compile</scope>
            </dependency>
    
            <dependency>
                <groupId>org.hibernate</groupId>
                <artifactId>hibernate-core</artifactId>
                <version>4.3.5.Final</version>
            </dependency>
    
            <dependency>
                <groupId>javax.servlet</groupId>
                <artifactId>javax.servlet-api</artifactId>
                <version>3.1.0</version>
                <scope>provided</scope>
            </dependency>
    
            <dependency>
                <groupId>javax.servlet</groupId>
                <artifactId>servlet-api</artifactId>
                <version>2.5</version>
            </dependency>
    
    
    
            <dependency>
                <groupId>jstl</groupId>
                <artifactId>jstl</artifactId>
                <version>1.2</version>
            </dependency>
    
            <dependency>
                <groupId>com.oracle</groupId>
                <artifactId>ojdbc14</artifactId>
                <version>11.2.0.2.0</version>
            </dependency>
            <dependency>
                <groupId>commons-dbcp</groupId>
                <artifactId>commons-dbcp</artifactId>
                <version>1.4</version>
            </dependency>
    <dependency>
        <groupId>org.springframework</groupId>
        <artifactId>spring-web</artifactId>
        <version>4.1.6.RELEASE</version>
    </dependency>
    
    </dependencies>
    

    删除了下面的依赖,它工作正常

    <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-web</artifactId>
            <version>4.1.6.RELEASE</version>
        </dependency>
    

    更新答案:-

    添加网址映射:

     <url-pattern>/*</url-pattern>
    

    这应该可以完成工作。

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 2015-11-28
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2012-10-16
      • 2018-07-31
      • 2011-06-15
      • 1970-01-01
      相关资源
      最近更新 更多