zoukankan      html  css  js  c++  java
  • SSM —— 注解解析

    @Component
    是所有受Spring 管理组件的通用形式,@Component注解可以放在类的头上,@Component不推荐使用。

    @Controller
    通过@Controller注解说明该类非普通类,而是一个控制器类。

    @Service
    @Repository
    用于注解dao层,在daoImpl类上面注解。

    @RestController
    1. Controller, RestController的共同点

         都是用来表示Spring某个类的是否可以接收HTTP请求

    2.  Controller, RestController的不同点

         @Controller标识一个Spring类是Spring MVC controller处理器

         @RestController:  a convenience annotation that does nothing more than adding the@Controller and@ResponseBody annotations。  @RestController是@Controller和@ResponseBody的结合体,两个标注合并起来的作用。

    官方文档:
    @RestController is a stereotype annotation that combines @ResponseBody and @Controller.
    意思是:
    @RestController注解相当于@ResponseBody + @Controller合在一起的作用。

    1)如果只是使用@RestController注解Controller,则Controller中的方法无法返回jsp页面,配置的视图解析器InternalResourceViewResolver不起作用,返回的内容就是Return 里的内容。

    例如:本来应该到success.jsp页面的,则其显示success.

    2) 如果需要返回到指定页面,则需要用 @Controller配合视图解析器InternalResourceViewResolver才行。
    3)如果需要返回JSON,XML或自定义mediaType内容到页面,则需要在对应的方法上加上@ResponseBody注解。

    @RequestMapping
    通过RequestMapping注解映射请求URL  

    @RequestMapping("/devmgr")注解映射请求地址

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

    @RequestMapping注解有六个属性,分成三类进行说明:

    1、 value, method;

    value:     指定请求的实际地址,指定的地址可以是URI Template 模式;

    method:  指定请求的method类型, GET、POST、PUT、DELETE等;

    2、consumes,produces

    consumes: 指定处理请求的提交内容类型(Content-Type),例如application/json, text/html;

    produces:    指定返回的内容类型,仅当request请求头中的(Accept)类型中包含该指定类型才返回;

    3、params,headers

    params: 指定request中必须包含某些参数值是,才让该方法处理。

    params 只是判断url 或者 form data 中的参数是否复合params的定义,并不会直接绑定数据到方法的参数中!

    headers: 指定request中必须包含某些指定的header值,才能让该方法处理请求。

    @CrossOrigin
    使用@CrossOrigin实现跨域请求,后台和前台分离开发

    @Qualifier
    @Resource 和 @Autowired
    @Autowired顾名思义,就是自动装配。

    其作用是为了消除代码Java代码里面的getter/setter与bean属性中的property。

    当然,getter看个人需求,如果私有属性需要对外提供的话,应当予以保留。

    @Autowired默认按类型匹配的方式,在容器查找匹配的Bean,当有且仅有一个匹配的Bean时,Spring将其注入@Autowired标注的变量中。

    -----------------------------------------------------------------------------------

    @Resource的装配顺序:
    (1)、@Resource后面没有任何内容,默认通过name属性去匹配bean,找不到再按type去匹配
    (2)、指定了name或者type则根据指定的类型去匹配bean
    (3)、指定了name和type则根据指定的name和type去匹配bean,任何一个不匹配都将报错

    然后,区分一下@Autowired和@Resource两个注解的区别:
    (1)、@Autowired默认按照byType方式进行bean匹配,@Resource默认按照byName方式进行bean匹配
    (2)、@Autowired是Spring的注解,@Resource是J2EE的注解

    ------------------------------------------------------------------------------------------------

    @Autowired注解是按照类型(byType)装配依赖对象,默认情况下它要求依赖对象必须存在,如果允许null值,可以设置它的required属性为false。如果我们想使用按照名称(byName)来装配,可以结合@Qualifier注解一起使用。如下:

    ---------------------------------------------------------------------------------------------------------------------------------@Resource默认按照ByName自动注入,由J2EE提供,需要导入包javax.annotation.Resource。@Resource有两个重要的属性:name和type,而Spring将@Resource注解的name属性解析为bean的名字,而type属性则解析为bean的类型。所以,如果使用name属性,则使用byName的自动注入策略,而使用type属性时则使用byType自动注入策略。如果既不制定name也不制定type属性,这时将通过反射机制使用byName自动注入策略。

    注:最好是将@Resource放在setter方法上,因为这样更符合面向对象的思想,通过set、get去操作属性,而不是直接去操作属性。

    @Resource装配顺序:

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

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

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

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

    @Resource的作用相当于@Autowired,只不过@Autowired按照byType自动注入。

    @ResponseBody
    作用: 该注解用于将Controller的方法返回的对象,通过适当的HttpMessageConverter转换为指定格式后,写入到Response对象的body数据区。

    使用时机:返回的数据不是html标签的页面,而是其他某种格式的数据时(如json、xml等)使用;

    @RequestBody
    @Param
    实例一 @Param注解单一属性

    dao层示例

    Public User selectUser(@param(“userName”) String name,@param(“userpassword”) String password);

    xml映射对应示例<select id=" selectUser" resultMap="BaseResultMap">  

    select  *  from user_user_t   where user_name = #{userName,jdbcType=VARCHAR} and user_password=#{userPassword,jdbcType=VARCHAR} 

     </select>

    注意:采用#{}的方式把@Param注解括号内的参数进行引用(括号内参数对应的是形参如 userName对应的是name);

    实例二 @Param注解JavaBean对象

    dao层示例

    public List<user> getUserInformation(@Param("user") User user);

    xml映射对应示例

    <select id="getUserInformation" parameterType="com.github.demo.vo.User" resultMap="userMapper">  

        select   

            <include refid="User_Base_Column_List" />  

            from mo_user t where 1=1  

         <!-- 因为传进来的是对象所以这样写是取不到值得 -->  

    <if test="user.userName!=null  and user.userName!=''">   and   t.user_name = #{user.userName}  </if>  

    <if test="user.userAge!=null  and user.userAge!=''">   and   t.user_age = #{user.userAge}  </if>      </select>  

    1,使用@Param注解

    当以下面的方式进行写SQL语句时:

        @Select("select column from table where userid = #{userid} ")
        public int selectColumn(int userid);

    当你使用了使用@Param注解来声明参数时,如果使用 #{} 或 ${} 的方式都可以。

        @Select("select column from table where userid = ${userid} ")
        public int selectColumn(@Param("userid") int userid);

    当你不使用@Param注解来声明参数时,必须使用使用 #{}方式。如果使用 ${} 的方式,会报错。

        @Select("select column from table where userid = ${userid} ")
        public int selectColumn(@Param("userid") int userid);

    2,不使用@Param注解

    不使用@Param注解时,参数只能有一个,并且是Javabean。在SQL语句里可以引用JavaBean的属性,而且只能引用JavaBean的属性。

        // 这里id是user的属性

        @Select("SELECT * from Table where id = ${id}")
        Enchashment selectUserById(User user);

    @RequestParam
    在springMVC中使用RequestParam注解映射请求参数,@RequestParam有三个属性,分别如下:

    (1) value 请求参数的参数名,作为参数映射名称;

    (2) required 该参数是否必填,默认为true(必填),当设置成必填时,如果没有传入参数,报错;

    (3) defaultValue 设置请求参数的默认值;

    @requestParam主要用于在SpringMVC后台控制层获取参数,类似一种是request.getParameter("name"),它有三个常用参数:defaultValue = "0", required = false, value = "isApp";defaultValue 表示设置默认值,required 铜过boolean设置是否是必须要传入的参数,value 值表示接受的传入的参数类型。

    value:参数key,可以不写;

    required:默认值为true,可以不写;

    获取URL或者 form data 中的参数

    GET

    注意 :

    GET中的参数形式为:username=atguigu&age=11&sex=boy

    POST中的参数形式为:以键值对形式保存在form data

    总得来说,均是键值对形式。与@PathVariabl中的占位符形式不同!!!

    @PathVariabl
    绑定路径中的占位符参数到方法参数变量中;

    只能绑定路径中的占位符参数,且路径中必须有参数。

    无论是 GET 或者POST 只要 URL中有参数即可!

    【注意:】如果URL中无参数,将会出错;如果URL有参数,但是没有使用@PathVariabl该注解,那么URL的参数不会默认与方法参数绑定!方法里的参数会默认绑定表单里面对应的参数!

    如果参数名与占位符一致,则可直接使用@PathVariable;

    如果不一致,则在@PathVariable( )括号内绑定占位符。

    Spring常用注解汇总
    使用注解之前要开启自动扫描功能,其中base-package为需要扫描的包(含子包)。

    <context:component-scan base-package="cn.test"/> 

    @Configuration把一个类作为一个IoC容器,它的某个方法头上如果注册了@Bean,就会作为这个Spring容器中的Bean。
    @Scope注解 作用域
    @Lazy(true) 表示延迟初始化
    @Service用于标注业务层组件、 
    @Controller用于标注控制层组件(如struts中的action)
    @Repository用于标注数据访问组件,即DAO组件。
    @Component泛指组件,当组件不好归类的时候,我们可以使用这个注解进行标注。
    @Scope用于指定scope作用域的(用在类上)
    @PostConstruct用于指定初始化方法(用在方法上)
    @PreDestory用于指定销毁方法(用在方法上)
    @DependsOn:定义Bean初始化及销毁时的顺序
    @Primary:自动装配时当出现多个Bean候选者时,被注解为@Primary的Bean将作为首选者,否则将抛出异常
    @Autowired 默认按类型装配,如果我们想使用按名称装配,可以结合@Qualifier注解一起使用。如下:
    @Autowired @Qualifier("personDaoBean") 存在多个实例配合使用
    @Resource默认按名称装配,当找不到与名称匹配的bean才会按类型装配。
    @PostConstruct 初始化注解
    @PreDestroy 摧毁注解 默认 单例  启动就加载
    @Async异步方法调用

  • 相关阅读:
    mysql 函数 存储过程 事件(event) job 模板
    protobuf 无proto 解码 decode 语言 java python
    mitmproxy fiddler 抓包 填坑
    android adb 常用命令
    android机器人 模拟 踩坑过程
    RabbitMQ添加新用户并支持远程访问
    Windows下RabbitMQ安装及配置
    Java mybatis mysql 常用数据类型对应关系
    easyExcel 踩坑
    linux防火墙查看状态firewall、iptable
  • 原文地址:https://www.cnblogs.com/gz007/p/10276177.html
Copyright © 2011-2022 走看看