@requestParam和@requestBody注解
1.get请求
get请求推荐使用url发送数据,使用url只能用@requestParam注解
2.post请求
post请求既可以使用@requestParam也可以使用@requestBody
当请求头为json时,使用@requestBody接收
当请求头为x-www-form-urlencoded时,使用@requestParam接收
ServletRequestWrapper类以及装饰器模式
装饰器模式,可以通过装饰器类,通过依赖原实现的方式(不使用继承),达到扩展原实现的目的。UML图如下:
装饰器模式UML图
ServletRequestWrapper中的装饰模式
以getRequestParameter为例
ServletRequest
public interface ServletRequest {
String getParameter(String var1);
}
HttpServletRequestImpl,实现了HttpServletRequest,HttpServletRequest实现了ServletRequest
public final class HttpServletRequestImpl implements HttpServletRequest {
public String getParameter(String name) {
if (this.queryParameters == null) {
this.queryParameters = this.exchange.getQueryParameters();
}
Deque<String> params = (Deque)this.queryParameters.get(name);
if (params == null) {
FormData parsedFormData = this.parseFormData();
if (parsedFormData != null) {
FormValue res = parsedFormData.getFirst(name);
return res != null && !res.isFileItem() ? res.getValue() : null;
} else {
return null;
}
} else {
return (String)params.getFirst();
}
}
}
ServletRequestWrapper
需要注意的是包装类的构造方法里传入了ServletRequest接口的具体实现,调用包装类的getParameter方法就可以自定义方法的同时,调用原方法。
public class ServletRequestWrapper implements ServletRequest {
private ServletRequest request;
public ServletRequestWrapper(ServletRequest request) {
if (request == null) {
throw new IllegalArgumentException("Request cannot be null");
} else {
this.request = request;
}
}
public String getParameter(String name) {
// todo 增强方法
// ....
// 调用原方法
return this.request.getParameter(name);
}
}
springmvc的执行流程
handler通俗讲就是controller
springmvc的执行流程
1.DispatcherServlet收到请求调用service方法。
2.HandlerMapping根据请求地址找到对应的controller的名字。
3.调用controller,其中要用HandlerAdapter作为中间桥梁,减少了直接调用导致的高度耦合。
public interface HandlerAdapter {
boolean supports(Object var1);
// handle方法运用反射调用对应的controller,并返回ModelAndView
@Nullable
ModelAndView handle(HttpServletRequest var1, HttpServletResponse var2, Object var3) throws Exception;
long getLastModified(HttpServletRequest var1, Object var2);
}
HandlerAdapter为适配器接口,当有一个新的controller的时候,不需要修改原有的handlerAdapter,只需要实现HandlerAdapter接口即可,满足对扩展开放,对修改关闭的原则。