2012-07-09 16 views
8

これはおそらく、このSpring MVCエラーについての百万分の一の質問ですが、まだ動作させることはできません。HTTPリクエスト(Spring MVC)のマッピングが見つかりません

私は単純なコントローラメソッドを/ accountにマッピングしようとしていますが、後で/ account/{id}を追加したいのですが、アカウントを取得することさえできません。

<mvc:annotation-driven /> 
<context:component-scan base-package="org.example" /> 

<bean id="viewResolver" class="org.springframework.web.servlet.view.InternalResourceViewResolver"> 
    <property name="prefix" value="/views/"/> 
    <property name="suffix" value=".jsp"/> 
</bean> 

AccountController.java:

@Controller 
public class AccountController { 

    @RequestMapping(value="/account", method = RequestMethod.GET) 
    public ModelAndView showAccount() throws Exception { 
     ModelAndView mav = new ModelAndView(); 
     mav.setViewName("account"); 
     mav.addObject("someText", "Hello World!"); 
     return mav; 
    } 
} 

のsrc /メイン/ webappsに/ここで

は私のweb.xmlは、アプリケーションのcontext.xmlの

<?xml version="1.0" encoding="ISO-8859-1" ?> 

<web-app xmlns="http://java.sun.com/xml/ns/j2ee" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" 
    xsi:schemaLocation="http://java.sun.com/xml/ns/j2ee http://java.sun.com/xml/ns/j2ee/web-app_2_4.xsd" 
    version="2.4"> 

    <display-name>My Spring MVC web application</display-name> 

    <listener> 
     <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class> 
    </listener> 

    <servlet> 
     <servlet-name>springDispatcherServlet</servlet-name> 
     <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class> 
     <init-param> 
      <param-name>contextConfigLocation</param-name> 
      <param-value>classpath:application-context.xml</param-value> 
     </init-param> 
     <load-on-startup>1</load-on-startup> 
    </servlet> 

    <servlet-mapping> 
     <servlet-name>springDispatcherServlet</servlet-name> 
     <url-pattern>/*</url-pattern> 
    </servlet-mapping> 

    <context-param> 
     <param-name>contextConfigLocation</param-name> 
     <param-value>classpath:application-context.xml</param-value> 
    </context-param> 
</web-app> 

内容ですviews/account.jsp:

<%@ page contentType="text/html;charset=UTF-8" language="java" %> 
<%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %> 

<h1>${someText}</h1> 

私はTomcatの中でアプリケーションを起動すると、私は次の行がログに表示されます参照してください。

[localhost-startStop-1] INFO org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerMapping - Mapped "{[/account], methods=[GET], params=[],headers=[],consumes=[],produces=[],custom=[]}" onto public org.springframework.web.servlet.ModelAndView org.example.springmvc.controller.AccountController.showAccount() throws java.lang.Exception 

私には、URLのlocalhostを示唆している:8080 /アカウントが適切にマップされ、少なくともいくつかを与える必要があります出力。しかし、私がlocalhost:8080/accountにアクセスしたときに404エラーが発生し、ログに以下のようなメッセージが表示されます。

No mapping found for HTTP request with URI [/views/account.jsp] in DispatcherServlet with name 'springDispatcherServlet' 
No mapping found for HTTP request with URI [/favicon.ico] in DispatcherServlet with name 'springDispatcherServlet' 

あなたは大歓迎です。あなたのSpring構成と間違って何も/account URIが正しくお使いのコントローラによって処理されていると、それはビューを返しているように見える、存在しないアプリケーションのcontext.xml

<bean class="org.springframework.web.servlet.mvc.annotation.DefaultAnnotationHandlerMapping"/> 
<bean class="org.springframework.web.servlet.mvc.annotation.AnnotationMethodHandlerAdapter"/> 

答えて

4

に次の豆を追加

+0

まだ運がない私は恐れています。アプリケーションを起動すると、ログに余分な行が表示されます。 'accountController' マップされたURLパスがハンドラに[/account.*] 'accountController' マップされたURLパスハンドラへ[/アカウント/]ハンドラへのURLパス[/アカウント]マップされた 'accountController' しかし、私はに行きます/ account私のWebブラウザでは、同じタイプのメッセージを受け取ります: WARN http-apr-8080-exec-3 org.springframework.web.servlet.PageNotFound - URIを持つHTTPリクエストのマッピングが見つかりません[/ WEB- INF/views/account.jsp]の名前が 'springDispatcherServlet'であるDispatcherServlet – Julius

+4

私はそれを動作させました!やれやれ!最後に。 web.xmlのを/ *から/に変更しました。私はそれが現在動作している理由を理解していません。少なくとも私は満足しているプログラマーです。 – Julius

+0

こんにちは@Biju http://stackoverflow.com/questions/17697899/how-to-map-dynamic-url-http-127-0-0-18080-prj-noticeopen-2-inをご覧ください-spring-mvc-contこれは少し違っていますが、私はコントローラに到達していません –

4

てみてください名前accountが正しく、InternalViewResolverによって、/views/account.jspへのパスとして解決されています。

このディスパッチは間違っています(/*あなたのSpring DispatcherServletにマッピングされているため、Springがこの/ビューも処理できるという仮定があるため、おそらくこの特定のエラーが表示されます)。あなたは、この操作を行う代わりに、/viewsフォルダ内のビューを配置する、/WEB-INF/viewsフォルダに移動してのおviewresolverを変更することができます:私はまだ同じエラーを取得し

<bean id="viewResolver" class="org.springframework.web.servlet.view.InternalResourceViewResolver"> 
    <property name="prefix" value="/WEB-INF/views/"/> 
    <property name="suffix" value=".jsp"/> 
</bean> 
+0

.... – Julius

+0

は、おかげで私のエラーを修正しました! –

関連する問題