第三天
JSP
概念:Java Server Pages,Java服务端页面
一种动态的网页技术,其中既可以定义HTML、JS、CSS等静态内容,还可以定义Java代码的动态内容
JSP = HTML + Java(其中HTML代码会使用响应对象的输出流中的write()方法来书写)
参考代码:
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
<title>Title</title>
</head>
<body>
<h1>JSP, Hello World</h1>
<%
System.out.println("hello, jsp~~~");
%>
</body>
</html>
JSP的作用:简化开发,避免了在Servlet中直接输出HTML标签。
即当一个页面中既需要静态内容有需要动态代码时(使用Servlet中转,先进行动态判断,然后在Servlet中通过writer写HTML代码)的繁琐。
JSP快速入门:
1、导入JSP坐标
<dependency>
<groupId>javax.servlet.jsp</groupId>
<artifactId>jsp-api</artifactId>
<version>2.2</version>
<!-- 依赖范围:由于tomcat中自带打好的jsp包所以运行时无需 -->
<scope>provided</scope>
</dependency>
2、创建JSP文件
New JSP/SPX
3、编写HTML标签何Java代码
<body>
<h1>
hello jsp
</h1>
<% System.out.println("jsp hello");%>
</body>
JSP原理:
概念:Java Servlet Pages,Java服务端页面
JSP = HTML + Java,用于简化开发的
JSP 本质上就是一个Servlet(本来JSP就是用来简化Servlet开发的,Tomcat底层会自动进行转换)
JSP 在被访问时,由JSP容器(Tomcat)将其转化为Java文件(Servlet),在由JSP容器(Tomcat)将其编译,最终对外提供服务的其实就是这个字节码文件
JSP脚本
JSP脚本用于在JSP页面内定义Java代码
JSP脚本分类:
<%...%>:内容会直接放到_jspService()方法中
<%=...%>:内容会放到out.print()中,作为out.print()参数
<%!...%>:内容会放到_jspService()方法之外,被类直接包含
使用JSP脚本展示品牌数据:
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<%
//模拟查询数据库
List<Brand> brands = new ArrayList<Brand>();
brands.add(new Brand(1,"三只松鼠","三只松鼠",100,"三只松鼠,好吃不上火",1));
brands.add(new Brand(2,"优衣库","优衣库",200,"优衣库,服适人生",0));
brands.add(new Brand(3,"小米","小米科技有限公司",1000,"为发烧而生",1));
%>
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
</head>
<body>
<input type="button" value="新增"><br>
<hr>
<table border="1" cellspacing="0" width="800">
<tr>
<th>序号</th>
<th>品牌名称</th>
<th>企业名称</th>
<th>排序</th>
<th>品牌介绍</th>
<th>状态</th>
<th>操作</th>
</tr>
<%
//可以将代码截断
for(int i = 0; i < brands.size(); i++){
Brand brand = brands.get(i);
%>
<tr align="center">
<td><%= brand.getId()%></td>
<td><%= brand.getBrandName()%></td>
<td><%= brand.getCompanyName()%></td>
<td><%= brand.getOrdered()%></td>
<td><%= brand.getDescription()%></td>
<%
if(brand.getStatus() == 1){
//显示启用
%>
<td><%="启用"%></td>
<%
}else{
//显示禁用
%>
<td><%="禁用"%></td>
<%
}
%>
<td><a href="#">修改</a> <a href="#">删除</a></td>
</tr>
<%
}
%>
</table>
</body>
</html>
JSP缺点
由于JSP页面内,既可以定义HTML标签,又可以定义Java代码,造成了以下问题:
书写麻烦:特别是复杂的页面
阅读麻烦
复杂度高:运行需要依赖于各种环境,JRE,JSP容器,JavaEE...
占内存和磁盘:JSP会自动生成.java和.class文件占磁盘,运行的.class文件占内存
调试困难:出错后,需要找到自动生成的.java文件进行调试
不利于团队协作:前端人员不会Java,后端人员不精HTML
...
JSP 已逐渐退出历史舞台 ----------> HTML + AJAX
由于这些问题的出现,在没有AJAX时,使用Servlet + JSP
不要直接在JSP里写Java代码
Servlet:逻辑处理,封装数据
JSP:获取数据,遍历展现数据
EL表达式(简化jsp中的数据获取)
Expression Language表达式语言,用于简化JSP页面内的Java代码
主要功能:在域对象中,获取数据
语法:$
${brands} 获取域中存储的key为brands的数据
JavaWeb中的四大域对象:
page:当前页面有效
request:当前请求有效
session:当前会话有效
application:当前应用有效
el表达式获取数据,会依次从这4个域中寻找,直到找到为止
JSTL标签(简化JSP中的遍历数据与流程控制)
JSP标准标签库(Jsp Standarded Tag Library),使用标签取代JSP页面上的Java代码(此处只提及常用的两个)
<c:if test="${flag == 1"}>
男
</c:if>
<c:if test="${flag == 2"}>
女
</c:if>
使用jstl步骤:
1、导入坐标:
<dependency>
<groupId>jstl</groupId>
<artifactId>jstl</artifactId>
<version>1.2</version>
</dependency>
<dependency>
<groupId>taglibs</groupId>
<artifactId>standard</artifactId>
<version>1.1.2</version>
</dependency>
2、在JSP页面上引入JSTL标签库
<%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/croe"%>
3、使用
<c:if>
增强for循环遍历标签:
<c:forEach>:相当于加强for循环
items:被遍历的容器
var:遍历产生的临时变量
varStatus:遍历状态对象,使用目的是为了动态变化下标
示例:
varStatus="status"
<td>${status.index}</td> <%-- 下标从0开始 --%>
<td>${status.count}</td> <%-- 下标从1开始 --%>
<c:forEach item="${brands}" var="brand">
<tr align="center">
<td>${brand.id}</td>
<td>${brand.brandName}</td>
<td>${brand.companyName}</td>
<td>${brand.description}</td>
</tr>
</c:forEach>
参考代码:
package com.itheima.web;
import com.itheima.pojo.Brand;
import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;
import java.util.ArrayList;
import java.util.List;
@WebServlet("/demo1")
public class ServletDemo1 extends HttpServlet {
protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
//1、准备数据,模拟
List<Brand> brands = new ArrayList<Brand>();
brands.add(new Brand(1,"三只松鼠","三只松鼠",100,"三只松鼠,好吃不上火",1));
brands.add(new Brand(2,"优衣库","优衣库",200,"优衣库,服适人生",0));
brands.add(new Brand(3,"小米","小米科技有限公司",1000,"为发烧而生",1));
//2、存储到request域中
request.setAttribute("brands", brands);
request.setAttribute("status", 1);
//3、转发到el-demo.jsp
// request.getRequestDispatcher("/el-demo.jsp").forward(request, response);
// request.getRequestDispatcher("/jstl-if.jsp").forward(request, response);
request.getRequestDispatcher("/jstl-forEach.jsp").forward(request, response);
}
protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
this.doGet(request, response);
}
}
<%--
Created by IntelliJ IDEA.
User: YAN
Date: 2023/2/3
Time: 22:04
To change this template use File | Settings | File Templates.
--%>
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
</head>
<body>
<input type="button" value="新增"><br>
<hr>
<table border="1" cellspacing="0" width="800">
<tr>
<th>序号</th>
<th>品牌名称</th>
<th>企业名称</th>
<th>排序</th>
<th>品牌介绍</th>
<th>状态</th>
<th>操作</th>
</tr>
<c:forEach items="${brands}" var="brand" varStatus="status">
<tr align="center">
<%--<td>${brand.id}</td>--%>
<%--<td>${status.index}</td>--%> <%-- 下标从0开始 --%>
<td>${status.count}</td> <%-- 下标从1开始 --%>
<td>${brand.brandName}</td>
<td>${brand.companyName}</td>
<td>${brand.ordered}</td>
<td>${brand.description}</td>
<c:if test="${brand.status == 1}">
<td>启用</td>
</c:if>
<c:if test="${brand.status != 1}">
<td>禁用</td>
</c:if>
<td><a href="#">修改</a> <a href="#">删除</a></td>
</tr>
</c:forEach>
</table>
</body>
</html>
普通for循环遍历标签:
<%--
begin:开始数
end:结束数
step:步长
--%>
<c:forEach begin="0" end="10" step="1" var="i">
${i}
</c:forEach>
参考代码:
<hr>
<c:forEach begin="1" end="10" step="1" var="i" >
<%-- 可以做分页工具条 --%>
<a href="#">${i}</a>
</c:forEach>
</body>
</html>
MVC 模式和三层架构
MVC模式:
MVC是一种分层开发的模式,其中:
M:Model,业务模型,处理业务
V:View,视图,界面展示
C:Controller,控制器,处理请求,调用模型和视图
MVC好处
职责单一,互不影响
有利于分工协作
有利于组件重用
三层架构:
表现层:接收请求,封装数据,调用业务逻辑层,响应数据
业务逻辑层:对业务逻辑进行封装,组合数据访问层中基本功能,形成复杂的业务逻辑功能
数据访问层:对数据库的CRUD基本操作
案例:
完成品牌数据的增删改查操作:
准备环境
创建新的模块brand_demo,引入坐标
创建三层架构的包结构
数据库标 tb_brand
实体类 Brand
MyBatis基础环境
Mybatis-config.xml
BrandMapper.xml
BrandMapper接口
查询所有:
通过一个超链接查询所有数据
Web层:
SelectAllServlet:调用Service查询、将数据存入requst、转发到brand.jsp中
在brand.jsp中遍历
Service层:
BrandService:提供一个selectAll方法调用BrandMapper中的selectAll方法
Dao层:
BrandMapper:List
添加
Web层:
AddServlet
1、接收数据,封装Brand对象
2、调用service完成添加
3、将数据转发到查询所有Servlet
Service层:
BrandService:提供一个add方法调用BrandMapper中的add方法
Dao层:
BrandMapper:void add(brand)
修改
修改-回显数据
Web层:
SelectByIdServlet
1、接收id
2、调用service查询Brand
3、存储request
4、将数据转发到修改页面
Service层:
BrandService:提供一个selectById方法调用BrandMapper中的selectById方法
Dao层:
BrandMapper:selectById(id)
修改-修改数据
Web层:
UpdateServlet
1、接收数据,封装Brand对象
2、调用service修改
3、转发到查询所有的Servlet
Service层:
BrandService:提供一个 update方法调用BrandMapper中的 update方法
Dao层:
BrandMapper:void update(brand)
删除
修改-回显数据
Web层:
DeleteByIdServlet
1、接收id
2、调用service查询Brand
3、存储request
4、将数据转发到删除页面
Service层:
BrandService:提供一个deleteById方法调用BrandMapper中的deleteById方法
Dao层:
BrandMapper:deleteById(id)
标签:BrandMapper,Java,brand,request,第三天,JSP,Brand From: https://www.cnblogs.com/fragmentary/p/17094950.html