当前位置:   article > 正文

注解总结,Java中的注解,springboot中的注解

注解总结,Java中的注解,springboot中的注解

注解总结

1、Junit

开始执行的方法:初始化资源,执行完之后的方法:释放资源
测试方法,必须是:公有、非静态、无参无返回值的
在一个类中,可以定义多个测试方法,每个测试方法可以单独运行,也可以整体运行(顺序:方法名升序)

Junit 4

注解说明
@Test测试方法
@Before用来修饰实例方法,在每个 @Test 之前被执行,可以有多个,按方法名 "降序" 依次执行
@After用来修饰实例方法,在每个 @Test 之前被执行,可以有多个,按方法名 "升序" 依次执行
@BeforeClass用于 "静态" 方法,在所有的 @Before 之前被执行,且只执行一次
@AfterClass用于 "静态" 方法,在所有的 @After 之前被执行,且只执行一次

Junit 5

注解说明
@Test测试方法
@BeforeEach用来修饰实例方法,在每个 @Test 之前被执行,可以有多个,按方法名 "降序" 依次执行
@AfterEach用来修饰实例方法,在每个 @Test 之前被执行,可以有多个,按方法名 "升序" 依次执行
@BeforeAll用于 "静态" 方法,在所有的 @BeforeEach 之前被执行,且只执行一次
@AfterAll用于 "静态" 方法,在所有的 @AfterEach 之前被执行,且只执行一次

2、Lombok

注解说明
@Settersetter 方法
@Gettergetter 方法
@Datasetter 和 getter 方法
@AllArgsConstructor全参构造器
@NoArgsConstructor无参构造器
@Slf4j日志对象

3、Mybatis

注解说明
@Param("rename")写在方法的参数列表上,起别名
@Insert("sql")
@Delete("sql")
@Update("sql")
@Select("sql")
@Results({...}) 配合 @Result 使用结果集封装
@One(select="类.方法")结果集封装
@Many(select="类.方法")结果集封装
@Result(id = true / false, property = "", javaType = .class,
column = "", one = @One(), many = @Many(), fetchType = FetchType.)
结果集封装
@CacheNamespace在 Mapper 接口中配置二级缓存
@Mapper使用在 mapper 层类(mapper 接口)上用于实例化 Bean
@MapperScan("com.zzw.mapper")如果想让每个接口都变成实现类,需要在每个接口类上加上 @Mapper 注解,太麻烦
在 Springboot 启动类上面添加 @MapperScan("com.zzw.mapper")
  1. * fetchType = FetchType.LAZY 表示懒加载
  2. * fetchType = FetchType.EAGER 表示立即加载
  3. * fetchType = FetchType.DEFAULT 表示使用全局配置
  1. public interface OrderMapper {
  2. @Select("select * from orders")
  3. @Results({
  4. @Result(id = true, column = "id", property = "id"),
  5. @Result(column = "ordertime", property = "ordertime"),
  6. @Result(column = "money", property = "money"),
  7. @Result(property = "user", javaType = User.class, column = "uid",
  8. one = @One(select = "com.lagou.mapper.UserMapper.findById", fetchType = FetchType.EAGER))
  9. })
  10. public List<Order> findAllWithUser();
  11. }

image

4、Spring

4.1、IOC

控制反转:对象不再自己创建,而是直接向 Spring 要

image

注解说明
@Component使用在类上用于实例化 Bean
@Controller使用在 controler 层类上用于实例化 Bean
@Service使用在 service 层类上用于实例化 Bean
@Repository使用在 mapper 层类上用于实例化 Bean
@Mapper使用在 mapper 层类(mapper 接口)上用于实例化 Bean(Mybatis 的)
@Bean使用在方法上,标注将该方法的返回值存储到 Spring 容器中(如果当前方法需要参数,它会自动在容器中查找装配)
@Scope标注 Bean 的作用范围,singleton、prototype
@LazyBean 是否懒加载,Spring 会在使用这个对象的时候,进行对象的创建
@PostConstruct使用在方法上,标注该方法是 Bean 的初始化方法(Java 的)
@PreDestroy使用在方法上,标注该方法是 Bean 的销毁方法(Java 的)
  1. * 在 Spring 中,对于 bean 支持五种作用范围
  2. - singleton 单例模式,即对象只创建一次,然后一直存在(默认)
  3. 容器初始化,对象创建;容器销毁,对象销毁
  4. - prototype 多例模式,即每次获取 bean 的时候,IOC 都给我们创建一个新对象
  5. 每一次调用 getBean 获取对象的时候,对象创建
  6. 对象销毁是由对象调用线程所在的垃圾回收期负责,Spring 不知道这个销毁的时间节点
  7. - 面试
  8. - request web 项目中,Spring 创建一个 Bean 的对象,将对象存入到 request 域中(一次请求)
  9. - session web 项目中,Spring 创建一个 Bean 的对象,将对象存入到 session 域中(一次会话)
  10. - globalSession 用于分布式 web 开发中,创建的实例绑定全局 session 对象
  11. 1、构造方法
  12. 初始化之前 postProcessBeforeInitialization(BeanPostProcessor)
  13. 2、初始化 afterProperitesSet(InitializingBean)、init-method
  14. 初始化之后 postProcessAfterInitialization(BeanPostProcessor)
  15. 3、销毁 destroy(DisposableBean)、destroy-method

