• Spring MVC @Controller和@RequestMapping注解


    @Controller 注解

    @Controller 注解可以将一个普通的 Java 类标识成控制器(Controller)类,示例代码如下。

    1. package net.biancheng.controller;
    2. import org.springframework.stereotype.Controller;
    3. @Controller
    4. public class IndexController {
    5. // 处理请求的方法
    6. }

    Spring MVC 是通过组件扫描机制查找应用中的控制器类的,为了保证控制器能够被 Spring MVC 扫描到,我们还需要在 Spring MVC 的配置文件中使用  标签,指定控制器类的基本包(请确保所有控制器类都在基本包及其子包下),示例代码如下

    1. <context:component-scan base-package="net.biancheng.controller" />

    @RequestMapping 注解

    @RequestMapping 注解是 Spring MVC 中最常被用到的注解之一。它通常被标注在控制器方法上,负责将请求与处理请求的控制器方法关联起来,建立映射关系。

    Spring MVC 的前端控制器(DispatcherServlet)拦截到用户发来的请求后,会通过 @RequestMapping 注解提供的映射信息找到对应的控制器方法,对这个请求进行处理。

    @RequestMapping 注解的使用方式

    @RequestMapping 既可以标注在控制器类上,也可以标注在控制器方法上。

    1. 修饰方法

    当 @RequestMapping  注解被标注在方法上时,value 属性值就表示访问该方法的 URL 地址。当用户发送过来的请求想要访问该 Controller 下的控制器方法时,请求路径就必须与这个 value 值相同,示例代码如下

    1. @Controller
    2. public class HelloController {
    3. @RequestMapping("/login")
    4. public String welcome() {
    5. return "login";
    6. }
    7. }
    2. 修饰类

    当 @RequestMapping 注解标注在控制器类上时,value 属性的取值就是这个控制器类中的所有控制器方法 URL 地址的父路径。也就是说,访问这个 Controller 下的任意控制器方法都需要带上这个父路径。

    1. @Controller
    2. @RequestMapping(value = "/springmvc")
    3. public class HelloController {
    4. @RequestMapping("/login")
    5. public String welcome() {
    6. return "login";
    7. }
    8. }

    在上面的控制类中,用户想要访问 HelloController 中的 welcome() 方法,请求的地址就必须带上父路径“/springmvc”,即请求地址必须为“/springmvc/login”。

    @RequestMapping 注解的属性

    @RequestMapping 注解中提供了多个可用属性,下面我们就对其中几个比较常用的属性进行介绍。

    1. value 属性

    在 @RequestMapping 注解中,value 属性用来设置控制器方法的请求映射地址。所有能够匹配到该请求映射地址的请求,都可以被该控制器方法处理,示例代码如下。

    @RequestMapping(value = "/register")

    value 属性是 @RequestMapping 注解的默认属性,如果我们在 @RequestMapping 注解中只设置了一个 value 属性,则该属性名可以被省略。value 属性的取值是一个字符串类型的数组,表示该控制器方法可以匹配多个请求地址

    1. @RequestMapping( value = {"/register", "/login"})
    2. public String success() {
    3. return "success";
    4. }
    2. name 属性

    name 属性相当于方法的注释,用于解释这个方法是用来干什么的,使方法更易理解。

    例如,下面的代码表示 getUsers() 方法是一个用来获取用户信息的控制器方法。

    1. @RequestMapping(value = "toUser",name = "获取用户信息")
    2. public String getUsers() {
    3. ……
    4. }
    3. method 属性

    method 属性用来设置控制器方法支持的请求方式。如果一个控制器方法没有设置 @RequestMapping 注解的 method 属性,则说明该控制器方法支持全部请求类型,可以处理所有类型的请求。
    method 属性的取值是一个 RequestMethod 类型的数组,表示一个控制器方法支持多种方式的请求,常用的请求方式有 GET、POST、DELETE、PUT 等。

    例如,控制器方法只支持 GET 方式的请求,代码如下。

    @RequestMapping(value = "/toUser",method = RequestMethod.GET)

     我们也可以为同一个控制器方法指定支持多种类型的请求。例如,一个方法既支持 GET 方式的请求,也支持 POST 方式的请求,代码如下。

    @RequestMapping(value = "/toUser",method = {RequestMethod.GET,RequestMethod.POST})
    4. params 属性

    params 属性用于指定请求中的参数,只有当请求中携带了符合条件的参数时,控制器方法才会对该请求进行处理。

    序号表达式含义
     "param"请求中必须携带名为 param 的参数
    "!param"与表达式 ① 的含义完全相反,请求中不能携带名为 param 的参数
    "param=value"请求中必须携带名为 param 的参数,且参数的取值必须为:value
    "param!=value"与表达式 ③ 的含义完全相反,请求中不能携带参数:param = value。

    params 属性的取值是一个字符串类型的数组,表示只有请求中同时携带了 params 属性指定的全部参数时,控制器方法才会对该请求进行处理。
    例如

    1. @RequestMapping(value = "/testParam", params = {"name=zhang", "age=23"})
    2. @ResponseBody
    3. public String testParam() {
    4. return "success";
    5. }

    以上代码表示,只有当请求中同时携带 name 和 age两个请求参数,且参数值必须分别为 “zhang” 和“23”时,控制器方法 testParam() 才会对该请求进行处理 。

    5. headers 属性

    headers 属性用于设置请求中请求头信息,只有当请求中携带指定的请求头信息时,控制器方法才会处理该请求。

    序号表达式含义
     "header"请求必须携带请求头信息:header 
    "!header"与表达式 ①  的含义完全相反,请求中不能携带请求头信息:header
    "header=value"请求中必须携带请求头信息:header=value 。
    "header!=value"与表达式 ③ 的含义完全相反,请求中不能携带请求头信息:header=value。

    header 属性是一个字符换类型的数组,表示只有当请求同时携带数组中规定的所有头信息时,控制器方法才会对该请求进行处理。 只有当请求的头Referer信息中包含相关内容才会处理该请求。

  • 相关阅读:
    Flask框架——Flask-SQLite数据库
    563页30万字智慧化工园区(一期)总体设计方案
    GBASE南大通用亮相第六届世界智能大会
    python二次开发CATIA:自动出工程图
    yolov3原理记录
    常见语言的hashmap实现方法
    ▶《强化学习的数学原理》(2024春)_西湖大学赵世钰 Ch0 一张图讲完强化学习原理
    《Python编程无师自通》读书笔记
    Dive into TensorFlow系列(2)- 解析TF核心抽象op算子
    YARN功能介绍、交互流程及调度策略
  • 原文地址:https://blog.csdn.net/qq_43079001/article/details/132684606