Springboot学习记录day3--注解以及注解类

一、关于@Target和Retention

注解@Target和@Retention可以用来修饰注解,是注解的注解。

@Target :  即该注解可以声明在哪些目标元素之前,也可理解为注释类型的程序元素的种类。

ElementType.PACKAGE:该注解只能声明在一个包名前。 

ElementType.ANNOTATION_TYPE:该注解只能声明在一个注解类型前。 

ElementType.TYPE:该注解只能声明在一个类前。

ElementType.CONSTRUCTOR:该注解只能声明在一个类的构造方法前。

ElementType.LOCAL_VARIABLE:该注解只能声明在一个局部变量前。

ElementType.METHOD:该注解只能声明在一个类的方法前。

ElementType.PARAMETER:该注解只能声明在一个方法参数前。

ElementType.FIELD:该注解只能声明在一个类的字段前。

@Retention :注解类的生命周期。 

RetentionPolicy.SOURCE  : 注解只保留在源文件,当Java文件编译成class文件的时候,注解被遗弃;

RetentionPolicy.CLASS  : 注解被保留到class文件,但jvm加载class文件时候被遗弃,这是默认的生命周期;

RetentionPolicy.RUNTIME  : 注解不仅被保存到class文件中,jvm加载class文件之后,仍然存在;
                        
以上文字来源:https://blog.csdn.net/Zero_uou/article/details/107819201

比如说,我在这个项目中写的:

@Target({ElementType.TYPE, ElementType.METHOD, ElementType.FIELD, ElementType.PARAMETER})
@Retention(RetentionPolicy.RUNTIME)
@Documented
public @interface AccessRole {
    SysUser.Type[] value() default {};
}

我定义了一个注解类AccessRole,我用@Target来说明这个注解类可以在一个类前、一个类的方法前、一个类的字段前、一个方法的参数前被声明。用@Retention来表明,这个注解类不仅被保存到class文件中,jvm加载class文件后仍然存在。

二、关于注解类

关于@Documentd:是一个元注解,即可以修饰其他注解的注解。

它的作用是,如果有它,那么被@AccessRole修饰的类在最终生成的文档中就会显示@AccessRole;倘若这里没有@Documentd,则最终生成的文档就不会有@AccessRole这个标识

接口内语句的话得意思是:@AccessRole注解定义了一个名为value的元素,它可以接受SysUser.Type枚举的数组。default {}表示如果没有为@UserTypes注解的value元素提供值,那么它将默认为一个空的枚举数组。

三、关于@RestController和@Controller

@Controller:是用于定义控制器的注解,用于处理客户端请求,并负责返回适当的视图作为响应。在@Controller注解的类当中,通常需要在方法上使用@ResponseBody注解来指示该方法的返回值作为响应的主体内容,而不是解析为视图。(若没有@RespnseBody,则默认返回是以视图为格式)

@RestController:相当于@Controller和@ResponseBody注解功能的结合。若该类被标记,则每个方法的返回值都会以JSON or XML的形式写入HTTP响应体中,相当于每个方法上都加了@ResponseBody注解(默认返回是数据格式)

讲的特别清楚明白的:【SpringBoot】带你一文彻底搞懂RestController和Controller的关系与区别-CSDN博客

Spring Boot应用中,如果你想要允许跨域请求并在周末(周六、周日)特定时间开启Access-Control-Allow-Origin策略,你可以创建一个自定义过滤器(Filter),例如使用`@CrossOrigin`注解,并通过`@PreAuthorize`或`@ConditionalOnDate`来控制其生效的时间。 首先,创建一个定制的过滤器,比如`WeekendCorsFilter.java`: ```java import org.springframework.boot.actuate.autoconfigure.web.server.ManagementServerProperties; import org.springframework.context.annotation.Bean; import org.springframework.context.annotation.Configuration; import org.springframework.http.HttpHeaders; import org.springframework.stereotype.Component; import org.springframework.util.StringUtils; @Configuration @Component public class WeekendCorsFilter { private final ManagementServerProperties management; public WeekendCorsFilter(ManagementServerProperties management) { this.management = management; } @Bean(name = "weekendCorsFilter") public WebMvcConfigurer corsConfigurer() { return (configurer) -> { configurer.addCorsConfiguration( "/**", // 允许所有的路径 headers -> { if (isWeekend()) { // 检查是否为周末 headers.setAllowCredentials(true); // 设置允许凭证 headers.addAllowedHeader("*"); // 允许所有头信息 headers.addAllowedMethod("*"); // 允许所有HTTP方法 headers.addAllowedOrigin("*"); // 允许来自任何源的请求 } else { // 非周末则按默认设置或你自己的规则处理 configurer.cors().allowCredentials(false); configurer.cors().allowedOrigins("http://your-origin.com"); } }); }; } private boolean isWeekend() { String[] daysOfWeek = {"Saturday", "Sunday"}; for (String day : daysOfWeek) { if (management.getEndpointProperties().getWeb().getDatepatterns().contains(day)) { return true; // 如果找到对应的日期模式,则为周末 } } return false; } } ``` 然后在启动Spring Boot Actuator配置中启用这个过滤器: ```java @SpringBootApplication public class Application { public static void main(String[] args) { SpringApplication.run(Application.class, args); } @Autowired private WeekendCorsFilter weekendCorsFilter; // ... @PostConstruct public void init() { weekendCorsFilter.corsConfigurer(); // 加载配置 } } ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值