详解Spring中的JavaConfig注解

发布时间 - 2026-01-10 22:56:25    点击率:

前言

大家都知道传统spring一般都是基于xml配置的,不过后来新增了许多JavaConfig的注解。特别是springboot,基本都是清一色的java config,不了解一下,还真是不适应。这里备注一下。

@RestController

spring4为了更方便的支持restfull应用的开发,新增了RestController的注解,比Controller注解多的功能就是给底下的RequestMapping方法默认都加上ResponseBody注解,省得自己再去每个去添加该注解。

@Configuration

这个标注该类是spring的配置类,本身自带Component注解

@ImportResource

对应的xml

<import resource="applicationContext-ehcache.xml"/>

存在的必要性

这个是兼容传统xml配置的,毕竟JavaConfig还不是万能的,比如 JavaConfig不能很好地支持aop:advisor和tx:advice , Introduce @EnableAspectJAutoProxy (equivalent to aop:aspectj-autoproxy) ,Introduce @Configuration-based equivalent to aop:config XML element

@ComponentScan

对应的xml

<context:component-scan base-package="com.xixicat.app"/>

该配置自动包含了如下配置的功能:

<context:annotation-config/>

就是向Spring容器注册AutowiredAnnotationBeanPostProcessor( 使用@Autowired必须注册 )、CommonAnnotationBeanPostProcessor( 使用@Resource 、@PostConstruct、@PreDestroy等必须注册 )、PersistenceAnnotationBeanPostProcessor( 使用@PersistenceContext必须注册 ) 以及RequiredAnnotationBeanPostProcessor( 使用@Required必须注册 )这4个BeanPostProcessor。

值得注意的是 Spring3.1RC2版本 是不允许注解Configuration的类在ComponentScan指定的包范围内的,否则会报错。

@Bean

对应的xml如下:

<bean id="objectMapper" class="org.codehaus.jackson.map.ObjectMapper" />

@EnableWebMvc

对应的xml如下:

<mvc:annotation-driven />

该配置自动注册DefaultAnnotationHandlerMapping( 来注册handler method和request的mapping关系 )与AnnotationMethodHandlerAdapter( 在实际调用handler method前对其参数进行处理 )两个bean,以支持@Controller注解的使用。

主要的作用如下:

  1. 可配置的ConversionService(方便进行自定义类型转换)
  2. 支持用@NumberFormat格式化数字类型字段
  3. 支持用@DateTimeFormat格式化Date,Calendar以及Joda Time字段( 如果classpath有Joda Time的话 )
  4. 支持@Valid的参数校验( 如果JSR-303相关provider有在classpath的话 )
  5. 支持@RequestBody/@ResponseBody注解的XML读写( 如果JAXB在classpath的话 )
  6. 支持@RequestBody/@ResponseBody注解的JSON读写( 如果Jackson在classpath的话 )

@ContextConfiguration

主要在junit测试时指定java config

@RunWith(SpringJUnit4ClassRunner.class)
@ContextConfiguration({
 "classpath*:spring/*.xml",
 "classpath:applicationContext.xml",
 "classpath:applicationContext-rabbitmq.xml",
 "classpath:applicationContext-mail.xml",
 "classpath:applicationContext-medis.xml",
 "classpath:applicationContext-mybatis.xml"})
@TransactionConfiguration(transactionManager = "mybatisTransactionManager", defaultRollback = false)
public class AppBaseTest {
 //......
}

@ResponseStatus

主要是rest开发用,注解返回的http返回码,具体值看org.springframework.http.HttpStatus枚举。一般post方法返回HttpStatus.CREATED,DELETE和PUT方法返回HttpStatus.OK。还可以配置异常处理,见@ExceptionHandler和@ControllerAdvice

@ExceptionHandler

主要用来处理指定的异常,返回返回指定的HTTP状态码,省得每个controller的方法自己去try catch。一般可以为每个应用定义一个异常基类,然后再定义业务异常,这样这里就可以统一捕获业务异常。

@ExceptionHandler(BizException.class)
 @ResponseStatus(HttpStatus.BAD_REQUEST)
 public @ResponseBody
 ReturnMessage bizExceptionHandler(Exception ex) {
  logger.error(ex.getMessage(),ex);
  return new ReturnMessage(HttpStatus.BAD_REQUEST.value(),ex.getMessage());
 }

不过值得注意的是这种方法仅限于controller的方法调用链产生的异常,如果在spring里头还使用了定时任务啥的,该注解是不会拦截到的。

@ControllerAdvice

配合@ExceptionHandler使用的,用来拦截controller的方法。

@ControllerAdvice
public class ErrorController {
 
 private static final Logger logger = LoggerFactory.getLogger(ErrorController.class);
 
