java mvc框架中的m指什么_SSM框架(十九):SpringMVC(1)三层架构和MVC设计,RequestMapping注解...

在 B/S 架构中,系统标准的三层架构包括:表现层、业务层、持久层。

表现层:

也就是我们常说的web层。它负责接收客户端请求,向客户端响应结果,通常客户端使用 http协议请求web层,

web 需要接收 http 请求,完成 http 响应。表现层包括展示层和控制层:控制层负责接收请求,展示层负责结果的展示。

表现层依赖业务层,接收到客户端请求一般会调用业务层进行业务处理,并将处理结果响应给客户端。

表现层的设计一般都使用 MVC 模型。(MVC 是表现层的设计模型,和其他层没有关系)

业务层:

也就是我们常说的 service 层。它负责业务逻辑处理,和我们开发项目的需求息息相关。

web 层依赖业务层,但是业务层不依赖 web 层。业务层在业务处理时可能会依赖持久层,

如果要对数据持久化需要保证事务一致性。(也就是我们说的,事务应该放到业务层来控制)

持久层:

也就是我们是常说的 dao 层。负责数据持久化,包括数据层即数据库和数据访问层,数据库是对数据进行持久化的载体,

数据访问层是业务层和持久层交互的接口,业务层需要通过数据访问层将数据持久化到数据库中。

通俗的讲,持久层就是和数据库交互,对数据库表进行增删改查的。

MVC 模型

MVC 全名是 Model View Controller,是模型(model)-视图(view)-控制器(controller)的缩写,

是一种用于设计创建 Web 应用程序表现层的模式。 MVC 中每个部分各司其职:

Model(模型) :

通常指的就是我们的数据模型。作用一般情况下用于封装数据。

View(视图) :

通常指的就是我们的 jsp 或者 html。作用一般就是展示数据的。通常视图是依据模型数据创建的。

Controller(控制器) :

是应用程序中处理用户交互的部分。 作用一般就是处理程序逻辑的。

SpringMVC

SpringMVC 是一种基于 Java 的实现 MVC 设计模型的请求驱动类型的轻量级 Web 框架。

SpringMVC中的对象:

前端控制器(DispatcherServlet)

请求到处理器映射(HandlerMapping)

处理器适配器(HandlerAdapter)

视图解析器(ViewResolver)

处理器或页面控制器(Controller)

验证器( Validator)

命令对象(Command 请求参数绑定到的对象就叫命令对象)

表单对象(Form Object 提供给表单展示和提交到的对象就叫表单对象)。

SpringMVC 和 Struts2 的优略分析

共同点:

它们都是表现层框架,都是基于 MVC 模型编写的。

它们的底层都离不开原始 ServletAPI。

它们处理请求的机制都是一个核心控制器。

区别:

Spring MVC 的入口是 Servlet, 而 Struts2 是 Filter

Spring MVC 是基于方法设计的,而 Struts2 是基于类, Struts2 每次执行都会创建一个动作类。所以 Spring MVC 会稍微比 Struts2 快些。

Spring MVC 使用更加简洁,同时还支持 JSR303, 处理 ajax 的请求更方便

Struts2 的 OGNL 表达式使页面的开发效率相比 Spring MVC 更高些,但执行效率并没有比 JSTL 提升,尤其是 struts2 的表单标签,远没有 html 执行效率高。

构建一个简单的springMVC的web项目

目录结构如下

web.xml为

Archetype Created Web Application

dispatcherServlet

org.springframework.web.servlet.DispatcherServlet

contextConfigLocation

classpath:springmvc.xml

1

dispatcherServlet

/

springmvc.xml为:

xmlns:mvc="http://www.springframework.org/schema/mvc"

xmlns:context="http://www.springframework.org/schema/context"

xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"

xsi:schemaLocation="http://www.springframework.org/schema/beanshttp://www.springframework.org/schema/beans/spring-beans.xsdhttp://www.springframework.org/schema/mvchttp://www.springframework.org/schema/mvc/spring-mvc.xsdhttp://www.springframework.org/schema/contexthttp://www.springframework.org/schema/context/spring-context.xsd">

index.jsp

Created by IntelliJ IDEA.

User: Figo

Date: 2019/11/30

Time: 23:30

To change this template use File | Settings | File Templates.

--%>

index

入门程序

入门

success.jsp

Created by IntelliJ IDEA.

User: Figo

Date: 2019/11/30

Time: 23:38

To change this template use File | Settings | File Templates.

--%>

success

入门成功

一个控制器:

package cn.figo.controller;

import org.springframework.stereotype.Controller;

import org.springframework.web.bind.annotation.RequestMapping;

/*** @Author Figo* @Date 2019/11/30 23:31* 控制器类*/

@Controller

public class HelloController {

@RequestMapping(path = "/hello")

public String sayHello(){

System.out.println("Hello springMVC");

return "success";

}

}

执行流程

1. 当启动Tomcat服务器的时候,因为配置了load-on-startup标签,所以会创建DispatcherServlet对象,就会加载springmvc.xml配置文件

2. 开启了注解扫描,那么HelloController对象就会被创建

