springboot和springcloud及常用注解积累

5 篇文章 0 订阅
2 篇文章 0 订阅

@SpringBootApplication是springboot启动类,包括三个注解(@ComponentScan && @Configuration && @EnableAutoConfiguration),他们的作用分别是:
@Configuration: 表示将该类作用springboot配置文件类

@EnableAutoConfiguration:表示程序启动时,自动加载springboot默认的配置

@ComponentScan:表示程序启动是,自动扫描当前包及子包下所有类,@ComponentScan 如果不设置basePackage的话 默认会扫描包的所有类,可根据basePackage 扫描指定的包,减少加载时间。默认扫描**/.class路径 比如这个注解在com.wuhulala 下面 ,那么会扫描这个包下的所有类还有子包的所有类,比如com.wuhulala.service包的应用

@Configuration 表示这个类中定义了Bean,会把这个类中bean加载到spring容器中
@EnableAutoConfiguration 表示 会在你开启某些功能的时候自动配置,告诉Spring Boot根据添加的jar依赖猜测你想如何配置Spring。
由于spring-boot-starter-web添加了Tomcat和Spring MVC,所以auto-configuration将假定你正在开发一个web应用,并对Spring进行相应地设置。

@Mapper && @MapperScan
Mapper类上面添加注解@Mapper,这种方式要求每一个mapper类都需要添加此注解
@MapperScan 可以指定要扫描的Mapper类的包的路径(@MapperScan(“com.demo…mapper”) || @MapperScan(“com.test…mapper", "com.demo…mapper”))

@EnableTransactionManagement && @Transactional
Spring Boot 使用事务非常简单,首先使用注解 @EnableTransactionManagement (启注解事务管理,等同于xml配置方式的 <tx:annotation-driven />)
开启事务支持后,然后在访问数据库的Service方法上添加注解 @Transactional 便可。

@Async && @EnableAsync
@EnableAsync 注解的意思是可以异步执行,就是开启多线程的意思。可以标注在方法、类上。
为了让@Async注解能够生效,需要在Spring Boot的主程序中配置@EnableAsync
@Async 所修饰的函数不要定义为static类型,这样异步调用不会生效

@Bean && @Configuration
@Configuration 标注在类上,相当于把该类作为spring的xml配置文件中的,作用为:配置spring容器(应用上下文)
@Bean 标注注册一个javabean 类似ssm框架的

@GetMapping && @PostMapping
Spring4.3中引进了{@GetMapping、@PostMapping、@PutMapping、@DeleteMapping、@PatchMapping},来帮助简化常用的HTTP方法的映射,并更好地表达被注解方法的语义。
@GetMapping是一个组合注解,是@RequestMapping(method = RequestMethod.GET)的缩写。该注解将HTTP Get 映射到 特定的处理方法上。
@PostMapping是一个组合注解,是@RequestMapping(method = RequestMethod.POST)的缩写。该注解将HTTP Post映射到 特定的处理方法上。

@springCloudApplication 应用开启入口 比@SpringBootApplication更强大
@EnableEurekaClient开启eureka客户端 可以调用在eureka注册的服务
@EnableDiscoveryClient 不仅可以开启eureka客户端,还有consul、zookeeper
@EnableEurekaServer 开启eureka服务端 类似于注册中心zookeeper
@EnableFeignClients 开启负载均衡 包装了Ribbon
@FeignClient: 发现服务
@EnableHystrix 开启容错保护
@EnableZuulProxy 开启网关代
@MapperScan(“com.xxx.user.mapper”) 扫描mapper包,可以直接注入
标注在启动类的resttempalte方法上(负载均衡)

@LoadBalanced 开启负载均衡(客户端) 配合@EnableFeignClients
标注在javaconfig文件
@PropertySource扫描外部资源文件properties 用来配置javabean
标注在service方法
@HystrixCommand(fallbackMethod = “login”) 容错保护,配合**@EnableHystrix**
@Cacheable(value = “key” ) redis库的value就是你的返回值

@ResponseBody 注解表示该方法的返回的结果直接写入 HTTP 响应正文(ResponseBody)中,一般在异步获取数据时使用,通常是在使用 @RequestMapping 后,返回值通常解析为跳转路径,加上 @Responsebody 后返回结果不会被解析为跳转路径,而是直接写入HTTP 响应正文中;

作用:
该注解用于将Controller的方法返回的对象,通过适当的HttpMessageConverter转换为指定格式后,写入到Response对象的body数据区。
使用时机:
返回的数据不是html标签的页面,而是其他某种格式的数据时(如json、xml等)使用;

异步获取 json 数据,加上 @Responsebody 注解后,就会直接返回 json 数据。

@RequestBody注解则是将 HTTP 请求正文插入方法中,使用适合的 HttpMessageConverter 将请求体写入某个对象。

1) 该注解用于读取Request请求的body部分数据,使用系统默认配置的HttpMessageConverter进行解析,然后把相应的数据绑定到要返回的对象上;
2) 再把HttpMessageConverter返回的对象数据绑定到 controller中方法的参数上。

例如:

@RequestMapping(value = "user/login")
@ResponseBody
	// 将ajax(datas)发出的请求写入 User 对象中
	public User login(@RequestBody User user) {   
		// 这样就不会再被解析为跳转路径,而是直接将user对象写入 HTTP 响应正文中
	    return user;    
	}
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值