springMvc理解
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注解的作用是将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 将请求体写入某个对象