前言
民勤網(wǎng)站建設(shè)公司創(chuàng)新互聯(lián),民勤網(wǎng)站設(shè)計(jì)制作,有大型網(wǎng)站制作公司豐富經(jīng)驗(yàn)。已為民勤成百上千提供企業(yè)網(wǎng)站建設(shè)服務(wù)。企業(yè)網(wǎng)站搭建\成都外貿(mào)網(wǎng)站制作要多少錢,請找那個(gè)售后服務(wù)好的民勤做網(wǎng)站的公司定做!
大家都知道傳統(tǒng)spring一般都是基于xml配置的,不過后來新增了許多JavaConfig的注解。特別是springboot,基本都是清一色的java config,不了解一下,還真是不適應(yīng)。這里備注一下。
@RestController
spring4為了更方便的支持restfull應(yīng)用的開發(fā),新增了RestController的注解,比Controller注解多的功能就是給底下的RequestMapping方法默認(rèn)都加上ResponseBody注解,省得自己再去每個(gè)去添加該注解。
@Configuration
這個(gè)標(biāo)注該類是spring的配置類,本身自帶Component注解
@ImportResource
對應(yīng)的xml
<import resource="applicationContext-ehcache.xml"/>
存在的必要性
這個(gè)是兼容傳統(tǒng)xml配置的,畢竟JavaConfig還不是萬能的,比如 JavaConfig不能很好地支持aop:advisor和tx:advice , Introduce @EnableAspectJAutoProxy (equivalent to aop:aspectj-autoproxy) ,Introduce @Configuration-based equivalent to aop:config XML element
@ComponentScan
對應(yīng)的xml
<context:component-scan base-package="com.xixicat.app"/>
該配置自動(dòng)包含了如下配置的功能:
<context:annotation-config/>
就是向Spring容器注冊AutowiredAnnotationBeanPostProcessor( 使用@Autowired必須注冊 )、CommonAnnotationBeanPostProcessor( 使用@Resource 、@PostConstruct、@PreDestroy等必須注冊 )、PersistenceAnnotationBeanPostProcessor( 使用@PersistenceContext必須注冊 ) 以及RequiredAnnotationBeanPostProcessor( 使用@Required必須注冊 )這4個(gè)BeanPostProcessor。
值得注意的是 Spring3.1RC2版本 是不允許注解Configuration的類在ComponentScan指定的包范圍內(nèi)的,否則會(huì)報(bào)錯(cuò)。
@Bean
對應(yīng)的xml如下:
<bean id="objectMapper" class="org.codehaus.jackson.map.ObjectMapper" />
@EnableWebMvc
對應(yīng)的xml如下:
<mvc:annotation-driven />
該配置自動(dòng)注冊DefaultAnnotationHandlerMapping( 來注冊handler method和request的mapping關(guān)系 )與AnnotationMethodHandlerAdapter( 在實(shí)際調(diào)用handler method前對其參數(shù)進(jìn)行處理 )兩個(gè)bean,以支持@Controller注解的使用。
主要的作用如下:
@ContextConfiguration
主要在junit測試時(shí)指定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開發(fā)用,注解返回的http返回碼,具體值看org.springframework.http.HttpStatus枚舉。一般post方法返回HttpStatus.CREATED,DELETE和PUT方法返回HttpStatus.OK。還可以配置異常處理,見@ExceptionHandler和@ControllerAdvice
@ExceptionHandler
主要用來處理指定的異常,返回返回指定的HTTP狀態(tài)碼,省得每個(gè)controller的方法自己去try catch。一般可以為每個(gè)應(yīng)用定義一個(gè)異?;?,然后再定義業(yè)務(wù)異常,這樣這里就可以統(tǒng)一捕獲業(yè)務(wù)異常。
@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的方法調(diào)用鏈產(chǎn)生的異常,如果在spring里頭還使用了定時(shí)任務(wù)啥的,該注解是不會(huì)攔截到的。
@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()); } }
總結(jié)
以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作能帶來一定的幫助,如果有疑問大家可以留言交流。
新聞標(biāo)題:詳解Spring中的JavaConfig注解
本文地址:http://bm7419.com/article48/gosdep.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供外貿(mào)網(wǎng)站建設(shè)、商城網(wǎng)站、移動(dòng)網(wǎng)站建設(shè)、用戶體驗(yàn)、品牌網(wǎng)站制作、虛擬主機(jī)
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)