1. JSP:

    1. 指令

    2. 注释

    3. 内置对象

  2. MVC开发模式

  3. EL表达式

  4. JSTL标签

  5. 三层架构

JSP

  1. 指令:

    • 作用:用于配置JSP页面,导入资源文件

    • 格式:

      • <%@ 指令名称 属性名1=属性值1 属性名2=属性值2...>
    • 分类:

      1. page:配置JSP页面的。

        • contentType:等同于response.setContentType()

          1. 设置响应体的mime类型以及字符集
          2. 设置当前jsp页面的编码(高级开发工具才能生效,如果使用低级工具,则需要使用pageEncoding属性设置当前页面的字符集编码)
        • language:曾经想统一所有语言,但到如今还是只有一个值(java)
        • import:导入jar包
        • errorPage:当前页面发生异常后会跳转到指定的错误页面
        • isErrorPage:标识当前页面是不是错误页面

          • ture:是,可以使用内置对象exception
          • false:否。默认值,不可以使用内置对象exception
      2. include:页面包含的。导入页面的资源文件。
        <%@include file="top.jsp"%>

      3. taglib:导入资源
        <%@taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>

        • prefix:前缀,自定义的
  2. 注释

    1. html注释:
      <!---->:只能注释html代码

    2. jsp注释
      <%----%>:什么都能注释

  3. 内置对象

    • 在jsp页面中不需要创建,直接使用的对象

    • 一共有九个:
      变量名 真实类型 作用

      1. pageContext PageContext 当前页面共享数据,获取其他八个内置对象

      2. request HTTPServletRequest 一次请求访问多个资源(转发)

      3. session HttpSession 一次会话的多个请求间

      4. application ServletContext 所有用户间共享数据

      5. response HttpServletResponse 响应对象

      6. page Object 当前servlet的对象(this)

      7. out JspWriter 输出对象,数据输出到页面上

      8. config ServletConfig Servlet配置对象

      9. exception Throwable 异常对象

MVC:开发模式

  1. jsp演变历史

    1. 早期只有servlet,只能使用response输出标签数据,非常麻烦
    2. 后来有了jsp,简化了Servlet的开发,如果过度使用jsp,在jsp中写了大量的java代码,有写html表,造成难以维护,难于分工协作
    3. 再后来,java的web开发,借鉴mvc开发模式,使得程序的更加合理性
  2. MVC:

    1. M:Model,模型。JavaBean

      • 完成具体的业务操作,如:查询数据库,封装对象
    2. V:View,视图。JSP

      • 展示数据
    3. C:Controller,控制器。Servlet

      • 获取用户的输入
      • 调用模型
      • 将数据交给视图来进行展示
    • 优缺点:

      1. 优点:

        1. 耦合性低,方便维护,可以利用于分工协作
        2. 重用性高
      2. 缺点:

        1. 使得项目架构变得复杂,对开发人员要求高

