当前位置:   article > 正文

JavaWeb之JSP和MVC三层架构_jsp框架

jsp框架

JSP

JSP

JSP概述

JSP的作用

JSP(全称:Java Server Pages):Java 服务端页面。是一种动态的网页技术,其中既可以定义 HTML、JS、CSS等静态内容,还可以定义 Java代码的动态内容, 简单来讲就是JSP可以写html , 还可以java, css, js都可以

JSP的原理

JSP 本质上就是一个 Servlet

JSP会被tomcat翻译成Servlet

JSP原理

  1. 浏览器第一次访问jsp 页面
  2. tomcat 会将 jsp转换为名为 xxx_jsp.java`的一个 Servlet
  3. tomcat 再将转换的 servlet编译成字节码文件xxx_jsp.class
  4. tomcat 会执行该字节码文件,向外提供服务

JSP脚本

JSP脚本用于在 JSP页面内定义 Java代码。在之前的入门案例中我们就在 JSP 页面定义的 Java 代码就是 JSP 脚本

JSP 脚本分类

<% %>

在<% %>中写代码会在service方法内部

<%= %>

在<%= %>中写代码会在println(参数)里面的参数

<%! %>

在<%! %>中写代码会在成员区域

JSP 缺点

  • 书写麻烦

    特别是复杂的页面

    既要写 HTML 标签,还要写 Java 代码

  • 阅读麻烦

    后期再看这段代码时还需要花费很长的时间去梳理

  • 复杂度高

    运行需要依赖于各种环境,JRE,JSP容器,JavaEE…

  • 占内存和磁盘

    JSP会自动生成.java和.class文件占磁盘,运行的是.class文件占内存

  • 调试困难

    出错后,需要找到自动生成的.java文件进行调试

  • 不利于团队协作

    前端人员不会 Java,后端人员不精 HTML

    如果页面布局发生变化,前端工程师对静态页面进行修改,然后再交给后端工程师,由后端工程师再将该页面改为 JSP 页面

JSP 已逐渐退出历史舞台,以后开发更多的是使用 HTML + Ajax来替代。使用Ajax技术,前端工程师负责前端页面开发,而后端工程师只负责后端代码开发。

前后端结合发展史

  1. 第一阶段:使用 servlet即实现逻辑代码编写,也对页面进行拼接。

  2. 第二阶段:随着技术的发展,出现了 JSP,人们发现 JSP使用起来比 Servlet方便很多,但是还是要在 JSP中嵌套Java代码,也不利于后期的维护

  3. 第三阶段:使用 Servlet进行逻辑代码开发,而使用 JSP 进行数据展示

    前后端发展史第三阶段

  4. 第四阶段:使用 servlet进行后端逻辑代码开发,而使用 HTML进行数据展示。而这里面就存在问题,HTML是静态页面,怎么进行动态数据展示呢?这就是 ajax的作用了。

EL表达式

EL表达式概述

EL(全称Expression Language )表达式语言,用于简化 JSP 页面内的 Java 代码。

EL 表达式的主要作用是 获取数据。其实就是从域对象中获取数据,然后将数据展示在页面上。

而 EL 表达式的语法也比较简单,${expression} 。例如:${brands} 就是获取域中存储的 key 为 brands 的数据。

获取域中的数据

如何获取

${ 键 }

四个作用域

Page

PageContext

只有当前页面中才有, 其他地方没有的

只有在当前页面中才能共享数据, 只要页面发生变化, 则会消失

request

HttpServletRequest

一次请求, 只有转发跳转的时候才有用, 因为只有转发才是一次请求

session

HttpSession

SessionScore

当前会话有效

application

ServletContext

ApplicationScore

当前应用有效

el 表达式获取数据,会依次从这4个域中寻找,直到找到为止

四个作用域

值得不一样获取方式不一样

值为基本类型(八种基本类型以及字符串)

${键}

值为对象(Student, Teacher)

${键.属性名}

概述
成员变量和属性的区别

成员变量

类中方法外定义的变量

属性

setXxx以及getXxx的成员方法

获取数据遵循的都是OGNL表达式, 对象图导航语言

值为List集合或者数组

${键[索引]}

值为Map集合

${键.key}

进行运算

算数运算

逻辑运算

比较运算

三元运算

JSTL标签

JSTL标签的概述

JSP标准标签库(Jsp Standarded Tag Library) ,使用标签取代JSP页面上的Java代码。

使用步骤

  1. 导入坐标

    	  <!--jstl-->
        <dependency>
          <groupId>jstl</groupId>
          <artifactId>jstl</artifactId>
          <version>1.2</version>
        </dependency>
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
  2. 引入标签库

    	<%@taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>
    
    • 1
  3. 使用标签

JSTL 提供了很多标签

JSTL标签

if
<c:if test="boolean表达式">  显示的内容 </c:if>
  • 1
foreach
遍历容器
<c:forEach var="beauty" items="${arr}">
   ${beauty}
</c:forEach>
  • 1
  • 2
  • 3
var

遍历出来的东西

items

从域中取出来的数组或者集合

varStatus

index

从0开始

count

从1开始

遍历指定次数
<c:forEach var="i" begin="1" end="10"  step="1">
    ${i}

</c:forEach>
  • 1
  • 2
  • 3
  • 4
var

遍历出来的东西

begin

从哪里开始

end

到哪里结束

step

步长, 默认值是1

MVC三层架构

MVC 模式和三层架构是一些理论的知识,将来我们使用了它们进行代码开发会让我们代码维护性和扩展性更好。

MVC模式

MVC 是一种分层开发的模式

  • M:Model,业务模型,处理业务

  • V:View,视图,界面展示

  • C:Controller,控制器,处理请求,调用模型和视图

MVC模式

MVC 好处

  • 职责单一,互不影响。每个角色做它自己的事,各司其职。

  • 有利于分工协作。

  • 有利于组件重用

三层架构

三层架构是将我们的项目分成了三个层面,分别是表现层,业务逻辑层,数据访问层。

三层架构

  • 数据访问层:对数据库的CRUD基本操作
  • 业务逻辑层:对业务逻辑进行封装,组合数据访问层层中基本功能,形成复杂的业务逻辑功能。例
  • 表现层:接收请求,封装数据,调用业务逻辑层,响应数据

而整个流程是,浏览器发送请求,表现层的Servlet接收请求并调用业务逻辑层的方法进行业务逻辑处理,而业务逻辑层方法调用数据访问层方法进行数据的操作,依次返回到serlvet,然后servlet将数据交由 JSP 进行展示。

三层架构的每一层都有特有的包名称

  • 表现层: com.xxx.controller或者 com.xxx.web
  • 业务逻辑层:com.xxx.service
  • 数据访问层:com.xxx.dao或者com.xxx.mapper

MVC模式和三层架构

MVC和三层架构

上半部分是 MVC 模式,上图下半部分是三层架构。 MVC 模式中的 C(控制器)和 V(视图)就是 三层架构中的表现层,而 MVC 模式中的 M(模型)就是 三层架构中的 业务逻辑层 和 数据访问层。

作用

可以将MVC 模式理解成是一个大的概念,而三层架构是对MVC 模式实现架构的思想。 需要按照要求将不同层的代码写在不同的包下,每一层里功能职责做到单一,比如将来如果将表现层的技术换掉,而业务逻辑层和数据访问层的代码则不需要发生变化。

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/小蓝xlanll/article/detail/140038
推荐阅读
  

闽ICP备14008679号