1      MVC模式回顾

Spring MVC是一种基于MVC的Web应用框架。

MVC是一种设计模式,MVC在b/s系统下的应用:

执行步骤:

  1. 发出请求,请求到MVC当中的C,C接收请求后并不能处理请求,需要把请求交给M
  2. 模型是用来处理请求的,所有用来处理的东西都是模型,pojo,action,service,dao
  3. 处理完后进行结果返回到C
  4. C需要一些好看的经过渲染的页面进行响应,这就用到V视图
  5. 控制器进行视图的渲染,将模型数据填充到request域
  6. Request准备好了后就可以response了

注意:b/s系统下模型无法将数据填充到视图

与springMVC的联系:控制器、模型、视图这些在spring中怎么实现的?

2      Spring MVC框架

执行步骤:

1 发起请求到前段控制器(dispatcherServlet)

2 前端控制器请求HandlerMapping查找Handler可以根据xml配置、注解进行查找

3 处理器映射器HandlerMapping向前端控制器返回handler

4 前端控制器调用处理器适配器去执行handler

5 处理器适配器去执行handler

6  handler执行完给适配器返回modelAndView

7 处理器适配器向前端控制器返回modelAndView,modelAndView是springMVC框架的一个底层对象,包括model和view

8 前端控制器请求视图解析器去进行视图解析,根据逻辑视图名解析成真正的视图(jsp)

9 视图解析器向前端控制器返回view

10 前端控制器进行视图渲染,视图渲染将模型数据(在modelAndView对象中)填充到request域

11 前端控制器向用户响应结果

3      springMVC主要组件

1前端控制器DispatcherServlet(不需要程序开发)

作用:接收请求,响应结果,相当于转发器,中央处理器

减少了其他组件之间的耦合度。

2 处理器映射器HandlerMapping(不需要程序开发)

作用:根据请求的url查找handler

3 处理器适配器HandlerAdapter(不需要程序开发)

作用:按照特定规则(HandlerAdapter要求的规则)执行handler

