【发布时间】:2026-01-14 08:15:01
【问题描述】:
<html>
<body>
<form action="add">
<input type="text" name="t1"><br>
<input type="text" name="t2"><br>
<input type="submit" />
</form>
</body>
</html>
Web.xml
<!DOCTYPE web-app PUBLIC
"-//Sun Microsystems, Inc.//DTD Web Application 2.3//EN"
"http://java.sun.com/dtd/web-app_2_3.dtd" >
<web-app>
<display-name>Archetype Created Web Application</display-name>
<servlet>
<servlet-name>telusko</servlet-name>
<servlet-class>
org.springframework.web.servlet.DispatcherServlet
</servlet-class>
</servlet>
<servlet-mapping>
<servlet-name>telusko</servlet-name>
<url-pattern>/</url-pattern>
</servlet-mapping>
telusko-servlet.xml
<?xml version="1.0" encoding="UTF-8"?>
<beans
xmlns="http://www.springframework.org/schema/beans"
xmlns:ctx="http://www.springframework.org/schema/context"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:mvc="http://www.springframework.org/schema/mvc"
xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans-2.5.xsd
http://www.springframework.org/schema/mvc
http://www.springframework.org/schema/mvc/spring-mvc-3.0.xsd
http://www.springframework.org/schema/context
http://www.springframework.org/schema/context/spring-context-2.5.xsd ">
<!-- <mvc:default-servlet-handler/> -->
<mvc:annotation-driven/>
<ctx:annotation-config></ctx:annotation-config>
<ctx:component-scan base-package="resources.com.telusko"></ctx:component-scan>
</beans>
AddController.java
package com.telusko;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
@Controller
public class AddController {
@RequestMapping("/add")
public void add() {
System.out.println("i am here");
}
}
我有一个 index.jsp 文件,我在其中声明 action=/add。现在在 web.xml 中声明一个调度程序,在其中给定 servlet 名称登录。之后制作一个 telusko-servlet.xml,其中定义基本包:
<ctx:component-scan base-package="com.telusko"></ctx:component-scan>
之后创建一个logincontroller类,并使用logincontroller类上面的注解@Controller和@RequestMapping("/add)上面的方法。之后运行 index.jsp 文件仍然给我错误,为什么noHandlerFound 错误发生在 login-servlet.xml 中。我在 AddController.java 文件所在的位置给出了基本包名称 com.telusko。
我应该在控制台上收到 “我在这里” 消息,但没有收到它,而不是收到 WARNING: No mapping found for HTTP request
Sep 26, 2018 10:47:36 PM org.springframework.web.servlet.DispatcherServlet
initServletBean
INFO: FrameworkServlet 'telusko': initialization started
Sep 26, 2018 10:47:36 PM
org.springframework.web.context.support.XmlWebApplicationContext
prepareRefresh
INFO: Refreshing WebApplicationContext for namespace 'telusko-servlet':
startup date [Wed Sep 26 22:47:36 IST 2018]; root of context hierarchy
Sep 26, 2018 10:47:36 PM
org.springframework.beans.factory.xml.XmlBeanDefinitionReader
loadBeanDefinitions
INFO: Loading XML bean definitions from ServletContext resource [/WEB-
INF/telusko-servlet.xml]
Sep 26, 2018 10:47:38 PM org.springframework.web.servlet.DispatcherServlet
initServletBean
INFO: FrameworkServlet 'telusko': initialization completed in 2096 ms
Sep 26, 2018 10:47:38 PM org.apache.catalina.core.StandardWrapperValve
invoke
SEVERE: Servlet.service() for servlet [telusko] in context with path
[/DemoMVC] threw exception [Servlet execution threw an exception] with root
cause
java.lang.NoSuchMethodError:
org.springframework.http.HttpMethod.resolve(Ljava/lang/String;)
Lorg/springframe
ork/http/HttpMethod;
at
org.springframework.web.servlet.FrameworkServlet.service
(FrameworkServlet.java:8
41)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:741)
at
org.apache.catalina.core.ApplicationFilterChain.internalDoFilter
(ApplicationFilterChain.java:231)
at
org.apache.catalina.core.ApplicationFilterChain.doFilter
(ApplicationFilterChain.java:166)
at org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:53)
at
org.apache.catalina.core.ApplicationFilterChain.internalDoFilter
(ApplicationFilterChain.java:193)
at
org.apache.catalina.core.ApplicationFilterChain.doFilter
(ApplicationFilterChain.java:166 at
org.apache.catalina.core.StandardWrapperValve.invoke
(StandardWrapperValve.java:199)at
org.apache.catalina.core.StandardContextValve.invoke
(StandardContextValve.java:96)at
org.apache.catalina.authenticator.AuthenticatorBase.invoke
(AuthenticatorBase.jav
a:490)
at
org.apache.catalina.core.StandardHostValve.invoke
(StandardHostValve.java:139)
at
org.apache.catalina.valves.ErrorReportValve.invoke
(ErrorReportValve.java:92)
at
org.apache.catalina.valves.AbstractAccessLogValve.invoke
(AbstractAccessLogValve.
java:668)
at
org.apache.catalina.core.StandardEngineValve.invoke
(StandardEngineValve.java:74)
at
org.apache.catalina.connector.CoyoteAdapter.service
(CoyoteAdapter.java:343)
at
org.apache.coyote.http11.Http11Processor.service
(Http11Processor.java:408)at
org.apache.coyote.AbstractProcessorLight.process
(AbstractProcessorLight.java:66)at
org.apache.coyote.AbstractProtocol$ConnectionHandler.process
(AbstractProtocol.ja
va:770)at
org.apache.tomcat.util.net.NioEndpoint$SocketProcessor.doRun
(NioEndpoint.java:1415)at
org.apache.tomcat.util.net.SocketProcessorBase.run
(SocketProcessorBase.java:49)
at java.util.concurrent.ThreadPoolExecutor.runWorker(Unknown Source)
at java.util.concurrent.ThreadPoolExecutor$Worker.run(Unknown Source)
at
org.apache.tomcat.util.threads.TaskThread$WrappingRunnable.run
(TaskThread.java:61)
at java.lang.Thread.run(Unknown Source)
【问题讨论】:
-
base-package="resources.com.telusko"看起来不对。当你的基本包只是com.telusko时,为什么resources在里面? -
我首先尝试使用 com.telusko,但它不起作用,然后我将其更改为 resource.com.telusko。
-
在控制台上出现此错误 信息:FrameworkServlet 'telusko':初始化在 2501 毫秒内完成 2018 年 9 月 26 日上午 1:06:55 org.springframework.web.servlet。 PageNotFound noHandlerFound WARNING: No mapping found for HTTP request with URI [/DemoMVC/add] in DispatcherServlet with name 'telusko'
-
我应该在 INFO 之后收到 “我在这里” 消息:FrameworkServlet 'telusko':初始化在 2501 毫秒内完成
-
@Prashant Singh 我在我的项目中遇到了这个错误。你找到解决这个问题的方法了吗?
标签: java spring spring-mvc servlets