元注解@Target分析

@Target

用于描述注解的使用范围
说明该注解可以放置在什么地方,如接口,class类上等

使用方式:
@Target({ElementType.TYPE})
public @interface FeignClient {
    
}
ElementType的值

即规定注解的声明,即限制改注释能使用的范围

  1. TYPE——接口(包括Annotation,即@interface)、类、枚举声明
  2. FIELD——字段(包括枚举常量)声明,@CFNotNull
  3. METHOD——方法声明,如@Autowired
  4. PARAMETER——参数声明,如@Param
  5. CONSTRUCTOR—— 构造函数什么,如@ConstructorProperties
  6. LOCAL_VARIABLE——局部变量声明,如@CFNotNull
  7. ANNOTATION_TYPE——注释类型声明,如@Target
  8. PACKAGE——包声明
  9. TYPE_PARAMETER——类型参数声明
  10. TYPE_USE——类型的使用
原码:
public enum ElementType {
    /** Class, interface (including annotation type), or enum declaration */
    TYPE,

    /** Field declaration (includes enum constants) */
    FIELD,

    /** Method declaration */
    METHOD,

    /** Formal parameter declaration */
    PARAMETER,

    /** Constructor declaration */
    CONSTRUCTOR,

    /** Local variable declaration */
    LOCAL_VARIABLE,

    /** Annotation type declaration */
    ANNOTATION_TYPE,

    /** Package declaration */
    PACKAGE,

    /**
     * Type parameter declaration
     *
     * @since 1.8
     */
    TYPE_PARAMETER,

    /**
     * Use of a type
     *
     * @since 1.8
     */
    TYPE_USE
}

注意:当注解未指定Target值时,或未被Target注释时,则说明该注解可以用于任何元素之上。

Target值具有多个值的表达形式
形式1:
@Target({ElementType.METHOD, ElementType.ANNOTATION_TYPE})
形式2:
@Target(value = {ElementType.ANNOTATION_TYPE,ElementType.CONSTRUCTOR})
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
@PreAuthorize是一个权限注解,用于在方法执行前进行权限验证。它可以根据所声明的权限表达式对当前登录用户的角色权限进行对比,以确定是否允许方法的执行。如果用户的角色权限集合中包含了所需的权限,那么方法将被放行;否则,将被拒绝。这个注解常用于需要进行权限控制的Controller方法上,通过添加@PreAuthorize注解和相应的权限表达式来限制只有具备某些特定权限的用户才能访问该方法。总的来说,@PreAuthorize注解提供了一种简便的方式来实现细粒度的权限控制,保护系统的安全性。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* [Spring Security-@PreAuthorize 权限注解分析](https://blog.csdn.net/inthat/article/details/108225481)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] - *3* [史上最简单的Spring Security教程(十二):@PreAuthorize注解实现权限控制](https://blog.csdn.net/liuminglei1987/article/details/107413061)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值