EL表达式

  1. 概念:Expression Language 表达式语言

  2. 作用:替换和简化jsp页面中java代码的编写

  3. 语法:${表达式}

  4. 注意:

    • jsp默认是支持el表达式的。如果要忽略el表达式

      1. 设置jsp中page指令中:isELIgnored="true" 忽略当前jsp页面中所有的el表达式
      2. \${表达式}:忽略当前这个el表达式
  5. 使用:

    1. 运算:

      • 运算符:

        1. 算数运算符:+ - * /(div) %(mod)
        2. 比较运算符:> < >= <= == !=
        3. 逻辑运算符:&&(and) ||(or) !(not)
        4. 空运算符:empty

          • 功能:用于判断字符串,集合,数组对象是否为null并且长度是否为0
          • ${empty list}:表示判断字符串,集合,数组对象是否为null,或者长度为0
          • ${not empty list}:表示判断字符串,集合,数组对象是否不为null,或者长度>0
    2. 获取值

      1. el表达式只能从域对象中获取值

      2. 语法:

        1. ${域名称.键名}:从指定域中获取指定键的值

          • 域名称:

            1. pageScope --> pageContext
            2. `requestScope --> request
            3. sessionScope --> session
            4. applicationScope -> application(ServletContext)
          • 举例:在request域中存储量name=xj
          • 获取:${requestScope.name}
        2. ${键名}:表示依次从最小的域中查找是否有该键对应的值
          ${name}

        3. 获取对象,List集合,Map集合的值

          1. 对象:${域名称.键名.属性名}

            • 本质上会调用对象的getter方法
          2. List集合:${域名称.键名[索引]}

          3. Map集合:

            • ${域名称.键名.key名称}
            • ${域名称.键名["key名称"]}
    3. 隐式对象

      • el表达式中有11个隐式对象
      • pageContext:

        1. 获取jsp其他八个内置对象
        2. ${pageContext.request.contextPath}:动态获取虚拟目录

JSTL

  1. 概念:JavaServer Pages Tag Library JSTL标准标签库

    • 是由Apache组织提供的开源的免费的jsp标签
  2. 作用:用于简化和替换jsp页面上的java代码

  3. 使用步骤:

    1. 导入jstl相关的jar包
    2. 引入标签库:taglib指令 <%@ taglib %>
    3. 使用标签
  4. 常用的JSTL标签

    1. if :相当于java中的if

      1. 属性:

        • test必须属性:接受boolean表达式

          • 如果表达式为true,则显示if标签体内容,如果为false,则不显示标签体内容
        • 一般情况下,test属性值会结合el表达式一起使用
      2. 注意:

        • c:if标签没有else情况,想要else则再定义一个c:if标签
    2. choose :相当于java的switch、

      1. 使用when标签做判断相当于case

      2. otherwise相当于default ```jsp <% request.setAttribute(“number”,3); %>

      星期一 星期二 星期三 星期四 星期五 星期六 星期天 ddd ```

  1. foreach:相当于java的for语句

    1. 完成重复的操作

      • 属性:

        • begin:开始值
        • end:结束值
        • var:临时变量
        • step:步长
        • varStatus:循环状态对象

          • index:容器中元素的索引,从0开始
          • count:循环次数
    2. 遍历容器

      • 属性

        • items:容器对象
        • var:容器中元素的临时变量
        • varStatus:循环状态对象

          • index:容器中元素的索引,从0开始
          • count:循环次数 ```jsp <%@ page import=”java.util.ArrayList” %> <%@ page import=”java.util.List” %><%— Created by IntelliJ IDEA.5 User: Jay Date: 2020/11/3 Time: 8:14 To change this template use File | Settings | File Templates. —%> <%@ page contentType=”text/html;charset=UTF-8” language=”java” isELIgnored=”false” %> <%@taglib prefix=”c” uri=”http://java.sun.com/jsp/jstl/core“ %> ${i}${s.index}${s.count}


