二、@ResquestMapping

2.1使用 @RequestMapping 映射请求

  • Spring MVC 使用 @RequestMapping 注解为控制器指定可以处理哪些 URL 请求
  • 在控制器的类定义及方法定义处都可标注
    @RequestMapping
    类定义处:提供初步的请求映射信息。相对于 WEB 应用的根目。
    方法处:提供进一步的细分映射信息。相对于类定义处的 URL。若类定义处未标注 @RequestMapping,则方法处标记的 URL 相对于WEB 应用的根目录
  • DispatcherServlet 截获请求后,就通过控制器上@RequestMapping 提供的映射信息确定请求所对应的处理方法。

2.1.1测试@ResquestMapping

SpringMVCTest.java

package com.atguigu.springmvc.handlers;

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

@RequestMapping("/springmvc")
@Controller
public class SpringMVCTest {

    private static final String SUCCESS="success";

    @RequestMapping("/testRequestMapping")
    public String testRequestMapping()
    {
        System.out.println("testRequestMapping");
        return SUCCESS;
    }

}

2.1.2index.jsp中的写法

index.jsp

<body>
<a href="springmvc/testRequestMapping">Test RequestMapping</a>
</body>

2.2映射请求参数、请求方法或请求头

  • @RequestMapping 除了可以使用请求 URL 映射请求外,还可以使用请求方法、请求参数及请求头映射请求
  • @RequestMapping 的 value、method、params 及 heads分别表示请求 URL、请求方法、请求参数及请求头的映射条件,他们之间是与的关系,联合使用多个条件可让请求映射更加精确化。
  • params 和 headers支持简单的表达式:
    – param1: 表示请求必须包含名为 param1 的请求参数
    – !param1: 表示请求不能包含名为 param1 的请求参数
    – param1 != value1: 表示请求包含名为 param1 的请求参数,但其值不能为 value1
    – {“param1=value1”, “param2”}: 请求必须包含名为 param1 和param2的两个请求参数数,且 param1 参数的值必须为 value1

2.2.1@RequestMapping中使用Method属性

SpringMVCTest.java

package com.atguigu.springmvc.handlers;

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

@RequestMapping("/springmvc")
@Controller
public class SpringMVCTest {

    private static final String SUCCESS="success";

    @RequestMapping("/testRequestMapping")
    public String testRequestMapping()
    {
        System.out.println("testRequestMapping");
        return SUCCESS;
    }


    //使用Method属性来指定请求方式
    @RequestMapping(value="/testMethod",method=RequestMethod.POST)
    public String testMethod()
    {
        System.out.println("testMethod");
        return SUCCESS;
    }
}

2.2.2在index.jsp中测试

index.jsp

<!--因为@RequestMapping中的method属性指定的是POST,所以不能使用get请求-->
<form action="springmvc/testMethod" method="POST">
      <input type="submit" value="submit"/>
    </form>

2.2.3@RequestMapping中指定params和heads属性

SpringMVCTest.java

package com.atguigu.springmvc.handlers;

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

@RequestMapping("/springmvc")
@Controller
public class SpringMVCTest {

    private static final String SUCCESS="success";

    @RequestMapping("/testRequestMapping")
    public String testRequestMapping()
    {
        System.out.println("testRequestMapping");
        return SUCCESS;
    }


    //使用Method属性来指定请求方式
    @RequestMapping(value="/testMethod",method=RequestMethod.POST)
    public String testMethod()
    {
        System.out.println("testMethod");
        return SUCCESS;
    }

    //可以使用params和headers来更加精确地映射请求,params和headers支持简单的表达式
    @RequestMapping(value="testParamsAndHeaders",
            params={"username","age!=10"}, headers={"Accept-Language=zh-CN,zh;q=0.8"})
    public String testParamsAndHeaders()
    {
        System.out.println("testParamsAndHeaders");
        return SUCCESS;
    }
}

2.2.4index.jsp中测试

index.jsp

<a href="springmvc/testParamsAndHeaders?username=zhangsan&age=11">testParamsAndHeaders</a>

浏览器中:

http://localhost:8080/springmvc-1/springmvc/testParamsAndHeaders?username=zhangsan&age=11

2.3@RequestMapping支持Ant风格的URL

Ant 风格资源地址支持 3 种匹配符:
- ?:匹配文件名中的一个字符
- *:匹配文件名中的任意字符
- 匹配多层路径

@RequestMapping 还支持 Ant 风格的 URL
- /user/*/createUser: 匹配/user/aaa/createUser、/user/bbb/createUser 等 URL
- /user/**/createUser: 匹配/user/createUser、/user/aaa/bbb/createUser 等 URL
- /user/createUser??: 匹配/user/createUser**aa**、/user/createUser**bb **等 URL

2.3.1@RequestMapping中指定Ant格式的属性

SpringMVCTest.java

package com.atguigu.springmvc.handlers;

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

@RequestMapping("/springmvc")
@Controller
public class SpringMVCTest {

    private static final String SUCCESS="success";

    @RequestMapping("/testRequestMapping")
    public String testRequestMapping()
    {
        System.out.println("testRequestMapping");
        return SUCCESS;
    }


    //使用Method属性来指定请求方式
    @RequestMapping(value="/testMethod",method=RequestMethod.POST)
    public String testMethod()
    {
        System.out.println("testMethod");
        return SUCCESS;
    }

    //可以使用params和headers来更加精确地映射请求,params和headers支持简单的表达式
    @RequestMapping(value="testParamsAndHeaders",
            params={"username","age!=10"}, headers={"Accept-Language=zh-CN,zh;q=0.8"})
    public String testParamsAndHeaders()
    {
        System.out.println("testParamsAndHeaders");
        return SUCCESS;
    }

    @RequestMapping("/testAntPath/*/abc")
    public String testAntPath()
    {
        System.out.println("testAntPath");
        return SUCCESS;
    }

}

2.3.2index.jsp中进行测试

index.jsp

<a href="springmvc/tetAntPath/fdsagfdas/abc">TestAntPath</a>
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值