4.2、DI

依赖注入

注解说明
@Autowired使用在字段上用于根据类型依赖注入
@Qualifier结合 @Autowired 一起使用,用于根据名称进行依赖注入
@Resource相当于 @Autowired + @Qualifier,按照名称进行注入(Java 的)
@Value注入普通属性(8 + String)(注入配置文件)
@PropertySource("db.properties") + @Value("${jdbc.url}")用于加载 .properties 文件中的配置

4.3、AOP

面向切面

注解说明
@Component指定是组件
@Aspect指定这个组件是 AOP 的增强类
@Order设置增强类优先级
@Pointcut指定方法为切入点
@Before前置通知
@AfterReturning后置通知
@AfterThrowing异常通知
@After最终通知
@Around环绕通知
@EnableAspectJAutoProxy(proxyTargetClass = true)0 xml 配置,切面自动代理,AOP 自动生成代理对象
告知 Spring 基于注解进行 AOP 编程,默认 JDK 代理,true 为 CGLib 代理
Spring AOP 代理默认实现 JDK,Springboot A0P 代理默认实现 Cglib

通过一个表达式来确定 AOP 要增强的是哪个或者那些方法
语法结构:execution( [权限修饰符] [返回值类型] [类的全路径名] [方法名] [参数列表] )(权限修饰符可以省略)

  1. '*' 一个或多个
  2. '..' 零个或多个
  1. execution(* com.zzw.dao.UserDaoImpl.add(..)) // 指定切点为 UserDaoImpl.add 方法 execution: 执行、实施
  2. execution(* com.zzw.dao.UserDaoImpl.*(..)) // 指定切点为 UserDaoImpl 所有的方法
  3. execution(* com.zzw.dao.*.*(..)) // 指定切点为 dao 包下所有的类中的所有的方法
  4. execution(* com.zzw.dao.*.add(..)) // 指定切点为 dao 包下所有的类中的 add 的方法
  5. execution(* com.zzw.dao.*.add*(..)) // 指定切点为 dao 包下所有的类中的 add 开头的方法
  6. execution(* *(..)) // 所有的方法
  1. - 前置通知(before) 在切点运行 "之前" 执行
  2. - 后置通知(after-returning) 在切点正常运行结束 "之后" 执行
  3. - 异常通知(after-throwing) 在切点 "发生异常" 的时候执行
  4. - 最终通知(after) 在切点的 "最终" 执行
  1. try {
  2. 前置通知(before)
  3. // 切点执行的位置
  4. 后置通知(after-returning)
  5. } catch (Exception e) {
  6. 异常通知(after-throwing)
  7. } finally {
  8. 最终通知(after)
  9. }
  1. try {
  2. begin(); // 开启事务
  3. obj = pjp.proceed(); // 切点执行的位置
  4. commit(); // 提交事务
  5. } catch (Throwable e) {
  6. rollback(); // 回滚事务
  7. } finally {
  8. close(); // 关闭事务
  9. }
  10. return obj;

4.4、事务

Spring 事务

注解说明
@Transactional加在类上,代表类中的所有方法都添加了事务控制
放在方法上,就是仅仅对当前方法增加了事务控制
@EnableTransactionManagement开启事务注解

4.5、配置

