接口介绍
HandlerMethodReturnValueHandler是RequestMappingHandlerAdapter用来处理完映射控制类,对方法返回的值进一步进行处理。
接口定义
/**
* 策略模式接口:处理 Controller 方法返回值
*/
public interface HandlerMethodReturnValueHandler {
/**
* 该处理程序是否支持给定的方法返回类型(只有返回true才回去调用handleReturnValue)
*/
boolean supportsReturnType(MethodParameter returnType);
/**
* 处理给定的返回值
* 通过向 ModelAndViewContainer 添加属性和设置视图或者
* 通过调用 ModelAndViewContainer.setRequestHandled(true) 来标识响应已经被直接处理(不再调用视图解析器)
*/
void handleReturnValue(Object returnValue, MethodParameter returnType,
ModelAndViewContainer mavContainer, NativeWebRequest webRequest) throws Exception;
}
例子
在定义自己的handler
public class MyHandlerMethodReturnValueHandler implements HandlerMethodReturnValueHandler {
@Override
public boolean supportsReturnType(MethodParameter returnType) {
return returnType.getParameterType() == Person.class;
}
@Override
public void handleReturnValue(Object returnValue, MethodParameter returnType, ModelAndViewContainer mavContainer, NativeWebRequest webRequest) throws Exception {
Assert.isInstanceOf(Person.class, returnValue);
//标识请求是否已经在该方法内完成处理
mavContainer.setRequestHandled(true);
// 获取方法上的注解
PersonAnnotation personAnnotation = returnType.getMethodAnnotation(PersonAnnotation.class);
HttpServletResponse response = webRequest.getNativeResponse(HttpServletResponse.class);
response.setContentType("text/plain;charset=UTF-8");
Person person = (Person) returnValue;
response.getWriter().println(personAnnotation.value() + ":" + person);
}
}
定义controller类
@Controller
public class DemoController {
@PersonAnnotation("person")
@RequestMapping(value = "/demo", method = RequestMethod.GET)
public Person getPerson() {
return new Person("xiya", 25);
}
}