<% List list = new ArrayList(); list.add(“aaa”); list.add(“bbb”); list.add(“ccc”);

  1. request.setAttribute("list",list);
  2. %>
  3. <c:forEach items="${list}" var="str" varStatus="s">
  4. ${s.index} ${s.count} ${str} <br>
  5. </c:forEach>

  1. 5.
  2. 练习
  3. -
  4. 学生对象存入list集合用foreach输出到页面上
  5. ```jsp
  6. <%
  7. List list = new ArrayList();
  8. list.add(new User("张三",12,new Date()));
  9. list.add(new User("李四",12,new Date()));
  10. list.add(new User("王五",12,new Date()));
  11. list.add(new User("赵六",12,new Date()));
  12. request.setAttribute("list",list);
  13. %>
  14. <table border="1" width="500" align="center">
  15. <tr>
  16. <th>编号</th>
  17. <th>姓名</th>
  18. <th>年龄</th>
  19. <th>生日</th>
  20. </tr>
  21. <c:forEach items="${list}" var="user" varStatus="s">
  22. <c:if test="${s.count mod 2 == 0}">
  23. <tr bgcolor="gray">
  24. <td>${s.count}</td>
  25. <td>${user.name}</td>
  26. <td>${user.age}</td>
  27. <td>${user.birthday}</td>
  28. </tr>
  29. </c:if>
  30. <c:if test="${s.count mod 2 == 1}">
  31. <tr bgcolor="#4169e1">
  32. <td>${s.count}</td>
  33. <td>${user.name}</td>
  34. <td>${user.age}</td>
  35. <td>${user.birthday}</td>
  36. </tr>
  37. </c:if>
  38. </c:forEach>
  39. </table>

三层架构:软件设计架构

  1. 界面层(表示层):用户看的到的界面。用户可以通过界面上的组件和服务器进行交互

  2. 业务逻辑层:处理业务逻辑的。

  3. 数据访问层:操作数据存储文件。

案例:用户信息的列表展示

  1. 需求:用户信息的增删改查操作

  2. 设计:

    1. 技术选型:servlet+JSP+MySQL+JDBCTemplate+Druid+BeanUtils+tomcat

    2. 数据库的设计:

      1. create database day17; -- 创建数据库
      2. use day17; -- 使用数据库
      3. create table user(
      4. id int primary key auto_increment,
      5. name varchar(20) not null,
      6. gender varchar(5),
      7. age int,
      8. address varchar(32),
      9. qq varchar(32),
      10. email varchar(32)
      11. )
  1. 开发:

    1. 环境搭建

      1. 创建数据库环境
      2. 创建项目,导入需要的jar包
    2. 编码
  1. package main.com.jie.domain;
  2. public class Users {
  3. private int id;
  4. private String name;
  5. private String gender;
  6. private int age;
  7. private String address;
  8. private String qq;
  9. private String email;
  10. @Override
  11. public String toString() {
  12. return "Users{" +
  13. "id=" + id +
  14. ", name='" + name + '\'' +
  15. ", gender='" + gender + '\'' +
  16. ", age=" + age +
  17. ", address='" + address + '\'' +
  18. ", qq='" + qq + '\'' +
  19. ", email='" + email + '\'' +
  20. '}';
  21. }
  22. public int getId() {
  23. return id;
  24. }
  25. public void setId(int id) {
  26. this.id = id;
  27. }
  28. public String getName() {
  29. return name;
  30. }
  31. public void setName(String name) {
  32. this.name = name;
  33. }
  34. public String getGender() {
  35. return gender;
  36. }
  37. public void setGender(String gender) {
  38. this.gender = gender;
  39. }
  40. public int getAge() {
  41. return age;
  42. }
  43. public void setAge(int age) {
  44. this.age = age;
  45. }
  46. public String getAddress() {
  47. return address;
  48. }
  49. public void setAddress(String address) {
  50. this.address = address;
  51. }
  52. public String getQq() {
  53. return qq;
  54. }
  55. public void setQq(String qq) {
  56. this.qq = qq;
  57. }
  58. public String getEmail() {
  59. return email;
  60. }
  61. public void setEmail(String email) {
  62. this.email = email;
  63. }
  64. }
  1. package main.com.jie.service;
  2. import main.com.jie.domain.Users;
  3. import java.util.List;
  4. /**
  5. * 用户管理的业务接口
  6. */
  7. public interface UserService {
  8. /**
  9. * 查询所有用户信息
  10. */
  11. public List<Users> findAll();
  12. }
  1. package main.com.jie.service.impl;
  2. import main.com.jie.dao.UserDao;
  3. import main.com.jie.dao.impl.UserDaoImpl;
  4. import main.com.jie.domain.Users;
  5. import main.com.jie.service.UserService;
  6. import java.util.List;
  7. public class UserServiceImpl implements UserService {
  8. private UserDao dao = new UserDaoImpl();
  9. @Override
  10. public List<Users> findAll() {
  11. //调用dao
  12. return dao.findAll();
  13. }
  14. }
  1. package main.com.jie.dao;
  2. import main.com.jie.domain.Users;
  3. import java.util.List;
  4. /**
  5. * 用户操作的dao
  6. */
  7. public interface UserDao {
  8. public List<Users> findAll();
  9. }
  1. package main.com.jie.dao.impl;
  2. import main.com.jie.dao.UserDao;
  3. import main.com.jie.domain.Users;
  4. import main.com.jie.util.JDBCUtils;
  5. import org.springframework.jdbc.core.BeanPropertyRowMapper;
  6. import org.springframework.jdbc.core.JdbcTemplate;
  7. import java.util.List;
  8. public class UserDaoImpl implements UserDao {
  9. private JdbcTemplate template = new JdbcTemplate(JDBCUtils.getDataSource());
  10. @Override
  11. public List<Users> findAll() {
  12. //使用JDBC操作数据库
  13. String sql = "select * from user";
  14. List<Users> users = template.query(sql, new BeanPropertyRowMapper<Users>(Users.class));
  15. return users;
  16. }
  17. }
  1. -

servlet层:

  1. package main.com.jie.web.servlet;
  2. import main.com.jie.domain.Users;
  3. import main.com.jie.service.UserService;
  4. import main.com.jie.service.impl.UserServiceImpl;
  5. import javax.servlet.ServletException;
  6. import javax.servlet.annotation.WebServlet;
  7. import javax.servlet.http.HttpServlet;
  8. import javax.servlet.http.HttpServletRequest;
  9. import javax.servlet.http.HttpServletResponse;
  10. import java.io.IOException;
  11. import java.util.List;
  12. @WebServlet("/userListServlet")
  13. public class UserListServlet extends HttpServlet {
  14. protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
  15. //1.调用UserService完成查询
  16. UserService service = new UserServiceImpl();
  17. List<Users> list = service.findAll();
  18. //2.将list存入request域
  19. request.setAttribute("list",list);
  20. //3.转发
  21. request.getRequestDispatcher("/list.jsp").forward(request,response);
  22. }
  23. protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
  24. this.doPost(request, response);
  25. }
  26. }
  1. package main.com.jie.util;
  2. import com.alibaba.druid.pool.DruidDataSourceFactory;
  3. import javax.sql.DataSource;
  4. import java.io.InputStream;
  5. import java.sql.Connection;
  6. import java.sql.SQLException;
  7. import java.util.Properties;
  8. /**
  9. * JDBC工具类 使用Durid连接池
  10. */
  11. public class JDBCUtils {
  12. private static DataSource ds;
  13. static {
  14. try{
  15. //1.加载配置文件
  16. Properties pro = new Properties();
  17. //使用ClassLoader加载配置文件吗,获取字节输入流
  18. InputStream resourceAsStream = JDBCUtils.class.getClassLoader().getResourceAsStream("druid.properties");
  19. pro.load(resourceAsStream);
  20. //2.初始化连接池对象
  21. ds = DruidDataSourceFactory.createDataSource(pro);
  22. }catch (Exception e){
  23. e.printStackTrace();
  24. }
  25. }
  26. /**
  27. * 获取连接池对象
  28. */
  29. public static DataSource getDataSource(){
  30. return ds;
  31. }
  32. /**
  33. * 获取连接
  34. */
  35. public static Connection getConnection() throws SQLException {
  36. return ds.getConnection();
  37. }
  38. }
  1. <%@ page contentType="text/html;charset=UTF-8" language="java" isELIgnored="false" %>
  2. <html lang="zh-CN">
  3. <head>
  4. <meta charset="utf-8"/>
  5. <meta http-equiv="X-UA-Compatible" content="IE=edge"/>
  6. <meta name="viewport" content="width=device-width, initial-scale=1"/>
  7. <title>首页</title>
  8. <!-- 1. 导入CSS的全局样式 -->
  9. <link href="css/bootstrap.min.css" rel="stylesheet">
  10. <!-- 2. jQuery导入,建议使用1.9以上的版本 -->
  11. <script src="js/jquery-2.1.0.min.js"></script>
  12. <!-- 3. 导入bootstrap的js文件 -->
  13. <script src="js/bootstrap.min.js"></script>
  14. <script type="text/javascript">
  15. </script>
  16. </head>
  17. <body>
  18. <div align="center">
  19. <a
  20. href="${pageContext.request.contextPath}/userListServlet" style="text-decoration:none;font-size:33px">查询所有用户信息
  21. </a>
  22. </div>
  23. </body>
  24. </html>
  1. <%@page contentType="text/html;charset=utf-8" language="java" isELIgnored="false" %>
  2. <%@taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>
  3. <!DOCTYPE html>
  4. <!-- 网页使用的语言 -->
  5. <html lang="zh-CN">
  6. <head>
  7. <!-- 指定字符集 -->
  8. <meta charset="utf-8">
  9. <!-- 使用Edge最新的浏览器的渲染方式 -->
  10. <meta http-equiv="X-UA-Compatible" content="IE=edge">
  11. <!-- viewport视口:网页可以根据设置的宽度自动进行适配,在浏览器的内部虚拟一个容器,容器的宽度与设备的宽度相同。
  12. width: 默认宽度与设备的宽度相同
  13. initial-scale: 初始的缩放比,为1:1 -->
  14. <meta name="viewport" content="width=device-width, initial-scale=1">
  15. <!-- 上述3个meta标签*必须*放在最前面,任何其他内容都*必须*跟随其后! -->
  16. <title>用户信息管理系统</title>
  17. <!-- 1. 导入CSS的全局样式 -->
  18. <link href="css/bootstrap.min.css" rel="stylesheet">
  19. <!-- 2. jQuery导入,建议使用1.9以上的版本 -->
  20. <script src="js/jquery-2.1.0.min.js"></script>
  21. <!-- 3. 导入bootstrap的js文件 -->
  22. <script src="js/bootstrap.min.js"></script>
  23. <style type="text/css">
  24. td, th {
  25. text-align: center;
  26. }
  27. </style>
  28. </head>
  29. <body>
  30. <div class="container">
  31. <h3 style="text-align: center">用户信息列表</h3>
  32. <table border="1" class="table table-bordered table-hover">
  33. <tr class="success">
  34. <th>编号</th>
  35. <th>姓名</th>
  36. <th>性别</th>
  37. <th>年龄</th>
  38. <th>籍贯</th>
  39. <th>QQ</th>
  40. <th>邮箱</th>
  41. <th>操作</th>
  42. </tr>
  43. <c:forEach items="${list}" var="user" varStatus="s">
  44. <tr>
  45. <td>${s.count}</td>
  46. <td>${user.name}</td>
  47. <td>${user.gender}</td>
  48. <td>${user.age}</td>
  49. <td>${user.address}</td>
  50. <td>${user.qq}</td>
  51. <td>${user.email}</td>
  52. <td><a class="btn btn-default btn-sm" href="update.html">修改</a>&nbsp;<a class="btn btn-default btn-sm" href="">删除</a></td>
  53. </tr>
  54. </c:forEach>
  55. <tr>
  56. <td colspan="8" align="center"><a class="btn btn-primary" href="add.html">添加联系人</a></td>
  57. </tr>
  58. </table>
  59. </div>
  60. </body>
  61. </html>
  1. 测试

  2. 部署运维