SpringMVC常用注解

一、@Controller()

使用此注解标注的类就是一个SpringMVC Controller对象,表示将这个类交给Spring容器进行管理。分发处理器会自动进行扫描。

※  仅仅使用这个注释,只是说明此类是一个控制器类。

故常常搭配以下方法,将控制器交给Spring管理:

1、在SpringMVC的配置文件中定义MyController的bean对象

<bean class="com.examp.lty.controller.MyController"/>

2、在SpringMVC的配置文件中写明Controller的上一层包名的路径

<context:component-scan base-package="com.example.lty"/>


二、@RequestMapping

@RequestMapping注解是一个用来处理请求地址映射的注解,一般用于类或方法。(用在类上,表示类的所有相应请求的方法都是以该地址作为父路径)

@RequestMapping属性说明:

(1)value:指定请求的实际地址

(2)method:指定请求的类型(GET、POST、PUT、DELETE)

(3)consumes:指定处理请求的提交类型(application/json , text/html)

(4)produces:指定返回内容的类型(request请求头包含此指定类型时,才返回)

(5)params:指定request中必须包含某些指定的参数值,才让该方法处理

(6)headers:指定request中必须包含某些指定的header值,才让该方法处理


三、@Resource和@Autowired

它们都是在bean的注入时使用(其实@Resource并不是Spring的注解,它的包是javax.annotation.Resource,需要导入,Spring支持该注解的注入)

(1)相同点:

均可用于字段和setter方法上。(二者同时存在于字段上,则无需写setter方法)

(2)不同点:

@Autowired需要导入包 org.springframework.beans.factory.annotation.Autowired,且只能按照byType注入,默认情况下要求依赖的对象必须存在,当设置其required属性为false时,才允许null值。

public class TestServiceImpl {

    // 下面两种@Autowired只要使用一种即可

    @Autowired

    private UserDao userDao; // 用于字段上


    @Autowired

    public void setUserDao(UserDao userDao) { // 用于属性的方法上

        this.userDao = userDao;

    }

}

@Autowired和@Qualifier一起使用时,可按照名称来装配

publicclass TestServiceImpl {

    @Autowired

    @Qualifier("userDao")

    private UserDao userDao;

}

@Resource默认按照名称自动注入,需导入javax.annotation.Resource包。其属性,name为bean的名字,type为bean的类型。(若指定了name属性,则使用byName的自动注入策略;若指定了type属性,则使用byType自动注入策略;若均不指定,则通过反射机制使用byName自动注入策略)

public class TestServiceImpl {

    // 下面两种@Resource只要使用一种即可

    @Resource(name="userDao")

    private UserDao userDao; // 用于字段上


    @Resource(name="userDao")

    public void setUserDao(UserDao userDao) { // 用于属性的setter方法上

        this.userDao = userDao;

    }

}

※ 通常将@Resource放在setter方法上(通过get、set操作对象,更符合面向对象思想)

@Resource装配顺序:

①如果同时指定了name和type,则从Spring上下文中找到唯一匹配的bean进行装配,找不到则抛出异常。

②如果指定了name,则从上下文中查找名称(id)匹配的bean进行装配,找不到则抛出异常。

③如果指定了type,则从上下文中找到类似匹配的唯一bean进行装配,找不到或是找到多个,都会抛出异常。

④如果既没有指定name,又没有指定type,则自动按照byName方式进行装配;如果没有匹配,则回退为一个原始类型进行匹配,如果匹配则自动装配。


四、@ModelAttribute和@SessionAttributes

代表该Controller所有方法在调用前,均需先执行此@ModelAttribute方法。(常用在BaseController中。因为所有Controller均继承BaseController,利用这一特性,则可实现在调用Controller时,先执行先执行@ModelAttribute方法)

@SessionAttributes写在class上,用于将值放入session中


五、@PathVariable

常用于取出Ajax请求,URL中的变量作为参数

@RequestMapping(value="/product/{productId}",method = RequestMethod.GET)

    public String getProduct(@PathVariable("productId") String productId){ 

          System.out.println("Product Id : " + productId); 

          return "hello"; 

    } 


六、@requestParam

常用于SpringMVC后台控制层获取参数(类似于:request.getParameter("name"))其常用参数有:defaultValue=“0”(指定默认值) , required=false (指定是否必须要传入参数) , value=“isapp” (指定接受传入的参数类型)


七、@ResponseBody

用于将Controller的方法返回的对象通过HttpMessageConverter转换成指定格式后,写入Response对象的body数据区(当返回的数据是json / xml 时使用)


八、@Component

通用注解(当类的归属层,不明确时使用,一般不使用此注释)


九、@Repository

用于Dao层的注解,在DaoImpl类上使用。

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容