2016-11-18 52 views
1

我正在处理spring引导应用程序的异常处理。我创建了自己的异常类巫婆我扔,一切工作正常我在控制台中得到异常,但我无法达到我的@ExceptionHandler方法。未达到Spring引导@ExceptionHandler

我的类,它抛出异常:

@Override 
public AuctionBody insertNewAuction(AuctionBody auctionBody, int ownerId, String AUCTION_TYPE) { 
    try { 
     SimpleJdbcInsert simpleJdbcInsert = new SimpleJdbcInsert(dataSource).withTableName("auctions") 
       .usingGeneratedKeyColumns("id"); 
     Map<String, Object> parameters = new HashMap<String, Object>(); 
     parameters.put("title", auctionBody.getTitle()); 
     parameters.put("type", auctionBody.getType()); 
     parameters.put("start_time", Timestamp.valueOf(auctionBody.getStartDate())); 
     parameters.put("end_time", Timestamp.valueOf(auctionBody.getEndDate())); 
     parameters.put("quantity", auctionBody.getItemQuantity()); 
     parameters.put("starting_price", auctionBody.getStartingPrice()); 
     parameters.put("currency", auctionBody.getCurrency()); 
     parameters.put("status", auctionBody.getStatus()); 
     parameters.put("description", null); 
     parameters.put("allow_bid_for_quantity", auctionBody.isAllowToBidForQuantity()); 
     parameters.put("buy_out_price", auctionBody.getBuyOutPrice()); 
     parameters.put("owner_id", ownerId); 
     parameters.put("buy_out_price", auctionBody.getBuyOutPrice()); 
     parameters.put("quantity_left", auctionBody.getItemQuantity()); 
     parameters.put("uuid", auctionBody.getAuctionIdUrlOwner()); 
     parameters.put("allow_buy_out", auctionBody.isAllowBuyOut()); 
     parameters.put("link", auctionBody.getLink()); 
     auctionBody.setId((Integer) simpleJdbcInsert.executeAndReturnKey(parameters)); 


     insertNewAuctionPictures(auctionBody, auctionBody.getId()); 
     if (AUCTION_TYPE.equals("FullAuction")) { 
      insertPeopleToInvite(auctionBody); 
     } 

     return auctionBody; 
    }catch (DataAccessException e){ 
     throw new JdbcExceptions("Cant add auction"); 
    } 
} 

例外是因为描述为空(我这样做只是检查,如果我会得到我的创建异常处理程序或没有)的抛出。

Exception类看起来是这样的:

public class JdbcExceptions extends RuntimeException { 
public JdbcExceptions(String message) { 
    super(message); 
} 

}

和异常处理程序控制器类看起来是这样的:

@ControllerAdvice 
public class ExceptionHandlingController { 

    @ExceptionHandler(JdbcExceptions.class) 
    @ResponseStatus(HttpStatus.INTERNAL_SERVER_ERROR) 
    public String getJdbcException(JdbcExceptions ex){ 
     return "redirect:/html/errorPage"; 
    } 
} 

我知道,它应该工作,我相信我有一些不良的配置,使我的@ExceptionHandler无法访问,但我还没有找到答案。 另外ExceptionHandlingController类是在应用程序运行时创建的。

主要类:

package com.visma.seli; 

import com.visma.seli.config.properties.repository.DatabaseProperties; 
import com.visma.seli.config.properties.repository.RepositoryProperties; 
import org.springframework.boot.Banner; 
import org.springframework.boot.SpringApplication; 
import org.springframework.boot.autoconfigure.EnableAutoConfiguration; 
import org.springframework.boot.autoconfigure.SpringBootApplication; 
import org.springframework.boot.builder.SpringApplicationBuilder; 
import org.springframework.boot.context.properties.EnableConfigurationProperties; 
import org.springframework.boot.web.support.SpringBootServletInitializer; 
import org.springframework.context.ApplicationContext; 
import org.springframework.context.annotation.ComponentScan; 
import org.springframework.scheduling.annotation.EnableScheduling; 
import org.springframework.web.servlet.DispatcherServlet; 

@SpringBootApplication 
@EnableConfigurationProperties({RepositoryProperties.class, DatabaseProperties.class}) 
@EnableScheduling 
@ComponentScan() 
@EnableAutoConfiguration 
public class SeliApplication extends SpringBootServletInitializer { 

    public static void main(String[] args) { 
     ApplicationContext ctx = SpringApplication.run(SeliApplication.class, args); 
     DispatcherServlet dispatcherServlet = (DispatcherServlet)ctx.getBean("dispatcherServlet"); 
     dispatcherServlet.setThrowExceptionIfNoHandlerFound(true); 
    } 

    @Override 
    protected SpringApplicationBuilder configure(SpringApplicationBuilder builder) { 
     return builder.bannerMode(Banner.Mode.OFF).sources(SeliApplication.class); 
    } 

    @Override 
    protected SpringApplicationBuilder createSpringApplicationBuilder() { 
     return new SpringApplicationBuilder().bannerMode(Banner.Mode.OFF); 
    } 
} 

在我的应用程序没有其他异常处理程序,并抛出后,我得到的消息,我设置Cant add auction

+0

那么抛出'JdbcExceptions'时究竟发生了什么?你有没有登录控制台?你的应用程序中是否有其他异常处理程序? –

+0

您可以添加SpringBoot主类和ExceptionHandlingController输入语句的代码吗? – developer

+0

为弹簧启动提供您的配置。看来@ControlerAdvice没有被检测到。 – ScanQR

回答

0

你可以尝试添加@EnableWebMvc到您的配置文件

@Configuration 
@EnableWebMvc 
@ComponentScan(...) 
public class MyAppConfiguration { 

}