2

我是 Spring 框架的新手。我想开发一个简单的 web 应用程序,它显示基于 url“/greeting.html”的 hello.jsp 内容。但现在,它给了我 404 错误。我究竟做错了什么?

这是我的项目的 github repo(这个项目是在 Eclipse STS 下创建的):https ://github.com/terancet/EventTracker

这是我的 HelloController 类

@Controller
public class HelloController {
    @RequestMapping(value = "/greeting")
    public String sayHello(Model model) {
        model.addAttribute("greeting", "Hello World");

        return "hello.jsp";
    }

}

这是 web.xml

<servlet>
        <servlet-name>springDispatcherServlet</servlet-name>
        <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>

        <init-param>
            <param-name>contextClass</param-name>
            <param-value>org.springframework.web.context.support.AnnotationConfigWebApplicationContext</param-value>
        </init-param>


        <init-param>
            <param-name>contextConfigLocation</param-name>
            <param-value>com.pluralsight.WebConfig</param-value>
        </init-param>
        <load-on-startup>1</load-on-startup>
    </servlet>

    <!-- Map all requests to the DispatcherServlet for handling -->
    <servlet-mapping>
        <servlet-name>springDispatcherServlet</servlet-name>
        <url-pattern>*.html</url-pattern>
    </servlet-mapping>

这是一个项目结构:

项目结构

4

3 回答 3

1

在你的WebConfig你有以下

@Bean
public InternalResourceViewResolver getInternalResourceViewResolver() {
    InternalResourceViewResolver resolver = new InternalResourceViewResolver();

    resolver.setPrefix("/WEB-INF/jsp/");
    resolver.setSuffix(".jsp");

    return resolver;
}

您的控制器正在返回hello.jp。这被传递InternalResourceViewResolver给要解析的视图。它将创建一条路径,/WEB-INF/jsp/hello.jsp.jsp然后转发到该路径。

首先让你的控制器返回hello而不是hello.jsp. 其次在目录中创建一个jsp目录WEB-INF并将您的移动hello.jsp到那里。第三次重启。

于 2015-06-22T06:07:45.973 回答
1

将 log4j.xml 或 log4j.properties 添加到

源/主/资源

文件夹(将自动检测到)。然后,当您启动服务器时,它会通过 info log 准确地告诉您控制器的 url 映射在哪里。这不仅要验证映射 url,而且要确保它确实被映射,这一点很重要:

此外,如果您在 STS/Eclipse 中:

right click on the project -> click properties -> click select 'Web Project Settings' 

在此处输入图像描述

默认情况下,这是派生 url 路径的地方。因此,如果其中的上下文根值是:“EventTracker”,那么您的完整 url 请求将是(假设设置了“.jsp”后缀,正如其他人在您的解析器中所指出的那样):

http://localhost/EventTracker/问候

我的 1 个项目中的示例 log4j.xml:

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE log4j:configuration PUBLIC "-//APACHE//DTD LOG4J 1.2//EN" "log4j.dtd">
<log4j:configuration xmlns:log4j="http://jakarta.apache.org/log4j/"> 

    <!-- Appenders -->
    <appender name="console" class="org.apache.log4j.ConsoleAppender">
        <layout class="org.apache.log4j.PatternLayout">
           <param name="ConversionPattern" value="%-5p:%d{yyyyMMdd HH:mm:ss} %t %c - %m%n"/>
        </layout>
    </appender>

    <appender name="fileAppender" class="org.apache.log4j.FileAppender">
       <param name="File" value="c:/tmp/my-app.log"/>
       <param name="MaxFileSize" value="10MB"/>
       <param name="MaxBackupIndex" value="50"/>

       <layout class="org.apache.log4j.PatternLayout">
            <param name="ConversionPattern" value="%-5p:%d{yyyyMMdd HH:mm:ss} %t %c - %m%n" />
        </layout>
    </appender>

    <!-- 3rdparty Loggers -->
    <logger name="org.springframework.core">
        <level value="info" />
    </logger>

    <logger name="org.springframework.beans">
        <level value="info" />
    </logger>

    <logger name="org.springframework.context">
        <level value="info" />
    </logger>

    <logger name="org.springframework.web">
        <level value="debug" />
    </logger>

    <logger name="org.springframework.webflow">
        <level value="debug" />
    </logger> 


    <!-- Root Logger -->
    <root>
        <priority value="info" />
        <appender-ref ref="console" />
        <appender-ref ref="fileAppender"/>
    </root>


</log4j:configuration> 

日志信息:

INFO : org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerMapping - Mapped "{[/userManagement/getUser],methods=[GET],params=[],headers=[],consumes=[],produces=[],custom=[]}" onto public org.assessme.com.entity.User org.assessme.com.controller.UserManagementController.data(java.util.Locale,org.springframework.ui.Model)
于 2015-06-24T14:55:29.263 回答
0

它可能是应用程序名称中的拼写错误。请尝试 localhost:8080/ Event t Tracker/greeting - EventTracker with Event t

并尝试将 url-pattern 更改为 /*

于 2015-06-21T11:51:01.763 回答