Spring MVC @Controller和@RequestMapping注解

Spring 2.5版本新增了Spring MVC注解功能,用于替换传统的基于XML的Spring MVC配置.

使用基于注解的控制器具有以下2个优点:

1.在基于注解的控制器类中可以编写多个处理方法,进而可以处理多个请求(动作),这就允许将相关的操作编写在同一个控制器类中,从而减少控制器类的数量,方便以后维护.

2.基于注解的控制器不需要在配置文件中部署映射,仅需要使用@RequestMapping注解一个方法进行请求处理即可.

下面介绍Spring MVC 中最重要的两个注解类型:@Controller和@RequestMapping.

Controller注解

@Controller注解用于声明某类的实例是一个控制器.例如,在net.baidu.controller包中创建控制器类IndexController,示例代码如下

package net.baidu.controller;

importorg.springframework.stereotype.Controller;

@Controller

public class IndexController{

// 处理请求的方法

}

Spring MVC使用扫描机制找到应用中所有基于注解的控制器类,所以,为了让控制器类被Spring MVC框架扫描到,需要在配置文件中声明spring-context,并使用<context:component-scan/>元素指定控制器类的基本包

例如,在springmvcDemo应用的配置文件springmvc-servlet.xml中添加一下代码:

<!-- 使用扫描机制扫描控制器类,控制器类都在net.baidu.controller包及其子包下 -->

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

RequestMapping注解

一个控制器内有多个处理请求的方法,如UserController里通常有增加用户,修改用户信息,删除指定用户,根据条件获取用户列表等.每个方法负责不同的请求操作,而@RequestMapping就负责将请求映射到对应的控制器方法上.

在基于注解的控制器类中可以为每个请求编写对应的处理方法.使用@RequestMapping注解将请求与处理方法一一对应即可.

@RequestMapping注解可用于类或方法上.用于类上,表示类中的所有响应请求的方法都以该地址作为父路径.

@RequestMapping注解常用属性如下:

1.value属性

value属性是@RequestMapping注解的默认属性,因此如果只有value属性时,可以省略该属性名,如果有其它属性,则必须写上value属性名称.如下:

@RequestMapping(value = "toUser")

@RequestMapping("toUser")

value属性支持通配符匹配,如@RequestMapping(value = "toUser/*")表示http://localhost:8080/toUser/1 或 http://localhost:8080/toUser/2都能正常访问.

2.path属性

path属性和value属性都用来作为映射使用.即@RequestMapping(value = ''toUser")和@RequestMapping(path="toUser")都能访问toUser()方法.

path属性支持通配符匹配,如@RequestMapping(path="toUser/*")表示http://localhost:8080/toUser/1或者http://localhost:8080/toUser/2都能够正常访问.

3.name属性

name属性相当于方法的注释,使方法更易理解.如@RequestMaping(value = "toUser",name = "获取用户信息").

4.method属性

method属性用于表示方法支持哪些HTTP请求.如果省略method属性,则说明该方法支持全部的HTTP请求

@RequestMapping(value = "toUser",method = "RequestMethod.GET")表示该方法只支持GET请求.也可指定多个HTTP请求,如@RequestMapping(value = "toUser",method = {RequestMethod.GET,RequestMethod.POST}),说明该方法同时支持GET和POST请求.

5.params属性

params属性用于指定请求中规定的参数,代码如下.

@RequestMapping(value = "toUser",params = "type")

public String toUser(){

            return "showUser";

}

以上代码表示请求中必须包含type参数是才能执行该请求.即http://localhost:8080/toUser?type=xx 能够正常访问toUser()方法,而http://localhost:8080/toUser则不能正常访问toUser()方法.

@RequestMapping(value = "toUser",params = "type = 1")

public String toUser() {

         return "showUser";

}

6.header属性

header属性表示请求中必须包含某些指定的header值.

@RequestMapping(value = "toUser",headers = "Referer=http://www.xx.com")表示请求的header中必须包含了指定的"Referer"请求头,以及值为"http://www.xx.com"时,才能执行该请求.

7.consumer属性

consumer属性用于指定处理请求的提交内容类型(Content-Type),例如:application/json,text/html.如@RequestMapping(value = "toUser",consumes = "application/json").

8.produces属性

produces属性用于指定返回的内容类型,返回的内容类型必须是request请求头(Accept)中所包含的类型.如@RequestMapping(value = "toUser",produces = "application/json").

除此之外,produces属性还可以指定返回值的编码.如@RequestMapping(value = "toUser",produces = "application/json,charset = utf-8 "),表示返回utf-8编码.

使用@RequestMapping 来完成映射,具体包括4个方面的信息项:请求URL,请求参数,请求方法和请求头.

通过请求URL进行映射

1)方法级别注解