4 处理器Handler(需要程序开发

注意:编写handler时按照handlerAdapter的要求去做,这样适配器才可以正确执行handler

5 视图解析器view resolver(不需要程序开发)

作用:进行视图解析,根据逻辑视图名解析成真正的视图(view)

6 视图view(需要程序员开发jsp

View是一个接口,实现类支持不同的view类型

4      一个简单的springMVC案例

4.1   配置前端控制器

   <!-- 配置springmvc前端控制器 -->
<servlet>
<servlet-name>springmvc</servlet-name>
<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
<init-param>
<param-name>contextConfigLocation</param-name>
<param-value>classpath:/*-servlet.xml</param-value>
</init-param>
<load-on-startup>1</load-on-startup>
</servlet> <servlet-mapping>
<servlet-name>springmvc</servlet-name>
<url-pattern>/</url-pattern>
</servlet-mapping>

4.2   配置处理器:配置器

 <!-- HandlerAdapter -->
<bean class="org.springframework.web.servlet.mvc.SimpleControllerHandlerAdapter"/>

4.3   配置处理器:映射器

 <!-- HandlerMapping -->
<bean class="org.springframework.web.servlet.handler.BeanNameUrlHandlerMapping"/>

4.4   配置视图解析器

 <!-- ViewResolver -->
<bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">
<property name="viewClass" value="org.springframework.web.servlet.view.JstlView"/>
<property name="prefix" value="/WEB-INF/jsp/"/>
<property name="suffix" value=".jsp"/>
</bean>

4.5   处理器书写

 <!-- Handler-->
<bean name="/hello" class="com.inspur.handler.HelloWorldController"/>

Java代码

 public class HelloWorldController implements Controller {
@Override
public ModelAndView handleRequest(HttpServletRequest request,
HttpServletResponse response) throws Exception {
//返回ModelAndView
ModelAndView mv = new ModelAndView();
//相当于request的setAttribute,在jsp页面中通过message取数据
mv.addObject("message", "Hello World!");
//设置逻辑视图名,视图解析器会根据该名字解析到具体的视图页面
mv.setViewName("hello");
return mv;
}
}

4.6   Jsp书写

 <%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%>
${message}

4.7   访问

http://localhost:8080/springmvctfirst/hello

01springMVC入门的更多相关文章

  1. Angular2入门系列教程7-HTTP(一)-使用Angular2自带的http进行网络请求

    上一篇:Angular2入门系列教程6-路由(二)-使用多层级路由并在在路由中传递复杂参数 感觉这篇不是很好写,因为涉及到网络请求,如果采用真实的网络请求,这个例子大家拿到手估计还要自己写一个web ...

  2. ABP入门系列(1)——学习Abp框架之实操演练

    作为.Net工地搬砖长工一名,一直致力于挖坑(Bug)填坑(Debug),但技术却不见长进.也曾热情于新技术的学习,憧憬过成为技术大拿.从前端到后端,从bootstrap到javascript,从py ...

  3. Oracle分析函数入门

    一.Oracle分析函数入门 分析函数是什么?分析函数是Oracle专门用于解决复杂报表统计需求的功能强大的函数,它可以在数据中进行分组然后计算基于组的某种统计值,并且每一组的每一行都可以返回一个统计 ...

  4. Angular2入门系列教程6-路由(二)-使用多层级路由并在在路由中传递复杂参数

    上一篇:Angular2入门系列教程5-路由(一)-使用简单的路由并在在路由中传递参数 之前介绍了简单的路由以及传参,这篇文章我们将要学习复杂一些的路由以及传递其他附加参数.一个好的路由系统可以使我们 ...

  5. Angular2入门系列教程5-路由(一)-使用简单的路由并在在路由中传递参数

    上一篇:Angular2入门系列教程-服务 上一篇文章我们将Angular2的数据服务分离出来,学习了Angular2的依赖注入,这篇文章我们将要学习Angualr2的路由 为了编写样式方便,我们这篇 ...

  6. Angular2入门系列教程4-服务

    上一篇文章 Angular2入门系列教程-多个组件,主从关系 在编程中,我们通常会将数据提供单独分离出来,以免在编写程序的过程中反复复制粘贴数据请求的代码 Angular2中提供了依赖注入的概念,使得 ...

  7. wepack+sass+vue 入门教程(三)

    十一.安装sass文件转换为css需要的相关依赖包 npm install --save-dev sass-loader style-loader css-loader loader的作用是辅助web ...

  8. wepack+sass+vue 入门教程(二)

    六.新建webpack配置文件 webpack.config.js 文件整体框架内容如下,后续会详细说明每个配置项的配置 webpack.config.js直接放在项目demo目录下 module.e ...

  9. wepack+sass+vue 入门教程(一)

    一.安装node.js node.js是基础,必须先安装.而且最新版的node.js,已经集成了npm. 下载地址 node安装,一路按默认即可. 二.全局安装webpack npm install ...

随机推荐

  1. Spring——概览

    Spring是什么? Spring是帮助开发者简化开发工作的工具. Spring的出现就是为了简化人们的复杂的开发.能够在不论什么Java应用中使用,使用了主要的JavaBean取代EJB. Spri ...

  2. ZOJ 3829 Known Notation(字符串处理 数学 牡丹江现场赛)

    题目链接:problemId=5383">http://acm.zju.edu.cn/onlinejudge/showProblem.do?problemId=5383 Do you ...

  3. redis实现计数--------Redis increment

    经理提出新的需求,需要知道每天微信推送了多少条模板消息,成功多少条,失败多少条,想到用Redis缓存,网上查了一些资料,Redis中有方法increment,测试代码如下 Controller imp ...

  4. 27. Remove Element[E]移除元素

    题目 Given an array nums and a value val, remove all instances of that value in-place and return the n ...

  5. Python基本数据类型之数字int

    数字 int(x, base=None) 将x转换为一个整数.base为按照多少进制进行转换 float(x) 将x转换到一个浮点数. complex(x) 将x转换到一个复数,实数部分为 x,虚数部 ...

  6. BZOJ 4756 线段树合并(线段树)

    思路: 1.最裸的线段树合并 2. 我们可以观察到子树求一个东西 那我们直接DFS序好了 入队的时候统计一下有多少比他大的 出的时候统计一下 减一下 搞定~ 线段树合并代码: //By SiriusR ...

  7. A - Presents

    Problem description Little Petya very much likes gifts. Recently he has received a new laptop as a N ...

  8. chrome打开控制台状态下,没有人为打断点,自动进入断点模式的解决方法

    如下图所示:在控制台去掉Sources -> XHR/fetch Breakpoints -> Any XHR or fetch 的勾

  9. layui新手使用

    1,首先最重要的是引入官方的layui.js  layui.css文件 2,在自己的项目中新建一个目录 再在该目录下建一个js文件,js中写入 layui.define(['layer', 'form ...

  10. hdu3572Task Schedule 最大流,判断满流 优化的SAP算法

    PS:多校联赛的题目质量还是挺高的.建图不会啊,看了题解才会的. 参考博客:http://blog.csdn.net/luyuncheng/article/details/7944417 看了上面博客 ...