Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
普通程序员一名
spring-framework
提交
3b7691d5
S
spring-framework
项目概览
普通程序员一名
/
spring-framework
与 Fork 源项目一致
从无法访问的项目Fork
通知
1
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
S
spring-framework
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
提交
3b7691d5
编写于
8月 18, 2009
作者:
A
Arjen Poutsma
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
SPR-6008 - @ResponseStatus on @ExceptionHandler method is ignored
上级
5680cd4a
变更
3
隐藏空白更改
内联
并排
Showing
3 changed file
with
35 addition
and
10 deletion
+35
-10
org.springframework.web.servlet/src/main/java/org/springframework/web/servlet/mvc/annotation/AnnotationMethodHandlerExceptionResolver.java
.../annotation/AnnotationMethodHandlerExceptionResolver.java
+26
-10
org.springframework.web.servlet/src/test/java/org/springframework/web/servlet/mvc/annotation/AnnotationMethodHandlerExceptionResolverTests.java
...tation/AnnotationMethodHandlerExceptionResolverTests.java
+5
-0
org.springframework.web/src/main/java/org/springframework/web/bind/annotation/ExceptionHandler.java
...springframework/web/bind/annotation/ExceptionHandler.java
+4
-0
未找到文件。
org.springframework.web.servlet/src/main/java/org/springframework/web/servlet/mvc/annotation/AnnotationMethodHandlerExceptionResolver.java
浏览文件 @
3b7691d5
...
...
@@ -44,6 +44,7 @@ import org.springframework.util.ClassUtils;
import
org.springframework.util.ObjectUtils
;
import
org.springframework.util.ReflectionUtils
;
import
org.springframework.web.bind.annotation.ExceptionHandler
;
import
org.springframework.web.bind.annotation.ResponseStatus
;
import
org.springframework.web.bind.support.WebArgumentResolver
;
import
org.springframework.web.context.request.NativeWebRequest
;
import
org.springframework.web.context.request.ServletWebRequest
;
...
...
@@ -89,14 +90,14 @@ public class AnnotationMethodHandlerExceptionResolver extends AbstractHandlerExc
if
(
handler
!=
null
)
{
Method
handlerMethod
=
findBestExceptionHandlerMethod
(
handler
,
ex
);
if
(
handlerMethod
!=
null
)
{
Native
WebRequest
webRequest
=
new
ServletWebRequest
(
request
,
response
);
Servlet
WebRequest
webRequest
=
new
ServletWebRequest
(
request
,
response
);
try
{
Object
[]
args
=
resolveHandlerArguments
(
handlerMethod
,
handler
,
webRequest
,
ex
);
if
(
logger
.
isDebugEnabled
())
{
logger
.
debug
(
"Invoking request handler method: "
+
handlerMethod
);
}
Object
retVal
=
doInvokeMethod
(
handlerMethod
,
handler
,
args
);
return
getModelAndView
(
retVal
);
return
getModelAndView
(
handlerMethod
,
handler
.
getClass
(),
retVal
,
webRequest
);
}
catch
(
Exception
invocationEx
)
{
logger
.
error
(
"Invoking request method resulted in exception : "
+
handlerMethod
,
invocationEx
);
...
...
@@ -109,7 +110,7 @@ public class AnnotationMethodHandlerExceptionResolver extends AbstractHandlerExc
/**
* Finds the handler method that matches the thrown exception best.
*
* @param handler the handler object
* @param handler
the handler object
* @param thrownException the exception to be handled
* @return the best matching method; or <code>null</code> if none is found
*/
...
...
@@ -171,7 +172,9 @@ public class AnnotationMethodHandlerExceptionResolver extends AbstractHandlerExc
return
result
;
}
/** Returns the best matching method. Uses the {@link DepthComparator}. */
/**
* Returns the best matching method. Uses the {@link DepthComparator}.
*/
private
Method
getBestMatchingMethod
(
Exception
thrownException
,
Map
<
Class
<?
extends
Throwable
>,
Method
>
resolverMethods
)
{
if
(!
resolverMethods
.
isEmpty
())
{
...
...
@@ -186,7 +189,9 @@ public class AnnotationMethodHandlerExceptionResolver extends AbstractHandlerExc
}
}
/** Resolves the arguments for the given method. Delegates to {@link #resolveCommonArgument}. */
/**
* Resolves the arguments for the given method. Delegates to {@link #resolveCommonArgument}.
*/
private
Object
[]
resolveHandlerArguments
(
Method
handlerMethod
,
Object
handler
,
NativeWebRequest
webRequest
,
...
...
@@ -221,7 +226,7 @@ public class AnnotationMethodHandlerExceptionResolver extends AbstractHandlerExc
* then checking {@link #resolveStandardArgument}.
*
* @param methodParameter the method parameter
* @param webRequest the request
* @param webRequest
the request
* @param thrownException the exception thrown
* @return the argument value, or {@link WebArgumentResolver#UNRESOLVED}
*/
...
...
@@ -256,8 +261,8 @@ public class AnnotationMethodHandlerExceptionResolver extends AbstractHandlerExc
* request {@link InputStream}, request {@link Reader}, response {@link OutputStream}, response {@link Writer},
* and the given {@code thrownException}.
*
* @param parameterType the method parameter type
* @param webRequest the request
* @param parameterType
the method parameter type
* @param webRequest
the request
* @param thrownException the exception thrown
* @return the argument value, or {@link WebArgumentResolver#UNRESOLVED}
*/
...
...
@@ -319,7 +324,16 @@ public class AnnotationMethodHandlerExceptionResolver extends AbstractHandlerExc
}
@SuppressWarnings
(
"unchecked"
)
private
ModelAndView
getModelAndView
(
Object
returnValue
)
{
private
ModelAndView
getModelAndView
(
Method
handlerMethod
,
Class
handlerType
,
Object
returnValue
,
ServletWebRequest
webRequest
)
throws
Exception
{
if
(
handlerMethod
.
isAnnotationPresent
(
ResponseStatus
.
class
))
{
ResponseStatus
responseStatus
=
handlerMethod
.
getAnnotation
(
ResponseStatus
.
class
);
HttpServletResponse
response
=
webRequest
.
getResponse
();
response
.
setStatus
(
responseStatus
.
value
().
value
());
}
if
(
returnValue
instanceof
ModelAndView
)
{
return
(
ModelAndView
)
returnValue
;
}
...
...
@@ -343,7 +357,9 @@ public class AnnotationMethodHandlerExceptionResolver extends AbstractHandlerExc
}
}
/** Comparator capable of sorting exceptions based on their depth from the thrown exception type. */
/**
* Comparator capable of sorting exceptions based on their depth from the thrown exception type.
*/
private
static
class
DepthComparator
implements
Comparator
<
Class
<?
extends
Throwable
>>
{
private
final
Class
<?
extends
Throwable
>
handlerExceptionType
;
...
...
org.springframework.web.servlet/src/test/java/org/springframework/web/servlet/mvc/annotation/AnnotationMethodHandlerExceptionResolverTests.java
浏览文件 @
3b7691d5
...
...
@@ -30,7 +30,9 @@ import org.springframework.mock.web.MockHttpServletResponse;
import
org.springframework.stereotype.Controller
;
import
org.springframework.util.ClassUtils
;
import
org.springframework.web.bind.annotation.ExceptionHandler
;
import
org.springframework.web.bind.annotation.ResponseStatus
;
import
org.springframework.web.servlet.ModelAndView
;
import
org.springframework.http.HttpStatus
;
/** @author Arjen Poutsma */
public
class
AnnotationMethodHandlerExceptionResolverTests
{
...
...
@@ -56,6 +58,8 @@ public class AnnotationMethodHandlerExceptionResolverTests {
ModelAndView
mav
=
exceptionResolver
.
resolveException
(
request
,
response
,
controller
,
ex
);
assertNotNull
(
"No ModelAndView returned"
,
mav
);
assertEquals
(
"Invalid view name returned"
,
"BindException"
,
mav
.
getViewName
());
assertEquals
(
"Invalid status code returned"
,
406
,
response
.
getStatus
());
}
@Test
(
expected
=
IllegalStateException
.
class
)
...
...
@@ -74,6 +78,7 @@ public class AnnotationMethodHandlerExceptionResolverTests {
}
@ExceptionHandler
(
BindException
.
class
)
@ResponseStatus
(
HttpStatus
.
NOT_ACCEPTABLE
)
public
String
handleBindException
(
Exception
ex
,
HttpServletResponse
response
)
{
return
ClassUtils
.
getShortName
(
ex
.
getClass
());
}
...
...
org.springframework.web/src/main/java/org/springframework/web/bind/annotation/ExceptionHandler.java
浏览文件 @
3b7691d5
...
...
@@ -83,6 +83,10 @@ import java.lang.annotation.Target;
* only applicable in a Servlet environment).
* </ul>
*
* <p>In Servlet environments, you can combine the {@code ExceptionHandler} annotation
* with {@link ResponseStatus @ResponseStatus}, to define the response status
* for the HTTP response.
*
* <p><b>NOTE: <code>@RequestMapping</code> will only be processed if a
* corresponding <code>HandlerMapping</code> (for type level annotations)
* and/or <code>HandlerAdapter</code> (for method level annotations) is
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录