方法级别注解的示例代码如下.

package net.baidu.controller;

import org.springframework.stereotype.Controller;

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

@Controller

public class IndexController{

@RequestMapping(value="/index/login")

public String login(){

return"login";

}

@RequestMapping(value="/index/register")

public String register(){

return"register";

}

}

上述示例中有两个RequestMapping注解语句,它们都作用在处理方法上.在整个Web项目中,@RequestMapping映射的请求信息必须保证全局唯一.

用户可以使用如下URL访问login方法(请求处理方法),在访问login方法之前需要事先在/WEB-INF/jsp/目录下创建login.jsp

http://localhost:8080/springmvcDemo/index/login

2)类级别注解

类级别注解代码如下

package net.baidu.controller;

import org.springframework.stereotype.Controller;

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

@Controller

@RequestMapping("/index")

public class IndexController{

@RequestMapping("/login")

public String login(){

return"login";

}

@RequestMapping("/register")

public String register(){

return"register";

}

}

在类级别注解的情况下,控制器类中的所有方法都将映射为类级别的请求。用户可以使用如下 URL 访问 login 方法。

http://localhost:8080/springmvcDemo/index/login

为了方便维护程序,建议开发者采用类级别注解,将相关处理放在同一个控制器类中。例如,对用户的增、删、改、查等处理方法都可以放在 UserController 控制类中。

通过请求参数、请求方法进行映射

@RequestMapping 除了可以使用请求 URL 映射请求之外,还可以使用请求参数、请求方法来映射请求,通过多个条件可以让请求映射更加精确。

package net.baidu.controller;

import org.springframework.stereotype.Controller;

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

@Controller

public class IndexController{

@RequestMapping(value="/index/success"method=RequestMethod.GET,Params="username")

public String success(@RequestParamString username){


return"index";

}

上述代码中,@RequestMapping 的 value 表示请求的 URL;method 表示请求方法,此处设置为 GET 请求,若是 POST 请求,则无法进入 success 这个处理方法中。params 表示请求参数,此处参数名为 username。

编写请求处理方法

在控制类中每个请求处理方法可以有多个不同类型的参数,以及一个多种类型的返回结果.

1)请求处理方法中常出现的参数类型

如果需要在请求处理方法中使用Servlet API类型,那么可以将这些类型作为请求处理方法的参数类型.Servlet API参数类型的示例代码如下:

package net.biancheng.controller;

import javax.servlet.http.HttpSession;

import org.springframework.stereotype.Controller;

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

@Controller

@RequestMapping("/index")

public class IndexController{

@RequestMapping("/login")

public String login(HttpSession session,HttpServletRequest request){

session.setAttribute("skey","session范围的值");

session.setAttribute("rkey","request范围的值");

return"login";

}

}

除了Servlet API参数类型以外,还有输入输出流,表单实体类,注解类型,与Spring框架相关的类型等,这些类型在后续章节中使用时再详细介绍.

其中特别重要的类型是org.springframework.ui.Model类型,该类型是一个包含Map的Spring MVC类型.在每次调用请求处理方法时 Spring MVC都将创建org.springframework.ui.Model对象.Model参数类型的示例代码如下:

packagenet.baidu.controller;

import javax.servlet.http.HttpServletRequest;

import javax.servlet.http.HttpSession;

import org.springframework.stereotype.Controller;

import org.springframework.ui.Model;

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

@Controller

@RequestMapping("/index")

public class IndexController{

@RequestMapping("/register")

public String register(Model model){

/*在视图中可以使用EL表达式${success}取出model中的值*/

model.addAttribute("success","注册成功");

return"register";

}

}

2)请求处理方法常见的返回类型

请求处理方法可以返回如下类型的对象:

ModelAndView                                                                                          Model                                                                                                                  包含模型属性的Map                                                                                   View                                                                                                                    代表逻辑视图名String                                                                                      void                                                                                                                     其它任意Java类型

最常见的返回类型就是代表逻辑视图名称的String类型,例如前面即结中的请求处理方法.

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,684评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 87,143评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,214评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,788评论 1 277
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,796评论 5 368
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,665评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,027评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,679评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 41,346评论 1 299
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,664评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,766评论 1 331
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,412评论 4 321
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,015评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,974评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,203评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,073评论 2 350
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,501评论 2 343

推荐阅读更多精彩内容