3. 从index.jsp发送请求,请求会先到达DispatcherServlet核心控制器,根据配置@RequestMapping注解找到执行的具体方法

4. 根据执行方法的返回值,再根据配置的视图解析器,去指定的目录下查找指定名称的JSP文件

5. Tomcat服务器渲染页面,做出响应

RequestMapping注解

RequestMapping注解的作用是建立请求URL和处理方法之间的对应关系

RequestMapping注解可以作用在方法和类上

1. 作用在类上:第一级的访问目录

2. 作用在方法上:第二级的访问目录

3. 细节:路径可以不编写 / 表示应用的根目录开始

4. 细节:${ pageContext.request.contextPath }也可以省略不写,但是路径上不能写 /

RequestMapping的属性

1. path 指定请求路径的url

2. value value属性和path属性是一样的

3. mthod 指定该方法的请求方式

4. params 指定限制请求参数的条件

5. headers 发送的请求中必须包含的请求头

RequestMapping属性

// method 限制请求的方式,如果请求方式不匹配也不会执行相关方法 // method = {RequestMethod.POST,RequestMethod.GET} // params 限制请求中的参数,请求中不带该参数,则无法匹配控制器方法 // params = {"username"} 请求中必须带有 username参数 // params = {"username=haha"} 请求中必须带有username参数,并且参数值必须是 haha // 控制器方法中的 username 会接收到 前端请求中的相应的请求参数值 @RequestMapping(path = "/testRequestMapping", method = {RequestMethod.POST,RequestMethod.GET},params = {"username=tom"},headers = {"accept"})

public String testRequestMapping(String username){

System.out.println("RequestMapping 注解");

System.out.println(username);

return "success";

}

index.jsp页面的请求

测试RequestMapping注解

参数绑定

绑定机制

1. 表单提交的数据都是k=v格式的 username=haha&password=123

2. SpringMVC的参数绑定过程是把表单提交的请求参数,作为控制器中方法的参数进行绑定的

3. 要求:提交表单的name和参数的名称是相同的

支持的数据类型

1. 基本数据类型和字符串类型

2. 实体类型(JavaBean)

3. 集合数据类型(List、map集合等)

基本数据类型和字符串类型

1. 提交表单的name和参数的名称是相同的

2. 区分大小写

实体类型(JavaBean)

1. 提交表单的name和JavaBean中的属性名称需要一致

2. 如果一个JavaBean类中包含其他的引用类型,那么表单的name属性需要编写成:对象.属性 例如:address.name

给集合属性数据封装

JSP页面编写方式:list[0].属性

前端页面form中的name值应该和相应的bean中的属性值相同,这就spring就可以自动封装数据

姓名:

密码:

金额:

用户名:

年龄:

控制器

// 请求参数的绑定 请求中的参数名和控制器方法中的参数名相同,spring会自动封装数据 @RequestMapping(path = "/testParams")

public String testParams(Account account){

System.out.println("参数绑定");

System.out.println(account);

return "success";

}

Account中的属性

public class Account implements Serializable {

private String username;

private String password;

private Double money;

private User user;

}

User中的属性

public class User implements Serializable {

private String uname;

private Integer age;

private Date date;

}

解决post中文乱码的过滤器

characterEncodingFilter

org.springframework.web.filter.CharacterEncodingFilter

encoding

UTF-8

characterEncodingFilter

/*

绑定集合数据

在Account中添加属性

private List list;

private Map map;

在前端代码中

用户名:

年龄:

用户名:

年龄:

这样就实现了集合属性的封装

Account{username='zhangsan', password='11111111', money=100.0, user=User{uname='ee', age=13, date=null}, list=[User{uname='rr', age=12, date=null}], map={one=User{uname='tt', age=18, date=null}}}

自定义类型转换器

比如User中有一个Date类型的属性date,前端传来的String类型的数据,

传入控制器后无法自动封装为Date类型,因此我们需要自定义类型转换器

/*** 把字符串转换日期*/

public class StringToDateConverter implements Converter {

/*** String source 传入进来字符串* @param source* @return*/

public Date convert(String source) {

// 判断 if(source == null){

throw new RuntimeException("请您传入数据");

}

DateFormat df = new SimpleDateFormat("yyyy-MM-dd");

try {

// 把字符串转换日期 return df.parse(source);

} catch (Exception e) {

throw new RuntimeException("数据类型转换出现错误");

}

}

}

然后在springmvc.xml中注册该转换器

如果不用类型转换器,无法封装Date类型的数据

获取servlet的原生API

public String testServlet(HttpServletRequest request, HttpServletResponse response) {

System.out.println("执行了...");

System.out.println(request);

HttpSession session = request.getSession();

System.out.println(session);

ServletContext servletContext = session.getServletContext();

System.out.println(servletContext);

System.out.println(response);

return "success";

}

输出如下

org.apache.catalina.connector.RequestFacade@4dcff089

org.apache.catalina.session.StandardSessionFacade@267ca42c

org.apache.catalina.core.ApplicationContextFacade@90047d0

org.apache.catalina.connector.ResponseFacade@57e9b725

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值