web.xml中的配置

理解:let’go为请求的入口,负责处理所有的请求,为DiapatcherServlet类型,他和servelet一样属于多线程单实例。

(利用反射原理创建出来servle,根据配置文件进行个性化的配置)

springmvc的xml配置文件

可以通过contextConfigLocation指定配置文件的路径,如果不指定则默认为WEN-INF文件夹下

Controller层详解

DiapatcherServlet详解

HttpServletBean继承自Httpservlet用来将servlet的一些配置设置到相应的属性(请求以及tomcat),FrameWorkServlet初始化了webApplicationContext(spring相关),DispatcherSrevlet初始化了自身9大组件。

9大组件

HandlerMapping

他的作用是根据具体的request(url)找到具体的Handler处理器,或者Interceptor(一般用来指一个Controller的对象)

HandlerAdapter

用来调用处理器来处理业务,处理后会返回一个ModelAndView

ViewResolver

根据字符串(名称)调用模版引擎生成一个特定的View,View使用指定的技术将程序的参数处理生成html页面返回给浏览器,需要request和local参数(local用来根据不同的地区设置不同的返回页面分格)

RequestToViewNameTranslator

当没有指定返回的页面时,就是将请求名称作为视图名称返回

返回的数据类型

返回ModelAndView

返回ModelAndView时最常见的一种返回结果。需要在方法结束的时候定义一个ModelAndView对象,并对Model和View分别进行设置。

返回String

1):字符串代表逻辑视图名

真实的访问路径=“前缀”+逻辑视图名+“后缀”

注意:如果返回的String代表逻辑视图名的话,那么Model的返回方式如下:

   public String testController(Model model){
model.addAttribute(attrName,attrValue);//相当于ModelAndView的addObject方法
return “逻辑视图名”;
   }

2):代表redirect重定向

redirect的特点和servlet一样,使用redirect进行重定向那么地址栏中的URL会发生变化,同时不会携带上一次的request

案例:

public String testController(Model model){
return “redirect:path”;//path代表重定向的地址
}

3):代表forward转发

通过forward进行转发,地址栏中的URL不会发生改变,同时会将上一次的request携带到写一次请求中去

案例:
public String testController(Model model){
return “forward:path”;//path代表转发的地址
}

3、返回void

返回这种结果的时候可以在Controller方法的形参中定义HTTPServletRequest和HTTPServletResponse对象进行请求的接收和响应,响应的view应该也是该请求的view

1)使用request转发页面
  request.getRequestDispatcher(“转发路径”).forward(request,response);

2)使用response进行页面重定向
  response.sendRedirect(“重定向路径”);

3)也可以使用response指定响应结果
  response.setCharacterEncoding(“UTF-8”);
  response.setContentType(“application/json;charset=utf-8”);
  response.getWriter.write(“json串”);

注解

@responseBody

@responseBody注解的作用是将controller的方法返回的对象通过适当的转换器转换为指定的格式之后,写入到response对象的body区,通常用来返回JSON数据或者是XML(对象的形式的化返回json格式,string直接输出到一个页面里)

数据,需要注意的呢,在使用此注解之后不会再走试图处理器,而是直接将数据写入到输入流中,他的效果等同于通过response对象输出指定格式的数据。

@RequestMapping(“/login”)
@ResponseBody

 public User login(User user){
    return user;
  }
  User字段:userName pwd
  那么在前台接收到的数据为:'{“userName”:”xxx”,”pwd”:”xxx”}’

  效果等同于如下代码:
  @RequestMapping(“/login”)
  public void login(User user, HttpServletResponse response){
    response.getWriter.write(JSONObject.fromObject(user).toString());
  }

@Responsebody 注解表示该方法的返回的结果直接写入 HTTP 响应正文(ResponseBody)中,一般在异步获取数据时使用;
在使用 @RequestMapping 后,返回值通常解析为跳转路径,加上 @Responsebody 后返回结果不会被解析为跳转路径,而是直接写入HTTP 响应正文中。例如,异步获取 json 数据,加上 @Responsebody 注解后,就会直接返回 json 数据。
@RequestBody 注解则是将 HTTP 请求正文插入方法中,使用适合的 HttpMessageConverter 将请求体写入某个对象

版权声明:本文为gdfs原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://www.cnblogs.com/gdfs/p/10912487.html