第5章—构建Spring Web应用程序—SpringMVC详解

简介: SpringMVC详解5.1.跟踪Springmvc的请求SpringMVC的核心流程如下:image具体步骤:第一步:发起请求到前端控制器(DispatcherServlet)第二步:前端控制器请求HandlerMapping...

SpringMVC详解

5.1.跟踪Springmvc的请求

SpringMVC的核心流程如下:

img_710cc5239ae652921c21baca6a262748.png
image

具体步骤:

第一步:发起请求到前端控制器(DispatcherServlet)

第二步:前端控制器请求HandlerMapping查找 Handler (可以根据xml配置、注解进行查找)

第三步:处理器映射器HandlerMapping向前端控制器返回Handler,HandlerMapping会把请求映射为HandlerExecutionChain对象(包含一个Handler处理器(页面控制器)对象,多个HandlerInterceptor拦截器对象),通过这种策略模式,很容易添加新的映射策略

第四步:前端控制器调用处理器适配器去执行Handler

第五步:处理器适配器HandlerAdapter将会根据适配的结果去执行Handler

第六步:Handler执行完成给适配器返回ModelAndView

第七步:处理器适配器向前端控制器返回ModelAndView (ModelAndView是springmvc框架的一个底层对象,包括 Model和view)

第八步:前端控制器请求视图解析器去进行视图解析 (根据逻辑视图名解析成真正的视图(jsp)),通过这种策略很容易更换其他视图技术,只需要更改视图解析器即可

第九步:视图解析器向前端控制器返回View

第十步:前端控制器进行视图渲染 (视图渲染将模型数据(在ModelAndView对象中)填充到request域)

第十一步:前端控制器向用户响应结果

5.2.编写基本的控制器

在Springmvc 中,控制器只是方法上添加@RequestMapping注解类,这个注解声明了他们所要处理的请求.如下所示:

@Controller
@RequestMapping
public class StuController {

    @RequestMapping(value="/",method = GET)
    public String home(){
        return "home";
    }
}

上面的@Controller是一个构造型注解,它基于@Component的注解.在这里,他的目的就是辅助时间组件扫描.当请求"/"路径进来后,他会通过视图解析器返回到"/WEB-INF/views/home.jsp.通过jsp的编写从而展示相关的内容到浏览者面前.

5.2.1.测试控制器

public class HomeControllerTest {
    @Test
    public void testHomePage(){
        HomeController controller =  new HomeController();
        assertEquals("home",controller.home());
        System.out.println("controller层home方法走的通");
    }
}

另外我们能够使用SpringMVC新的测试特性来进行测试:

public class HomeControllerTest {
    @Test
    public void testHomePage() throws Exception {
        HomeController controller =  new HomeController();
        //模拟mvc测试
        MockMvc mockMvc = standaloneSetup(controller).build();
        //执行GET请求 语气得到home视图
        mockMvc.perform(get("/")).andExpect(view().name("home"));
        System.out.println("模拟测试通过");
    }
}

5.2.3.传递模型数据到视图中

@Controller
@RequestMapping
public class HomeController {
    @RequestMapping(value="/",method = GET)
    public String home(String name, Student student){
        return "home";
    }

}

5.3.接受请求的输入

SpringMVC允许多种方式将客户端的数据传送到控制请的处理器的方法中,包括:

  • 查询参数
  • 表单参数
  • 路径变量

5.3.1 处理查询参数

@Autowired
    private StuService stuService;
    @RequestMapping("list")
    public String list(Model model) {
        List<Student> stuList = stuService.getAllStu();
        model.addAttribute("stuList", stuList);
        return "list";
    }

5.3.2 处理表单

@RequestMapping("add")
    public String list(Student student) {
        stuService.addStu(student);
        return "redirect:list";

    }

jsp:

<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
    <title>Title</title>
</head>
<body>
<form action="/stu/add">
    name:<input type="text" name="name">
    age:<input type="text" name="age">

    <input type="submit" value="提交">
</form>
</body>
</html>

相关文章
|
22天前
|
安全 测试技术 数据库
维护的Web应用程序
【10月更文挑战第4天】维护的Web应用程序
42 4
|
2天前
|
数据可视化 数据库 开发者
使用Dash构建交互式Web应用程序
【10月更文挑战第16天】本文介绍了使用Python的Dash框架构建交互式Web应用程序的方法。Dash结合了Flask、React和Plotly等技术,让开发者能够快速创建功能丰富的数据可视化应用。文章从安装Dash开始,逐步介绍了创建简单应用程序、添加交互元素、部署应用程序以及集成更多功能的步骤,并提供了代码示例。通过本文,读者可以掌握使用Dash构建交互式Web应用程序的基本技巧和高级功能。
11 3
|
17天前
|
JavaScript 前端开发
如何使用Vue.js构建响应式Web应用程序
【10月更文挑战第9天】如何使用Vue.js构建响应式Web应用程序
|
17天前
|
前端开发 JavaScript 测试技术
构建响应式Web应用程序:React实战指南
【10月更文挑战第9天】构建响应式Web应用程序:React实战指南
|
22天前
|
存储 JavaScript 前端开发
如何使用React和Redux构建现代化Web应用程序
【10月更文挑战第4天】如何使用React和Redux构建现代化Web应用程序
|
23天前
|
设计模式 测试技术 持续交付
开发复杂Web应用程序
【10月更文挑战第3天】开发复杂Web应用程序
31 2
|
19天前
|
XML Java 数据格式
手动开发-简单的Spring基于注解配置的程序--源码解析
手动开发-简单的Spring基于注解配置的程序--源码解析
34 0
|
19天前
|
XML Java 数据格式
手动开发-简单的Spring基于XML配置的程序--源码解析
手动开发-简单的Spring基于XML配置的程序--源码解析
60 0
|
5月前
|
前端开发 Java BI
Spring3 Web MVC 集成Jasper Report生成PDF例子
Spring3 Web MVC 集成Jasper Report生成PDF例子
53 7
|
5月前
|
JSON 前端开发 Java
Spring Web MVC入门(3)——响应
Spring Web MVC入门(3)——响应
51 1