 @ExceptionHandler(BizException.class)
 @ResponseStatus(HttpStatus.BAD_REQUEST)
 public @ResponseBody
 ReturnMessage bizExceptionHandler(Exception ex) {
  logger.error(ex.getMessage(),ex);
  return new ReturnMessage(HttpStatus.BAD_REQUEST.value(),ex.getMessage());
 }
 
 @ExceptionHandler(Exception.class)
 @ResponseStatus(HttpStatus.INTERNAL_SERVER_ERROR)
 public @ResponseBody
 ReturnMessage serverExceptionHandler(Exception ex) {
  logger.error(ex.getMessage(),ex);
  return new ReturnMessage(HttpStatus.INTERNAL_SERVER_ERROR.value(),ex.getMessage());
 }
}

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流。


# spring  # javaconfig  # spring注解javabean  # java  # 注解  # Spring的Xml和JavaConfig 扩展哪个好用  # Spring 使用JavaConfig实现配置的方法步骤  # Spring实战之XML与JavaConfig的混合配置详解  # spring基础系列之JavaConfig配置详解  # 一文搞懂Spring中的JavaConfig  # 的是  # 都是  # 很好  # 还可以  # 大家都  # 对其  # 新增了  # 然后再  # 自定义  # 再去  # 不了解  # 这篇文章  # 自带  # 报错  # 则会  # 更方便  # 不适应  # 就可以  # 主要是  # 不是万能 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: Laravel事件监听器怎么写_Laravel Event和Listener使用教程  高防服务器租用指南:配置选择与快速部署攻略  如何快速重置建站主机并恢复默认配置?  如何用搬瓦工VPS快速搭建个人网站?  HTML透明颜色代码怎么让下拉菜单透明_下拉菜单透明背景指南【技巧】  Windows家庭版如何开启组策略(gpedit.msc)?(安装方法)  ChatGPT回答中断怎么办 引导AI继续输出完整内容的方法  佐糖AI抠图怎样调整抠图精度_佐糖AI精度调整与放大细化操作【攻略】  用v-html解决Vue.js渲染中html标签不被解析的问题  laravel怎么配置Redis作为缓存驱动_laravel Redis缓存配置教程  Win11应用商店下载慢怎么办 Win11更改DNS提速下载【修复】  微博html5版本怎么弄发语音微博_语音录制入口及时长限制操作【教程】  Laravel如何实现文件上传和存储?(本地与S3配置)  新三国志曹操传主线渭水交兵攻略  如何在VPS电脑上快速搭建网站?  微信小程序 wx.uploadFile无法上传解决办法  轻松掌握MySQL函数中的last_insert_id()  Python文件异常处理策略_健壮性说明【指导】  java ZXing生成二维码及条码实例分享  如何在建站之星网店版论坛获取技术支持?  jimdo怎样用html5做选项卡_jimdo选项卡html5实现与切换效果【指南】  html5如何设置样式_HTML5样式设置方法与CSS应用技巧【教程】  如何获取免费开源的自助建站系统源码?  如何在阿里云虚拟主机上快速搭建个人网站?  微信小程序制作网站有哪些,微信小程序需要做网站吗?  大连网站制作公司哪家好一点,大连买房网站哪个好?  Laravel任务队列怎么用_Laravel Queues异步处理任务提升应用性能  高防服务器:AI智能防御DDoS攻击与数据安全保障  Laravel如何保护应用免受CSRF攻击?(原理和示例)  js实现点击每个li节点,都弹出其文本值及修改  高防服务器租用首荐平台,企业级优惠套餐快速部署  香港服务器网站推广:SEO优化与外贸独立站搭建策略  lovemo网页版地址 lovemo官网手机登录  如何在IIS服务器上快速部署高效网站?  昵图网官方站入口 昵图网素材图库官网入口  Laravel如何处理表单验证?(Requests代码示例)  如何为不同团队 ID 动态生成多个独立按钮  Laravel如何使用Eloquent进行子查询  laravel怎么实现图片的压缩和裁剪_laravel图片压缩与裁剪方法  Windows10电脑怎么设置虚拟光驱_Win10右键装载ISO镜像文件  googleplay官方入口在哪里_Google Play官方商店快速入口指南  Edge浏览器提示“由你的组织管理”怎么解决_去除浏览器托管提示【修复】  潮流网站制作头像软件下载,适合母子的网名有哪些?  简历在线制作网站免费版,如何创建个人简历?  深圳网站制作设计招聘,关于服装设计的流行趋势,哪里的资料比较全面?  PHP正则匹配日期和时间(时间戳转换)的实例代码  Win11任务栏卡死怎么办 Windows11任务栏无反应解决方法【教程】  Laravel Asset编译怎么配置_Laravel Vite前端构建工具使用  如何在IIS中新建站点并配置端口与物理路径?  DeepSeek是免费使用的吗 DeepSeek收费模式与Pro版本功能详解