文章目录

  • Controller配置
  • 控制器Controller
  • 参数传递(View to Controller)
  • @RequestParam
  • @RequestMapping
  • 参数传递(Controller to View)
  • ModelAndView
  • Model
  • 数据处理


Controller配置

使用SpringMVC,必须配置以下信息:

  • 处理器映射器
<bean class="org.springframework.web.servlet.handler.BeanNameUrlHandlerMapping"/>
  • 处理器适配器
<bean class="org.springframework.web.servlet.mvc.SimpleControllerHandlerAdapter"/>

or

  • 注解驱动(如果使用注解来实现Spring MVC,可以不用处理器映射器和处理器适配器)
<mvc:annotation-driven/>
  • 视图解析器(必要)
<bean id="InternalResourceViewResolver" class="org.springframework.web.servlet.view.InternalResourceViewResolver">
    <property name="prefix" value="/WEB-INF/jsp/"/>
    <property name="suffix" value=".jsp"/>
</bean>

控制器Controller

控制器复杂提供访问应用程序的行为,通常通过接口定义或注解定义两种方法实现。 控制器负责解析用户的请求并将其转换为一个模型。在Spring MVC中一个控制器类可以包含多个方法。

在SpringMVC中,对于Controller的配置方式有很多种:

1.控制器实现方式:实现Controller接口

实现接口Controller定义控制器是较老的办法,缺点是:一个控制器中只有一个方法,如果要多个方法则需要定义多个Controller;定义的方式比较麻烦。

参数传递(View to Controller)

2.使用注解@Controller定义控制器

@Controller注解类型用于声明Spring类的实例是一个控制器(在讲IOC时还提到了另外3个注解);

Spring可以使用扫描机制来找到应用程序中所有基于注解的控制器类,为了保证Spring能找到你的控制器,需要在配置文件中声明组件扫描。

<!-- 自动扫描指定的包,下面所有注解类交给IOC容器管理 -->
<context:component-scan base-package="cn.kgc.kb03.servlet"/>

用注解实现:

@Controller //使用注解定义控制器,注解的类会自动添加到Spring上下文中
    @RequestMapping("/login")  //映射包
    public class LoginServlet{

    Logger log=Logger.getLogger(LoginServlet.class);

    @RequestMapping(value = "/loginServlet") //映射访问路径
    public void login(@RequestParam(value = "name",required = false) String name,
                      @RequestParam(value = "password",required = false) String password){
        System.out.println("这儿是控制器");
        System.out.println(name+","+password);
    }
}
@RequestParam

Controller方法中参数前加@RequestParam进行直接入参,指定其对应的请求参数。

  • value 参数名
  • required 是否必需
  • defaultValue 默认参数名,不推荐使用
@RequestMapping

@RequestMapping注解用于映射url到控制器类或一个特定的处理程序方法,它负责将不同的请求映射到对应的控制器方法上。

  1. 只注解在方法上面
    参考上面的代码,如果@RequestMapping直接注解在方法上面,那么访问路径为:
    访问路径:http://localhost:8080/项目名//loginServlet
  2. 同时注解类与方法
    访问路径:http://localhost:8080/项目名/login/loginServlet , 需要先指定类的路径再指定方法的路径。
// 注意这里的映射规则
    @RequestMapping(value = "/turn",method = RequestMethod.POST,params = "userCode")

映射规则

  • 通过请求URL进行映射
  • 通过请求参数进行映射
  • 若选择方法参数直接入参的话,方法入参名必须与请求中参数名保持一致
  • 通过请求方法进行映射
  • GET
  • POST

参数传递(Controller to View)

ModelAndView

包含视图信息和模型数据信息

常用方法

  • 添加模型数据
    ModelAndView addObject(String attributeName, Object attributeValue)ModelAndView addAllObjects(Map<String,?> modelMap)
  • 设置视图
    void setView(View view)void setViewName(String viewName)
/**
     * 参数传递:controller to view-(ModelAndView)
     * @param userCode
     * @return
     */
    @RequestMapping(value = "/turn",method = RequestMethod.POST,params = "userCode")
    public ModelAndView hello(@RequestParam String userCode){
        ModelAndView mav=new ModelAndView();
        log.info("登入成功:userCode"+userCode);
        mav.addObject("userCode",userCode);
        mav.setViewName("success");
        return mav;
    }

结果跳转方式:

设置ModelAndView对象,根据View名称,和视图解析器,跳转到指定的页面;

页面 :{视图解析器的前缀} + viewName + {视图解析器的后缀}

Model

除了可以使用ModelAndView对象来返回模型数据之外,还可以使用Spring MVC提供的Model对象来完成模型数据的传递。

  • 数据结构:Map类型
  • 常用方法:添加模型数据
    Model.addAttribute(String attributeName,Object attributeValue)
/**
     * 参数传递:controller to view-(Model)
     * @param username
     * @param model
     * @return
     */
    @RequestMapping(value = "/commit",method = {RequestMethod.GET})
    public String index(String username,Model model){
        //Spring MVC会自动实例化一个Model对象用于向视图中传值
        model.addAttribute("username", "username");
        //返回视图位置
        return "index";
    }

数据处理

处理前端传递过来的数据

  1. 名字规范的数据
@RequestMapping("/hello")
//请求参数名和处理参数名一样的情况下,我们直接接收到前端传递的数据;
//Model主要作用:为了给前端传递我们封装好的参数;
public String hello(String name, Model model){
    System.out.println(name);
    model.addAttribute("aaa",name);
    return "user";
}
  1. 名字不规范的数据
//请求参数名和处理参数名不一样的情况下
//状况:用户传递的参数名和我们要处理的参数名不一致,需要使用一个注解@RequestParam("username")来进行匹配
@RequestMapping("/hello2")
public String hello2(@RequestParam(value = "username",required = false) String name){
    System.out.println(name);
    return "user";
}
  1. 传递对象
    尽量规范的编程:提交表单的数据和对象的属性名一致
//如何传递一个对象
//要求:提交表单的数据和对象的属性名一致;参数直接使用对象即可;否则按照上面方式处理
//http://localhost:8080/mvc04/hello3?id=1&username=Theshy&password=123456;
@RequestMapping("/hello3")
public String hello3(User user,Model model){
    System.out.println(user);
    model.addAttribute("user",user);
    return "user";
}