SpringMVC学习(1)—基本注解

一直在使用,这次系统的学习一下:

一、@RequstMapping映射

SpringMVC使用@RequestMapping注解为控制器指定可以处理的URL请求,在控制器的类定义及方法定义处都可以标注。

类定义处:定义初步的请求映射信息,相对于web应用的根目录

方法定义处:提供进一步的细分映射映射信息。相对于类定义的URL。如果类定义处未标注@RequestMapping,则方法处标记的URL相对于web端应用的根目录。 

DispatcherServlet截获请求之后,就通过控制器上@RequestMapping提供的映射信息确认请求对应的处理方法。

映射器请求的参数、请求方法或请求头

@RequestMapping除了可以使用请求url映射请求外,还可以使用请求方法,请求参数及其请求头映射请求;

@RequestMpping的value、method、param、heads分别表示请求url、请求方法、请求参数及其请求头的映射条件,他们之间是与的关系,联合使用多个参数条件可以让映射更加精准化。

params和headers支持简单的表达式:

例如:1、param1表示请求必须包含有param1的请求参数;

2、!param1表示请求不能包含名为param1的请求参数;

3、param1!=values1表示请求包含名为param1的请求参数,但是其值不能为value1;

4、{"param1=value1","param2"}:请求必须包含名为param1和param2的两个请求参数,且param1参数的值必须为value1;

@RequestMapping方法的映射请求:

Ant风格资源地址支持三种匹配符:

1、?:匹配文件名中的一个字符;

2、*:匹配文件命中的任意字符;

3、**:匹配多层路径;

@RequestMapping还支持Ant风格的url

1、/user/*/createUser:匹配user/aaa/createUser、user/bbb/createUser等url;

2、/user/**/createUser:匹配/user/createUser、/user/aaa/bbb/createUser等url;

3、/user/createUser??:匹配/user/createUseraa、/user/createUserbb等url;

 

二、@PathVariable映射URL绑定的占位符

带有占位符的url是Spring3.0新增的功能,该功能在SpingMVC像REST目标挺进发展过程中具有里程碑式的意义;

通过@PathVariable可以将url中占位符参数绑定到控制处理方法的入参中:url中的(xxx)占位符可以通过@PathVariable("xxx")绑定到操作方法的入参中。

	@RequestMapping("/testPathVariable/{id}")
	public String testPathVariable(@PathVariable("id") Integer id){
		System.out.println("testPathVariable: " + id);
		return "SUCCESS";
	}

三、使用@RequestHeader绑定请求报头的属性值

请求头包含了若干个属性,服务器可以据此获知客户端的信息,通过@RequestHeader即可将请求头中的属性值绑定到处理方法的入参中。

	private static final String SUCCESS="success";
	@RequestMapping("/testRequestHeader")
	public String testRequestHeader(@RequestHeader(value="Accept-Lanager") String al){
		System.out.println("testRequestHeader Accept-Lanager:"+al);
		return SUCCESS;
	}

四、使用@CookieValue绑定请求中Cookie的值

@CookieValue可以让处理方法入参绑定某个Cookie的值

	private static final String SUCCESS="success";
	@RequestMapping("/testCookieValue")
	public String testCookieValue(@CookieValue("JESSIONID") String sessionId){
		System.out.println("testCookieValue sessionId="+sessionId);
		return SUCCESS;
	}

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值