Spring MVC的核心类和注解——@RequestMapping注解(二)@RequestMapping注解的属性

一、@RequestMapping注解的属性

属性名

类型

描述

name

String

可选属性,用于为映射地址指定别名。

value

String[]

可选属性,也是默认属性,用于指定请求的URL。

method

RequestMethod[]

可选属性,用于指定该方法可以处理哪种类型的请求方式。

params

String[]

可选属性,用于指定客户端请求中参数的值,必须包含哪些参数的值,才可以通过其标注的方法处理。

headers

String[]

可选属性,用于指定客户端请求中,必须包含哪些header的值,才可以通过其标注的方法处理。

consumes

String[]

可选属性,用于指定处理请求的提交内容类型(Content-type)。

produces

String[]

可选属性,用于指定返回的内容类型,仅当request请求头中的(Accept)类型中包含该指定类型才返回。

二、value属性的两种映射路径标注

        value属性是@RequestMapping注解的默认属性。当value属性是@RequestMapping注解显式使用的唯一属性时,可以省略value的属性名。例如,下面两种映射路径标注的含义相同。

@RequestMapping(value="/firstController")
@RequestMapping("/firstController")

        使用value属性时,可以指定映射单个的请求URL,也可以将多个请求映射到一个方法上。在value属性中添加一个带有请求路径的列表,就可以将这个请求列表中的路径都映射到对应的方法上。

import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;

@Controller
public class AuthController {
    //设定当前方法的访问映射地址列表
    @RequestMapping(value = {"/addUser", "/deleteUser"})
    public void checkAuth() {
        System.out.println("增删操作校验");
    }
}

启动项目,在浏览器中访问地址http://localhost:8080/chapter11/addUser,控制台打印输出信息。

增删操作校验

在浏览器中访问地址http://localhost:8080/chapter11/deleteUser,控制台打印输出信息。

增删操作校验

三、method属性限定处理器映射

        method属性可以对处理器映射的URL请求方式进行限定。当请求的URL和处理器映射成功,但请求方式和method属性指定的属性值不匹配,处理器也不能正常处理请求。

1、接下来通过一个案例演示method属性中HTTP请求类型的声明。

import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;

@Controller
@RequestMapping("/method")
public class MethodController {
    //处理请求方式为 GET 的请求
    @RequestMapping(method = RequestMethod.GET)
    public void get() {
        System.out.println("RequestMethod.GET");
    }

    //处理请求方式为 DELETE 的请求
    @RequestMapping(method = RequestMethod.DELETE)
    public void delete() {
        System.out.println("RequestMethod.DELETE");
    }

    //处理请求方式为 POST 的请求
    @RequestMapping(method = RequestMethod.POST)
    public void post() {
        System.out.println("RequestMethod.POST");
    }

    //处理请求方式为 PUT 的请求
    @RequestMapping(method = RequestMethod.PUT)
    public void put() {
        System.out.println("RequestMethod.PUT");
    }

    @RequestMapping(value = "/method",
            method = {RequestMethod.GET,RequestMethod.POST})
    public void getAndPost() {
        System.out.println("RequestMethod.GET+RequestMethod.POST");
    }
}

2、启动项目后,在客户端依次以GET方式、DELETE方式、POST方式和PUT方式请求访问http://localhost:8080/chapter11/method时,程序会分别执行文件中的get()方法、delete()方法、post()方法和put()方法,控制台打印输出信息。

RequestMethod.GET
RequestMethod.DELETE
RequestMethod.POST
RequestMethod.PUT

四、method属性中有多个HTTP请求类型

        如果需要同时支持多个请求方式,则需要将请求方式列表存放在英文大括号中,以数组的形式给method属性赋值,并且多个请求方式之间用英文逗号分隔,示例代码如下所示。

@RequestMapping(value = "/method",
method = {RequestMethod.GET,RequestMethod.POST})
public void getAndPost() {
	System.out.println("RequestMethod.GET+RequestMethod.POST");
}

五、params属性值的定义方式

        params属性中定义的值可以将请求映射的定位范围缩小。当客户端进行请求时,如果请求参数的值等于params属性定义的值,可以正常执行所映射到的方法,否则映射到的方法不执行。

import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;

@Controller
public class ParamsController {
    @RequestMapping(value = "/params", params = "id=1")
    public void findById(String id) {
        System.out.println("id=" + id);
    }
}

  • 25
    点赞
  • 15
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Code repairman

你的鼓励将是我创作的最大的动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值