1.新建web项目
2.导入相关jar包
3.编写web.xml,注册DispatcherServlet
4.编写springmvc配置文件
5.创建对应控制类,controler
6.最后完善前端视图和controller直接的对应
7.测试运行调试
web.xml
<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns="http://xmlns.jcp.org/xml/ns/javaee"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee http://xmlns.jcp.org/xml/ns/javaee/web-app_4_0.xsd"
version="4.0">
<!--1.注册Servlet-->
<servlet>
<servlet-name>SpringMVC</servlet-name>
<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
<!--通过初始化参数指定SpringMVC配置文件的位置,进行关联-->
<init-param>
<param-name>contextConfigLocation</param-name>
<param-value>classpath:springmvc-04-anno.xml</param-value>
</init-param>
<!--启动顺序,数值越小,启动越早-->
<load-on-startup>1</load-on-startup>
</servlet>
<!--所有的请求都会被springmvc拦截-->
<servlet-mapping>
<servlet-name>SpringMVC</servlet-name>
<url-pattern>/</url-pattern>
</servlet-mapping>
</web-app>
springmvc配置文件
<?xml version="1.0" encoding="UTF-8" ?>
<!--4.编写SpringMVC的配置文件!名称:springmvc-servlet.xml:[servletname]-servlet.xml!
说明,这里的名称要求是按照官方来的-->
<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"
xsi:schemaLocation="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.xsd
http://www.springframework.org/schema/mvc
http://www.springframework.org/schema/mvc/spring-mvc.xsd">
<!--自动扫描包,让指定包下的注解生效,由IOC容器统一管理-->
<context:component-scan base-package="com.kpp.controller"></context:component-scan>
<!--让springMVC不处理静态资源-->
<mvc:default-servlet-handler></mvc:default-servlet-handler>
<!--
支持mvc注解驱动
在spring中一般采用@RequestMapping注解来完成映射关系
要想使@RequestMapping注解生效
必须向上下文中注册DefaultAnnotationHandlerMapping
和一个AnnotationMethodHandlerAdapter实例
这两个实例分别在类级别和方法级别处理
而annotation-driven配置帮助我们自动完成上述两个实例的注入
-->
<mvc:annotation-driven></mvc:annotation-driven>
<!--视图解析器-->
<bean class="org.springframework.web.servlet.view.InternalResourceViewResolver" id="InternalResourceViewResolver">
<!--前缀-->
<property name="prefix" value="/WEB-INF/jsp/"></property>
<!--后缀-->
<property name="suffix" value=".jsp"></property>
</bean>
</beans>
controller类
package com.kpp.controller;
import org.springframework.stereotype.Controller;
import org.springframework.ui.Model;
import org.springframework.web.bind.annotation.RequestMapping;
@Controller
//@RequestMapping("HelloController")
public class HelloController {
@RequestMapping("/hello")
public String hello(Model model){
//封装数据
model.addAttribute("msg","hello,spring mvc by annocation");
return "hello";//会被视图解析器处理
}
}
使用springMVC必须配置的三大件
处理器映射器,处理器适配器,视图解析器
通常,我们只需要手动配置视图解析器,而处理器映射器和处理器适配器只需要开启注解驱动即可,
而省去了大段的xml配置
controller配置总结
SpringMVC数据处理
SpringMVC结果跳转方式
SpringMVC:Controller及Restful风格
SpringMVC:Controller及Restful风格
控制器Controller
*控制器负责提供访问应用程序的行为,通常通过接口定义或注解定义两种方法实现。
*控制器负责解析用户的请求并将其转换为一个模型。
*在SpringMVC中一个控制器类可以包含多个方法
*在SpringMVC中,对于controller的配置方式有很多种
方式如下:
实现Controller接口
//Controller是一个接口,在org.springframework.web.servlet.mvc包下,接口中只有一个方法;
//只有实现了Controller的类,这就是个控制器
public class ControllerDemo1 implements Controller {
@Override
public ModelAndView handleRequest(HttpServletRequest httpServletRequest, HttpServletResponse httpServletResponse) throws Exception {
ModelAndView mav = new ModelAndView();
mav.addObject("msg","controller test1");
mav.setViewName("hello");
return mav;
}
}
然而,实现接口Controller定义控制器是较老的办法
缺点是:一个控制器中只有一个方法,如果要多个方法则需要定义多个Controller;定义的方法比较麻烦;
使用注解@Controller
*@Controller注解类型用于声明Spring类的实例是一个控制器(在讲IOC时还提到了另外3个注解);
*Spring可以使用扫描机制来找到应用程序中所有基于注解的控制器类,为了保证Spring能找到你的控制器,需要在配置文件中声明组件扫描。
@Component
@Service
@Controller
@Repository
<context:component-scan base-package="com.kpp.controller"></context:component-scan>
增加一个controllerDemo2类,使用注解实现:
package com.kpp.controller;
import org.springframework.stereotype.Controller;
import org.springframework.ui.Model;
import org.springframework.web.bind.annotation.RequestMapping;
@Controller//代表这个类会被spring接管
public class ControllerDemo2 {
@RequestMapping("t2")
public String test1(Model model){
model.addAttribute("msg","2021/5/21");
return "hello";//return+controller注解返回视图解析器
}
@RequestMapping("t3")
public String test2(Model model){
model.addAttribute("msg","2021/5/24");
return "hello";//return+controller注解返回视图解析器
}
//使用同一个jsp页面
}
RequestMapping说明
@RequestMapping
*@RequestMapping注解用于映射url到控制器类或一个特定的处理程序方法。可用于类或方法上。
用于类上,表示类中的所有响应请求的方法都是以该地址作为父路径。
*为了测试结论更加准确,我们可以加上一个项目名测试myweb
*只注解在方法上面
@Controller
public class ControllerDemo3 {
@RequestMapping("/t1")
public String test1(Model model){
model.addAttribute("msg","ControllerDemo3");
return "hello";
}
}
访问路径:http://localhost:8080/项目名/h1
同时注解类与方法
@Controller
@RequestMapping("/c3")
public class ControllerDemo3 {
@RequestMapping("/t1")
public String test1(Model model){
model.addAttribute("msg","ControllerDemo3");
return "hello";
}
}
@Controller
public class RestfulController {
@RequestMapping("/add/{a}/{b}")
public String test1(@PathVariable int a,@PathVariable int b, Model model){
int res = a+b;
model.addAttribute("msg","结果为:"+res);
return "hello";
}
}