注解说明
@Configuration用于指定当前类是一个 Spring 配置类,当创建容器时会从该类上加载注解
@Import(DbConfig.class)用于导入其他配置类
@ComponentScan("com.itheima")用于指定 Spring 在初始化容器时要扫描的包
@Bean使用在方法上,标注将该方法的返回值存储到 Spring 容器中
如果当前方法需要参数,它会自动在容器中查找装配
@PropertySource("db.properties") + @Value("${jdbc.url}")
@PropertySource("classpath:jdbc.properties")
用于加载 .properties 文件中的配置
  1. @Configuration
  2. @Import(DbConfig.class)
  3. @ComponentScan("com.zzw")
  4. public class SpringConfig {
  5. @Bean // @Bean 还相当于 @AutoWired 标注一个方法上, 也就是说如果当前方法需要参数, 它会自动在容器中查找装配
  6. public JdbcTemplate jdbcTemplate(DataSource dataSource) {
  7. JdbcTemplate jdbcTemplate = new JdbcTemplate();
  8. jdbcTemplate.setDataSource(dataSource);
  9. return jdbcTemplate;
  10. }
  11. }
  12. ApplicationContext context = new AnnotationConfigApplicationContext(SpringConfig.class);
  1. @PropertySource("db.properties")
  2. public class DbConfig {
  3. @Value("${jdbc.driver}")
  4. private String driver;
  5. @Value("${jdbc.url}")
  6. private String url;
  7. @Value("${jdbc.username}")
  8. private String username;
  9. @Value("${jdbc.password}")
  10. private String password;
  11. @Bean
  12. public DruidDataSource dataSource() {
  13. DruidDataSource dataSource = new DruidDataSource();
  14. dataSource.setDriverClassName(driver);
  15. dataSource.setUrl(url);
  16. dataSource.setUsername(username);
  17. dataSource.setPassword(password);
  18. return dataSource;
  19. }
  20. }
  1. # db.properties
  2. jdbc.driver=com.mysql.jdbc.Driver
  3. jdbc.url=jdbc:mysql:///spring
  4. jdbc.username=root
  5. jdbc.password=root

5、SpringMVC

文件上传、异常处理、拦截器

注解说明
@Controller标注类作为控制器(处理器)
@RequestMapping用于建立请求 URL 和处理请求方法之间的对应关系,路径、方法、参数、请求头
@PostMapping、@DeleteMapping、@PutMapping、@GetMapping对请求方式进行控制,增删改查
@CrossOrigin(origins = {"http://localhost:3000"})允许跨域
--------------------------------------------------------------------------------------------------------------------
@PathVariable可以获取请求 URL 路径中的参数值,Restful 风格
@RequestParam处理参数名称,默认值、非必须、接收 List
@RequestBody标注在参数前面,用于将请求体(get 没有请求体)中的 Json 数据转换成指定的对象
如果没有具体的实体类来接收参数,就要用 Map 来接收
@RequestHeader接收请求头,Map<String, String> headers 获取所有请求头、获取指定键的请求头
@CookieValue("JSESSIONID")获取 Cookie 中的数据
@DateTimeFormat(pattern = "yyyy-MM-dd")日期类型转换,可以用于方法参数列表和类的属性上(入参)
@JsonFormat(pattern = "yyyy-MM-dd", timezone = "GMT+8")处理响应 Json 数据的处理,可以用于方法参数列表和类的属性上(出参)
@ResponseBody标注在方法或者类上,表示将方法返回值对象转换成指定的形式(Json / 字符串),直接写回响应
@RestController = @Controller + @Responsebody返回 Json 数据,不需要在方法前面加 @ResponseBody 注解了
@SessionAttributes("username")向 request 域存入的 key 为 username 时,同步到 session 域中
--------------------------------------------------------------------------------------------------------------------
@ControllerAdvice要标注在类上,表示当前类是一个全局异常处理器的类
@RestControllerAdvice要标注在类上,表示当前类是一个全局异常处理器的类,方法返回值自动转 Json
@ExceptionHandler(Throwable.class)标注在方法上,表示当前方法可以处理哪些异常

6、Springboot

注解说明
@SpringBootApplication启动类
@SpringBootTest(classes=SpringbootApplication.class)测试类
@Configuration(proxyBeanMethods = true)配置类
@ConfigurationProperties(prefix = "datasource")读取配置文件信息,来给被标注的类的属性赋值,当前类必须放到容器中才生效

参考文献:注解总结 - lidongdongdong~ - 博客园 (cnblogs.com)

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/你好赵伟/article/detail/328906
推荐阅读
相关标签
  

闽ICP备14008679号