SpringMVC-03
一、Controller配置总结
控制器Controller
- 控制器复杂提供访问应用程序的行为,通常通过接口定义或者注解两种方法实现.
- 控制器负责解析用户请求并将其转换为一个模型
- 在Spring MVC中一个控制器类可以包含多个方法
- 在Spring MVC中,对于Controller的配置有很多种
Controller是一个接口,位于org.springframework.web.servlet包下,只有一个方法
1.基于接口实现Controller
代码实现
1.先把模块定义为web项目
2.在Project Structure 的Artifacts找到当前的模块
新建一个文件夹,将各种依赖导入
3.配置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">
<servlet>
<servlet-name>springmvc</servlet-name>
<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
<init-param>
<param-name>contextConfigLocation</param-name>
<param-value>classpath:springmvc-servlet.xml</param-value>
</init-param>
<load-on-startup>1</load-on-startup>
</servlet>
<servlet-mapping>
<servlet-name>springmvc</servlet-name>
<url-pattern>/</url-pattern>
</servlet-mapping>
</web-app>
4.配置springmvc-servlet.xml文件
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
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.xsd">
<bean class="org.springframework.web.servlet.handler.BeanNameUrlHandlerMapping"/>
<bean class="org.springframework.web.servlet.mvc.SimpleControllerHandlerAdapter"/>
<bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">
<property name="prefix" value="/WEB-INF/jsp/"/>
<property name="suffix" value=".jsp"/>
</bean>
<bean id="/t1" class="com.Liang.controller.ControllerDemo01"/>
</beans>
- 配置Controller
package com.Liang.controller;
import org.springframework.web.servlet.ModelAndView;
import org.springframework.web.servlet.mvc.Controller;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
public class ControllerDemo01 implements Controller {
@Override
public ModelAndView handleRequest(HttpServletRequest httpServletRequest, HttpServletResponse httpServletResponse) throws Exception {
ModelAndView mv = new ModelAndView();
mv.addObject("msg","你好");
mv.setViewName("test");
return mv;
}
}
6.jsp页面编写
7. 启动Tomcat测试
说明:
- 实现接口Controller
- 定义控制器是一个古老的方式
- 缺点: 一个控制器只有一个方法,如果要多个方法则需定义多个Controller,定义方式比较麻烦
- 实现接口需要绑定控制器,因为bean的ID唯一,所以一个url对应一个控制器,不用来实现RestFul功能
2.基于注解实现Controller
@Controller注解类型用于声明Spring类的实例是一个控制器
web.xml一样,需配置springmvc-servlet.xml
<?xml version="1.0" encoding="UTF-8"?>
<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">
<!-- 自动扫描包,该包下注解有效-->
<context:component-scan base-package="com.Liang.controller1"/>
<!-- 过滤静态资源-->
<mvc:default-servlet-handler/>
<!-- 注解驱动-->
<mvc:annotation-driven/>
<!-- 开启注解模式-->
<!-- <bean class="org.springframework.web.servlet.handler.BeanNameUrlHandlerMapping"/>-->
<!-- <bean class="org.springframework.web.servlet.mvc.SimpleControllerHandlerAdapter"/>-->
<bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">
<property name="prefix" value="/WEB-INF/jsp/"/>
<property name="suffix" value=".jsp"/>
</bean>
<!-- <bean id="/t1" class="com.Liang.controller.ControllerDemo01"/>-->
<!-- <bean id="/t2" class="com.Liang.controller.ControllerDemo02"/>-->
</beans>
和一个实现Controller注解的类
package com.Liang.controller1;
import org.springframework.stereotype.Controller;
import org.springframework.ui.Model;
import org.springframework.web.bind.annotation.RequestMapping;
@Controller
@RequestMapping("/cd")
public class ControllerDemo03 {
@RequestMapping("/h")
public String sayHello(Model model)
{
model.addAttribute("msg","狗子");
System.out.println("你好呀");
return "test02";
}
@RequestMapping("/h1")
public String sayHello1(Model model)
{
model.addAttribute("msg","喵咪");
return "test02";
}
}
说明
可以发现,我们的两个请求都可以指向一个视图,但是页面结果的结果是不一样的,从这里可以看出视图是被复用的,而控制器与视图之间是弱偶合关系。
RequsetMapping的使用
@RequesetMapping
- @RequstMapping注解用于映射url到控制器类或一个特定的处理程序方法
RequestMapping注解有@Target({ElementType.Type,ElementType.METHOD})
可以知道该注解可以用在类或方法中,用到类上,表示该地址为父路径
只注解到方法上面
@Controller
public class TestController {
@RequestMapping("/h1")
public String test(){
return "test";
}
}
访问路径:http://localhost:8080 / 项目名 / h1
同时注解类与方法
@Controller
@RequestMapping("/admin")
public class TestController {
@RequestMapping("/h1")
public String test(){
return "test";
}
}
访问路径:http://localhost:8080 / 项目名/ admin /h1 , 需要先指定类的路径再指定方法的路径;