开发者

Spring 3, ReST, @ResponseBody and @ExceptionHandler

I have been trying to get exception handling working in my simple Spring 3 based ReST web services. Based on everything I have seen, there is a bug that prevents this from working automatically with the @ResponseBody and @ExceptionHandler annotations

h开发者_运维技巧ttps://jira.springsource.org/browse/SPR-6902

So given that it isn't supported until Spring 3.1 or 3.0.6, what is the current best method for doing exception handling? I have seen numerous posts but haven't found a clear answer that has worked for me. An ideal solution would be one that automatically provides support for both xml and json

  • Do I have to manually define the entire marshalling setup? Won't this remove the need for the annotations that make using Spring 3 rest support worth it?
  • Seems in order to manually define marshalling (i.e. Jaxb2Marshaller) I need to add a new dependency on spring-ws which is a bit of a pain
  • Is it easier to just define a 'Response' object that all my methods return and wrap all functions in try/catch blocks?


You can redirect on error and then return something in @ResponseBody:

@ExceptionHandler(Exception.class)
public ModelAndView handleMyException(Exception  exception) {
    return new ModelAndView("redirect:errorMessage?error="+exception.getMessage());
} 

@RequestMapping(value="/errorMessage", method=RequestMethod.GET)
@Responsebody
public String handleMyExceptionOnRedirect(@RequestParameter("error") String error) {
    return error;
} 

Little ugly, but this is just work around till the fix will be available.


This is a good workaround, but with one addition. The @ExceptionHandler(Exception.class) should be @ExceptionHandler(MyException.class, YourException.class) as you can get into a loop using the general Exception class.

You can then test for (ex instanceof Myexception) to determine the message to display if need be.

0

上一篇:

下一篇:

精彩评论

暂无评论...
验证码 换一张
取 消

最新问答

问答排行榜