1. 什么是JSP

JSP全名为Java Server Pages,中文名叫java服务器页面,其根本是一个简化的Servlet设计,它是由Sun Microsystems公司倡导、许多公司参与一起建立的一种动态网页技术标准。JSP技术有点类似ASP技术,它是在传统的网页HTML文件(.htm,.html)中插入Java程序段(Scriptlet)和JSP标记(tag),从而形成JSP文件,后缀名为(*.jsp)。用JSP开发的Web应用是跨平台的,既能在Linux下运行,也能在其他操作系统上运行。

JSP将网页逻辑与网页设计的显示分离,支持可重用的基于组件的设计,使基于Web的应用程序的开发变得迅速和容易。

.html 静态页面(包含固定的页面内容)
.jsp 动态页面(页面数据可以动态更新,支持嵌套java代码和html代码)

2. JSP为什么会出现

  • 1.servlet展示信息的不方便,引入了JSP。
  • 2.JSP本质上也是一个servlet!!!!!!
  • 3.JSP就是在HTML页面中嵌入了java代码。

    3.JSP中如何嵌套java代码

    小脚本(<% java代码%>),就是java代码写在<% %>这一组标签中就行了。
    1. 声明标签 <%!变量或者方法声明%>
    2. 表达式标签 <%= 表达式%> 在页面上显示的效果
    3. 程序代码标签 <%java代码%> 页面上动态展示内容
    page指令:
    <%@ page language=”java” import=”java.util.*” pageEncoding=”UTF-8”%>
    <body>
    <%! int i=10;%><!--成员变量-->
    <%! public void show(){}%> <!--成员方法-->
    <%=i%> <!--输出变量值-->
    </body>
    
    如果把一个数据存在request域中,取值操作如下:

image.png
jsp中的注释:

<!-- html注释内容,查看源码时能看到 -->
<%-- jsp注释,查看页面源码时看不到 --%>

4. JSP的原理

image.png

当浏览器访问http://localhost:8080/day9_1/index.jsp。服务器发现后缀为.jsp,它会根据路径找到index.jsp文件,会将index.jsp翻译成index_jsp.java文件,对这个java文件进行编译,产生一个index_jsp.class文件,将class文件加载运行。将JSP翻译成java文件,它是将JSP中的所有的HTML代码通过流进行输出,也就是说最终翻译成class,被虚拟机加载,它本质是servlet,它就会往回响应,响应回去就是把JSP中的HTML代码以流的方式写回浏览器。所以在JSP中展示出了HTML代码.

5. JSP的内置对象

JSP中一共预先定义了9个这样的对象,分别为:request、response、session、application、out、pagecontext、config、page、exception
1、request对象
request 对象是 javax.servlet.httpServletRequest类型的对象。 该对象代表了客户端的请求信息,主要用于接受通过HTTP协议传送到服务器的数据。(包括头信息、系统信息、请求方式以及请求参数等)。request对象的作用域为一次请求。
2、response对象
response 代表的是对客户端的响应,主要是将JSP容器处理过的对象传回到客户端。response对象也具有作用域,它只在JSP页面内有效。所属类型:HttpServletResponse
3、session对象
session 对象是由服务器自动创建的与用户请求相关的对象。服务器为每个用户都生成一个session对象,用于保存该用户的信息,跟踪用户的操作状态。session对象内部使用Map类来保存数据,因此保存数据的格式为“Key/value”。 session对象的value可以使复杂的对象类型,而不仅仅局限于字符串类型。HttpSession
4、application对象
application 对象可将信息保存在服务器中,直到服务器关闭,否则application对象中保存的信息会在整个应用中都有效。与session对象相比,application对象生命周期更长,类似于系统的“全局变量” ServletContext
区别:
request:单次请求
session:浏览器访问期间(会话期间)
application:服务器启动期间,所存的数据可以跨浏览器
5、out 对象
out 对象用于在Web浏览器内输出信息,并且管理应用服务器上的输出缓冲区。在使用 out 对象输出数据时,可以对数据缓冲区进行操作,及时清除缓冲区中的残余数据,为其他的输出让出缓冲空间。待数据输出完毕后,要及时关闭输出流。

示例:

out.print("<script type='text/javascript'>alert('用户名不存在');location.href='index.jsp'</script>");

6、pageContext 对象
pageContext 对象的作用是取得任何范围的参数,通过它可以获取 JSP页面的out、request、reponse、session、application 等对象。pageContext对象的创建和初始化都是由容器来完成的,在JSP页面中可以直接使用pageContext对象。
7、config 对象
config 对象的主要作用是取得服务器的配置信息。通过 pageConext对象的 getServletConfig() 方法可以获取一个config对象。当一个Servlet 初始化时,容器把某些信息通过config对象传递给这个 Servlet。 开发者可以在web.xml 文件中为应用程序环境中的Servlet程序和JSP页面提供初始化参数。

//将image路径转换成服务器端的路径
String url= config.getServletContext().getRealPath("/image");
<h1>url=<%=url %></h1>

8、page 对象
page 对象代表JSP本身,只有在JSP页面内才是合法的。 page隐含对象本质上包含当前 Servlet接口引用的变量,类似于Java编程中的 this 指针。
9、exception 对象
exception 对象的作用是显示异常信息,只有在包含 isErrorPage=”true” 的页面中才可以被使用,在一般的JSP页面中使用该对象将无法编译JSP文件。excepation对象和Java的所有对象一样,都具有系统提供的继承结构。
exception 对象几乎定义了所有异常情况。在Java程序中,可以使用try/catch关键字来处理异常情况; 如果在JSP页面中出现没有捕获到的异常,就会生成 exception 对象,并把 exception 对象传送到在page指令中设定的错误页面中,然后在错误页面中处理相应的 exception 对象。
(1)先在可能发生错误的页面中添加errorPage属性:

<%@ page pageEncoding="utf-8"
  errorPage="error.jsp"
  contentType="text/html;charset=UTF-8" language="java" %>

(2) 在error.jsp页面中设置isErrorPage=”true” 的属性
(使用exception对象之前,需要先将当前页面设置成错误页面)

<%@ page language="java" isErrorPage="true" import="java.util.*" pageEncoding="UTF-8"%>

jsp的作用域:
pageContext -> request -> session -> application
当前页面 —> 单次请求有效 — > 当前会话期间—> 服务器运行期间有效

6. JSP的指令

JSP指令用来设置整个JSP页面相关的属性,如网页的编码方式和脚本语言。
语法格式如下:

<%@ directive attribute="value" %>
directive:指令名称 attribute 属性名 value:属性值
指令名称 描述
page 定义网页依赖属性,比如脚本语言、error页面、缓存需求等等
include 包含其他文件
taglib 引入标签库的定义

(1)Page指令
Page指令为容器提供当前页面的使用说明一个JSP页面可以包含多个page指令
Page指令的语法格式:
<%@ page attribute=”value” %>

image.png
(2) Include指令
JSP可以通过include指令来包含其他文件。被包含的文件可以是JSP文件、HTML文件或文本文件。包含的文件就好像是该JSP文件的一部分,会被同时编译执行。
Include指令的语法格式如下:

<%@ include file="文件相对 url 地址" %>

include 指令中的文件名实际上是一个相对的 URL 地址。
如果您没有给文件关联一个路径,JSP编译器默认在当前路径下寻找。
(3)Taglib指令
JSP API允许用户自定义标签,一个自定义标签库就是自定义标签的集合。
Taglib指令引入一个自定义标签集合的定义,包括库路径、自定义标签。

<%@ taglib uri="uri" prefix="" %>

uri属性确定标签库的位置,prefix属性指定标签库的前缀(可自定义)。

7. JSP出现的状态码

image.png

8. EL表达式

(1)什么Expression Language 表达式语言
最初定义于JSTL1.0部分
在JSP2.0中,EL从JSTL中剥离出来,放置在JSP规范中,称为JSP2.0规范的一部分
在JSP中使用EL表达式,可以简化对象和变量的访问是EL表达式
(2)EL表达式语法
语法格式:${需要展示信息的名字}
注意:
当表达式没有指定变量或者对象的范围时,
那么容器会依次从pageContext—>request—>session—>application中查找该变量或对象,我们可以通过隐含对象获得指定作用域的值:
pageScope对象,用于获取当前页面的属性值
requestScope对象,用于获取请求范围的属性值
sessionScope对象,用于获取会话范围的属性值
applicationScope对象,用于获取程序范围的属性值
语法:
${requestScope.key}
(3)EL中基础操作符
image.png
示例:

单个变量:${a+10}<br>
单个变量:${s}<br>
单个对象:${key.属性名}
//对象类型
  Users u=new Users();
  u.setName("王老五");
  u.setPass("abc");
  pageContext.setAttribute("u1",u);
  user.name=${u1.name}
  user.pass=${u1.pass}
// list集合对象:
    List list=new ArrayList();
  list.add("刘能");
  list.add(30);
  list.add(u);
  pageContext.setAttribute("list2",list);
  list1=${list2[0]}<br/>
  list2=${list2[1]}<br/>
  list3=${list2[2].pass}<br/>
// map集合:
  k1=${map1.k1}<br>
  k2=${map1.k2.username}--- ${map1.k2.password}
判断变量是否有值或是否存在:${empty key值}
  List list2=new ArrayList();
  list2.add("aa");
  request.setAttribute("list222",list2);
判断list中是否有数据:${empty list222}

9. JSTL

(1) 什么是JSTL
JSP标准标签库(JSTL)是一个JSP标签集合,它封装了JSP应用的通用核心功能
JSTL支持通用的、结构化的任务,比如迭代,条件判断,XML文档操作,国际化标签,SQL标签。 除了这些,它还提供了一个框架来使用集成JSTL的自定义标签。
根据JSTL标签所提供的功能,可以将其分为5个类别。核心标签 格式化标签 sql标签 xml标签 jstl函数(后面详细解释)
(2) JSTL的作用和语法格式
作用:简化jsp页面编写代码
语法格式:
1. 下载 jakarta-taglibs-standard-1.1.2.zip 包并解压,将 jakarta-taglibs-standard-1.1.2/lib/ 下的两个 jar 文件:standard.jar 和 jstl.jar 文件拷贝到 /WEB-INF/lib/ 下。
2. 在JSP页面中引入<%@ taglib prefix=”页面使用的名称” uri=”功能范围的路径”%>

功能范围 Uri 前缀
core http://java.sun.com/jsp/jstl/core c
i18n http://java.sun.com/jsp/jstl/fmt fmt
sql http://java.sun.com/jsp/jstl/sql sql
xml http://java.sun.com/jsp/jstl/xml x
functions http://java.sun.com/jsp/jstl/function fn

(3) 核心标签
①核心标签是最常用的 JSTL标签。引用核心标签库的语法如下:

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

② 核心标签的分类
表达式操作 out、set、remove、catch
流程控制 if、choose、when、otherwise
迭代操作 forEach、forTokens
URL操作 import、param、url、redirect
Set标签
<c:set> 主要用来将变量存储至JSP范围中 或是JavaBean的属性或Map对象中
image.png
<c:out>主要用来显示数据的内容
image.png
<c:remove> 主要负责移除变量
image.png
<c:if> 主要用于进行if判断,如果为true,则输出标签体中的内容
image.png
<c:choose>,<c:when>,<c:otherwise> 作用相当于if-else
image.png
<c:forEach> 循环控制,它可以将数组,集合(Collection)中的成员循序浏览一遍。
image.png
(4)格式化标签
1、fmt:formatDate 作用:将日期类型格式化为指定模式的字符串
属性
value:将要被格式化的数据
pattern:格式化的模式,与SimpleDateFormat的参数设置一样
var:格式化后的字符串所要存放的变量,若不指定var,则会将格式化的结果直接显示在页面
scope:变量存放的域属性空间,默认page
type:其取值为date、time、both,表示给出的value是日期、时间、还是两者都包含,默认是date
2、fmt:parseDate 作用:用于将指定字符串转化为日期类型
Value服务器获取的时间
Pattern:转换的格式
Var:页面显示的变量
3、fmt:formatNumber 按照指定格式对数字进行格式化
属性
maxIntegerDigits:整数部分最多的位数
minIntegerDigits:整数部分最少的位数
maxFrctionDigits:小数部分最多的位数
minFrctionDigits:小数部分最少的位数
var:存储格式化结果的变量
scope:var属性的作用域
integerOnly:是否只解析整型数true或者浮点数false

10、小试牛刀

做一个网页,可以登录,可以注册,登录之后显示个人昵称。
就在之前做过的视频播放网站的基础上改吧!
index.jsp

<%--
  Created by IntelliJ IDEA.
  com.zh.User: zlz1314
  Date: 2020/9/6
  Time: 11:11
  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" %>
<%@taglib prefix="sql" uri="http://java.sun.com/jsp/jstl/sql" %>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>电影星河</title>
  <style>
    /* 公共css样式 */
    * {margin:0px;padding:0px}
    a {text-decoration: none;}
    ul li{list-style:none;}

    /* 页面头部样式 */
    #header{
      position:fixed;
      top:0px;
      width:100%;
      background-color: #0785D4;
    }
    #header .header-nav{
      height:60px;
      width:1000px;
      margin:0px auto;
    }
    .logo{color:white;height: 60px;float: left;line-height: 60px;margin-left: 10px;}

    .header-nav ul li{
      float: left;
    }

    .header-nav ul li .navb-txt{
      display:block;
      width:120px;
      height:60px;
      line-height: 60px;
      font-size:18px;
      font-weight: bold;
      color:white;
      text-align:center;
    }

    .header-nav ul .navb a:hover{
      background-color: white;
      color: blue;
    }

    .header-nav ul li img{
      margin-top: 10px;
      width: 40px;
      height: 40px;
      background-position: 100%,100%;
    }

    @font-face {
      font-family: 'icomoon';
      src:  url('fonts/icomoon.eot?7kkyc2');
      src:  url('fonts/icomoon.eot?7kkyc2#iefix') format('embedded-opentype'),
      url('fonts/icomoon.ttf?7kkyc2') format('truetype'),
      url('fonts/icomoon.woff?7kkyc2') format('woff'),
      url('fonts/icomoon.svg?7kkyc2#icomoon') format('svg');
      font-weight: normal;
      font-style: normal;
    }

    .icon{
      font-family: "icomoon";
      margin-top: 20px;
      color: white;
    }
    .login,.register{color: white}
    .login:hover{color: coral;}
    .register:hover{color: rebeccapurple;}


    /* 页面导航样式 */
    /* #nav {
        height: 60px;
        margin-top: 62px;
        background-color: #46474a;
    } */

    /* 页面主体样式 */
    #container{
      width:100%;
    }

    #container .content{
      margin:0px auto;
      margin-top: 82px;
      width: 1200px;
      clear: left;
    }

    /* 左侧列表样式 */
    #left-side {
      width: 800px;
      clear: left;
    }

    #left-side .top-text{
      width: 630px;
      height: 35px;
      border-bottom: 2px solid #e5e5e5;
      line-height: 35px;
      font-size: 150%;
      color: #0785DC;
    }

    #left-side .top-text .more{
      font-size: 70%;
      float:right;
      color: #0785DC;

    }
    #left-side .top-text .more:hover{color: red;}
    #left-side ul{
      overflow: auto;
    }

    #left-side ul li {
      width: 200px;
      height: 200px;
      margin:6px;
      float: left;
    }
    #left-side ul li .img{
      width: 200px;
      height: 150px;

    }
    #left-side ul li .image {
      width: 200px;
      height: 170px;
      background-position: 100%,100%;

    }
    #left-side ul li .text{
      float: left;
    }
    #left-side ul li .name{
      line-height: 70px;
      height: 24px;
    }
    .li-hv{
      color: black;
      overflow: hidden;
    }
    .li-hv:hover{color:dodgerblue;}
    .image{
      transition: margin-left 0.2s;
    }
    .li-hv:hover .image {margin-left:-3px}


    /* 右侧播放器样式 */
    #right-side {
      position:fixed;
      top: 90px;
      left: 850px;
      height: 450px;
      width: 450px;
    }

    /* 页面尾部样式 */
    #footer{
      height: 40px;
      background-color: #ccc;
      margin-top:20px;
    }
    #footer p{
      text-align: center;
      font-size: 14px;
      color:#777;
      line-height:18px ;
    }
  </style>
</head>
<body>
<!-- 网页头部开始 -->

<div id="header">
  <div class="logo">
        <% session.setAttribute("count",1000); %>
        <span>本站已有${count}位注册用户!</span>
      </div>
      <div class="header-nav">
        <ul>
          <li class="logo">
            <img src="./images/银河.jpg" alt="电影星河">
          </li>
          <li class="logo">
            <a class = "navb-txt" href="index.jsp">电影星河</a>
          </li>
          <li class="navb">
            <a class = "navb-txt" href="#">首页</a>
          </li>
          <li class="navb">
            <a class = "navb-txt" href="#">电影分类</a>
          </li>
          <li class="navb">
            <a class = "navb-txt" href="#">本月最热</a>
          </li>
          <li class="navb">
            <a class = "navb-txt" href="#">年度榜单</a>
          </li>
          <li class="navb">
            <a class = "navb-txt" href="#">联系我们</a>
          </li>
          <li class="icon">
            <a href="#">
              <span class="icon"></span>
              <a class="login" href="login.jsp">登录</a>
              <a class="register" href="register.jsp">注册</a>
            </a>

          </li>
          <div style="clear: both;"></div>
        </ul>
      </div>
    </div>
    <!-- 网页头部结束 -->

    <!-- 导航栏开始 -->
    <!-- <div id="nav"></div> -->
    <!-- 导航栏结束 -->

    <!-- 网页主体开始 -->
    <div id="container">
      <div class="content">
        <div id="left-side">
          <div class="top-text">
            <span class="video">精选视频</span>
            <a href="https://www.bilibili.com/" class="more" target="_blank">更多>>></a>
          </div>
          <ul class="main">
            <!-- 电影列表 -->
            <li>
              <a class="li-hv" href="./videos/17张牌你能秒我?.mp4" target="播放器" title="17张牌你能秒我?">
                <div class="img">
                  <img class="image" src="./images/1.jpg" alt="17张牌你能秒我?" >
                </div>
                <div class="text">
                  <p class="name">17张牌你能秒我?</p>
                </div>
              </a>
            </li>
            <li>
              <a class="li-hv" href="./videos/敢 杀 我 的 马?.mp4" target="播放器" title="敢杀我的马?">
                <div class="img">
                  <img class="image" src="./images/5.jpg" alt="敢杀我的马?" >
                </div>
                <div class="text">
                  <p class="name">敢杀我的马?</p>
                </div>
              </a>
            </li>
            <li>
              <a class="li-hv" href="./videos/最 强 法 海.mp4" target="播放器" title="最强法海">
                <div class="img">
                  <img class="image" src="./images/2.jpg" alt="最强法海" >
                </div>
                <div class="text">
                  <p class="name">最强法海</p>
                </div>
              </a>
            </li>
            <li>
              <a class="li-hv" href="./videos/逮虾户.mp4" target="播放器" title="逮虾户">
                <div class="img">
                  <img class="image" src="./images/3.jpg" alt="逮虾户" >
                </div>
                <div class="text">
                  <p class="name">逮虾户</p>
                </div>
              </a>
            </li>
            <li>
              <a class="li-hv" href="./videos/火影.mp4" target="播放器" title="火影">
                <div class="img">
                  <img class="image" src="./images/4.jpg" alt="火影" >
                </div>
                <div class="text">
                  <p class="name">火影忍者</p>
                </div>
              </a>
            </li>
            <li>
              <a class="li-hv" href="https://www.bilibili.com/video/BV1yE411v7Pq?t=4" target="播放器" title="前方高能">
                <div class="img">
                  <img class="image" src="./images/6.jpg" alt="前方高能" >
                </div>
                <div class="text">
                  <p class="name">前方高能</p>
                </div>
              </a>
            </li>
            <li>
              <a class="li-hv" href="https://www.bilibili.com/video/BV1Vb41177ud?t=35" target="播放器" title="漫威宇宙">
                <div class="img">
                  <img class="image" src="./images/7.jpg" alt="漫威宇宙" >
                </div>
                <div class="text">
                  <p class="name">漫威宇宙</p>
                </div>
              </a>
            </li>
            <li>
              <a class="li-hv" href="https://www.bilibili.com/video/BV1cs411s7LY?t=4" target="播放器" title="哔哩哔哩拜年祭">
                <div class="img">
                  <img class="image" src="./images/8.jpg" alt="哔哩哔哩拜年祭" >
                </div>
                <div class="text">
                  <p class="name">哔哩哔哩拜年祭</p>
                </div>
              </a>
            </li>
            <li>
              <a class="li-hv" href="./videos/9.mp4" target="播放器" title="极乐净土">
                <div class="img">
                  <img class="image" src="./images/9.jpg" alt="极乐净土" >
                </div>
                <div class="text">
                  <p class="name">极乐净土</p>
                </div>
              </a>
            </li>
            <li>
              <a class="li-hv" href="https://www.bilibili.com/video/BV1FJ411V7gy?t=33" target="播放器" title="处处吻">
                <div class="img">
                  <img class="image" src="./images/10.jpg" alt="处处吻" >
                </div>
                <div class="text">
                  <p class="name">处处吻</p>
                </div>
              </a>
            </li>
            <li>
              <a class="li-hv" href="./videos/黑人抬棺.mp4" target="播放器" title="黑人抬棺">
                <div class="img">
                  <img class="image" src="./images/11.jpg" alt="黑人抬棺" >
                </div>
                <div class="text">
                  <p class="name">黑人抬棺</p>
                </div>
              </a>
            </li>
            <li>
              <a class="li-hv" href="https://www.bilibili.com/bangumi/play/ep331428" target="播放器" title="凡人修仙传">
                <div class="img">
                  <img class="image" src="./images/13.jpg" alt="凡人修仙传" >
                </div>
                <div class="text">
                  <p class="name">凡人修仙传</p>
                </div>
              </a>
            </li>
          </ul>
        </div>

        <div id="right-side">
          <iframe src = "./videos/17张牌你能秒我?.mp4" name = "播放器" frameborder="1" width="100%" height="100%"></iframe>
        </div>
      </div>
    </div>
    <!-- 网页主体结束 -->

    <!-- 网页尾部开始 -->
    <div id="footer">
      <p>本网站提供的最新电影资源均系收集于各大视频网站,本网站只提供web页面服务,并不提供影片资源存储,也不参与录制、上传</p>
      <p>若本站收录的链接无意侵犯了贵司版权,请邮箱联系我们,我们会及时处理相关内容,谢谢!邮箱:xixixi@haha.com</p>
    </div>
    <!-- 网页尾部结束 -->
</body>
</html>

login.jsp

<%--
  Created by IntelliJ IDEA.
  com.zh.User: zlz1314
  Date: 2020/9/6
  Time: 11:11
  To change this template use File | Settings | File Templates.
--%>
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>登录</title>
    <style>
        /* 全局设置,取消默认属性 */
        * {margin:0px;padding: 0px;}
        li {list-style: none;}
        /* content样式 */
        #content{width: 600px;height: 400px;background-color: white;margin: 40px auto;border: 1px solid #808080;}
        /* form样式 */
        #registForm{display: block;}

        /* title样式 */
        #title{height: 40px;width: 600px;font-size: 30px;color: #25BB9B;margin: 30px auto;font-weight: bold;line-height: 40px;border-bottom: 1px solid #f1f4f5;text-align: center;}
        /* li */
        li{display: block;}
        li .label,.r-txt,.tips {display: inline-block;}
        .label{margin: 10px 5px 10px 20px;width: 70px;height: 28px;}
        .r-txt{width: 200px;height: 22px;}
        .r-txt,.tips{margin: 10px;}
        .tips{line-height: 22px;color: darkgray; font-size: 13px;}
        /* input */
        .inptxt{height: 30px;width:200px ;line-height: 20px;border: 1px solid #cfcdc7;background: #fff;color: #999;padding: 5px 0 5px 5px;border-radius: 5px;caret-color:black;}
        /* button */
        .btn{margin:40px;display: inline-block;}
        .button{height: 40px;width: 200px;text-align: center;background-color: #25BB9B;border:none;color:white}
        .btn :hover{cursor: pointer;}
    </style>
</head>
<body>

    <div id = "content" >
        <div id="title">登录</div>
        <form id = "registForm" action="verification.jsp" method="POST" name="loginForm" onsubmit="return doSubmit()">
            <div id = "layout-bg">
                <ul class="reg-list">
                    <li>
                        <div class="label">登录账号:</div>
                        <div class="r-txt"><input class = "inptxt" type="text" placeholder="请输入账号" name="uaccount" onblur="checkUname()" /></div>
                        <div class="tips">6~18位有效字符(字母、数字、下划线)</div>
                    </li>
                    <li>
                        <div class="label">登录密码:</div>
                        <div class="r-txt"><input class = "inptxt" type="password" placeholder="请输入密码" name="upass" onblur="checkUpass()" /></div>
                        <div class="tips">6~18位任意字符</div>
                    </li>

                    <li>
                        <div class="btn" style="margin-left: 110px;">
                            <input class="button" type="submit" value="立即登录"/>
                        </div>
                    </li>

                </ul>

            </div>
        </form>
    </div>

</body>
<script>
    //验证账号函数
    function checkUaccount(){
        //获取账号信息
        var uaccount = document.myform.uname;
        //执行验证
        if(uaccount.value.match(/^\w{6,18}$/) == null){
            alert("账号请输入6~18位有效字符!");
            // console.log(uname.parentNode.nextSibling.nextSibling)
            uaccount.parentNode.nextSibling.nextSibling.style.color = "red";

            return false;
        }
        uaccount.parentNode.nextSibling.nextSibling.style.color = "darkgray";
        return true;
    }

    //验证密码函数
    function checkUpass(){
        //获取密码信息
        var upass = document.myform.upass;
        //执行验证
        if(upass.value.match(/^.{6,18}$/) == null){
            alert("密码请输入6~18位!");
            upass.parentNode.nextSibling.nextSibling.style.color = "red";
            return false;
        }
        upass.parentNode.nextSibling.nextSibling.style.color = "darkgray";
        return true;
    }
    //表单提交
    function doSubmit(){
        return checkUaccount() && checkUpass();
    }

</script>
</html>

main.jsp

<%--
  Created by IntelliJ IDEA.
  com.zh.User: zlz1314
  Date: 2020/9/6
  Time: 11:11
  To change this template use File | Settings | File Templates.
--%>
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>电影星河</title>
    <style>
        /* 公共css样式 */
        * {margin:0px;padding:0px}
        a {text-decoration: none;}
        ul li{list-style:none;}

        /* 页面头部样式 */
        #header{
            position:fixed;
            top:0px;
            width:100%;
            background-color: #0785D4;
        }
        #header .header-nav{
            height:60px;
            width:1000px;
            margin:0px auto;
        }
        .logo{color:white;height: 60px;float: left;line-height: 60px;margin-left: 10px;}

        .header-nav ul li{
            float: left;
        }

        .header-nav ul li .navb-txt{
            display:block;
            width:120px;
            height:60px;
            line-height: 60px;
            font-size:18px;
            font-weight: bold;
            color:white;
            text-align:center;
        }

        .header-nav ul .navb a:hover{
            background-color: white;
            color: blue;
        }

        .header-nav ul li img{
            margin-top: 10px;
            width: 40px;
            height: 40px;
            background-position: 100%,100%;
        }

        @font-face {
            font-family: 'icomoon';
            src:  url('fonts/icomoon.eot?7kkyc2');
            src:  url('fonts/icomoon.eot?7kkyc2#iefix') format('embedded-opentype'),
            url('fonts/icomoon.ttf?7kkyc2') format('truetype'),
            url('fonts/icomoon.woff?7kkyc2') format('woff'),
            url('fonts/icomoon.svg?7kkyc2#icomoon') format('svg');
            font-weight: normal;
            font-style: normal;
        }

        .icon{
            font-family: "icomoon";
            margin-top: 20px;
            color: white;
        }
        .login,.register{color: white}
        .login:hover{color: coral;}
        .register:hover{color: rebeccapurple;}


        /* 页面导航样式 */
        /* #nav {
            height: 60px;
            margin-top: 62px;
            background-color: #46474a;
        } */

        /* 页面主体样式 */
        #container{
            width:100%;
        }

        #container .content{
            margin:0px auto;
            margin-top: 82px;
            width: 1200px;
            clear: left;
        }

        /* 左侧列表样式 */
        #left-side {
            width: 800px;
            clear: left;
        }

        #left-side .top-text{
            width: 630px;
            height: 35px;
            border-bottom: 2px solid #e5e5e5;
            line-height: 35px;
            font-size: 150%;
            color: #0785DC;
        }

        #left-side .top-text .more{
            font-size: 70%;
            float:right;
            color: #0785DC;

        }
        #left-side .top-text .more:hover{color: red;}
        #left-side ul{
            overflow: auto;
        }

        #left-side ul li {
            width: 200px;
            height: 200px;
            margin:6px;
            float: left;
        }
        #left-side ul li .img{
            width: 200px;
            height: 150px;

        }
        #left-side ul li .image {
            width: 200px;
            height: 170px;
            background-position: 100%,100%;

        }
        #left-side ul li .text{
            float: left;
        }
        #left-side ul li .name{
            line-height: 70px;
            height: 24px;
        }
        .li-hv{
            color: black;
            overflow: hidden;
        }
        .li-hv:hover{color:dodgerblue;}
        .image{
            transition: margin-left 0.2s;
        }
        .li-hv:hover .image {margin-left:-3px}


        /* 右侧播放器样式 */
        #right-side {
            position:fixed;
            top: 90px;
            left: 850px;
            height: 450px;
            width: 450px;
        }

        /* 页面尾部样式 */
        #footer{
            height: 40px;
            background-color: #ccc;
            margin-top:20px;
        }
        #footer p{
            text-align: center;
            font-size: 14px;
            color:#777;
            line-height:18px ;
        }
    </style>
</head>
<body>
<!-- 网页头部开始 -->

<div id="header">
    <div class="logo">
        <span>本站已有${sessionScope.count + 10}位注册用户!</span>
    </div>
    <div class="header-nav">
        <ul>
            <li class="logo">
                <img src="./images/银河.jpg" alt="电影星河">
            </li>
            <li class="logo">
                <a class = "navb-txt" href="movies.html">电影星河</a>
            </li>
            <li class="navb">
                <a class = "navb-txt" href="#">首页</a>
            </li>
            <li class="navb">
                <a class = "navb-txt" href="#">电影分类</a>
            </li>
            <li class="navb">
                <a class = "navb-txt" href="#">本月最热</a>
            </li>
            <li class="navb">
                <a class = "navb-txt" href="#">年度榜单</a>
            </li>
            <li class="navb">
                <a class = "navb-txt" href="#">联系我们</a>
            </li>
            <li class="icon">
                <a href="#">
                    <span class="icon"></span>
                    <a class="login"><%= session.getAttribute("name") %></a>
                </a>

            </li>
            <div style="clear: both;"></div>
        </ul>
    </div>
</div>
<!-- 网页头部结束 -->

<!-- 导航栏开始 -->
<!-- <div id="nav"></div> -->
<!-- 导航栏结束 -->

<!-- 网页主体开始 -->
<div id="container">
    <div class="content">
        <div id="left-side">
            <div class="top-text">
                <span class="video">精选视频</span>
                <a href="https://www.bilibili.com/" class="more" target="_blank">更多>>></a>
            </div>
            <ul class="main">
                <!-- 电影列表 -->
                <li>
                    <a class="li-hv" href="./videos/17张牌你能秒我?.mp4" target="播放器" title="17张牌你能秒我?">
                        <div class="img">
                            <img class="image" src="./images/1.jpg" alt="17张牌你能秒我?" >
                        </div>
                        <div class="text">
                            <p class="name">17张牌你能秒我?</p>
                        </div>
                    </a>
                </li>
                <li>
                    <a class="li-hv" href="./videos/敢 杀 我 的 马?.mp4" target="播放器" title="敢杀我的马?">
                        <div class="img">
                            <img class="image" src="./images/5.jpg" alt="敢杀我的马?" >
                        </div>
                        <div class="text">
                            <p class="name">敢杀我的马?</p>
                        </div>
                    </a>
                </li>
                <li>
                    <a class="li-hv" href="./videos/最 强 法 海.mp4" target="播放器" title="最强法海">
                        <div class="img">
                            <img class="image" src="./images/2.jpg" alt="最强法海" >
                        </div>
                        <div class="text">
                            <p class="name">最强法海</p>
                        </div>
                    </a>
                </li>
                <li>
                    <a class="li-hv" href="./videos/逮虾户.mp4" target="播放器" title="逮虾户">
                        <div class="img">
                            <img class="image" src="./images/3.jpg" alt="逮虾户" >
                        </div>
                        <div class="text">
                            <p class="name">逮虾户</p>
                        </div>
                    </a>
                </li>
                <li>
                    <a class="li-hv" href="./videos/火影.mp4" target="播放器" title="火影">
                        <div class="img">
                            <img class="image" src="./images/4.jpg" alt="火影" >
                        </div>
                        <div class="text">
                            <p class="name">火影忍者</p>
                        </div>
                    </a>
                </li>
                <li>
                    <a class="li-hv" href="https://www.bilibili.com/video/BV1yE411v7Pq?t=4" target="播放器" title="前方高能">
                        <div class="img">
                            <img class="image" src="./images/6.jpg" alt="前方高能" >
                        </div>
                        <div class="text">
                            <p class="name">前方高能</p>
                        </div>
                    </a>
                </li>
                <li>
                    <a class="li-hv" href="https://www.bilibili.com/video/BV1Vb41177ud?t=35" target="播放器" title="漫威宇宙">
                        <div class="img">
                            <img class="image" src="./images/7.jpg" alt="漫威宇宙" >
                        </div>
                        <div class="text">
                            <p class="name">漫威宇宙</p>
                        </div>
                    </a>
                </li>
                <li>
                    <a class="li-hv" href="https://www.bilibili.com/video/BV1cs411s7LY?t=4" target="播放器" title="哔哩哔哩拜年祭">
                        <div class="img">
                            <img class="image" src="./images/8.jpg" alt="哔哩哔哩拜年祭" >
                        </div>
                        <div class="text">
                            <p class="name">哔哩哔哩拜年祭</p>
                        </div>
                    </a>
                </li>
                <li>
                    <a class="li-hv" href="./videos/9.mp4" target="播放器" title="极乐净土">
                        <div class="img">
                            <img class="image" src="./images/9.jpg" alt="极乐净土" >
                        </div>
                        <div class="text">
                            <p class="name">极乐净土</p>
                        </div>
                    </a>
                </li>
                <li>
                    <a class="li-hv" href="https://www.bilibili.com/video/BV1FJ411V7gy?t=33" target="播放器" title="处处吻">
                        <div class="img">
                            <img class="image" src="./images/10.jpg" alt="处处吻" >
                        </div>
                        <div class="text">
                            <p class="name">处处吻</p>
                        </div>
                    </a>
                </li>
                <li>
                    <a class="li-hv" href="./videos/黑人抬棺.mp4" target="播放器" title="黑人抬棺">
                        <div class="img">
                            <img class="image" src="./images/11.jpg" alt="黑人抬棺" >
                        </div>
                        <div class="text">
                            <p class="name">黑人抬棺</p>
                        </div>
                    </a>
                </li>
                <li>
                    <a class="li-hv" href="https://www.bilibili.com/bangumi/play/ep331428" target="播放器" title="凡人修仙传">
                        <div class="img">
                            <img class="image" src="./images/13.jpg" alt="凡人修仙传" >
                        </div>
                        <div class="text">
                            <p class="name">凡人修仙传</p>
                        </div>
                    </a>
                </li>
            </ul>
        </div>

        <div id="right-side">
            <iframe src = "./videos/17张牌你能秒我?.mp4" name = "播放器" frameborder="1" width="100%" height="100%"></iframe>
        </div>
    </div>
</div>
<!-- 网页主体结束 -->

<!-- 网页尾部开始 -->
<div id="footer">
    <p>本网站提供的最新电影资源均系收集于各大视频网站,本网站只提供web页面服务,并不提供影片资源存储,也不参与录制、上传</p>
    <p>若本站收录的链接无意侵犯了贵司版权,请邮箱联系我们,我们会及时处理相关内容,谢谢!邮箱:xixixi@haha.com</p>
</div>
<!-- 网页尾部结束 -->
</body>
</html>

register.jsp

<%--
  Created by IntelliJ IDEA.
  com.zh.User: zlz1314
  Date: 2020/9/6
  Time: 11:11
  To change this template use File | Settings | File Templates.
--%>
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>注册</title>
    <style>
        /* 全局设置,取消默认属性 */
        * {margin:0px;padding: 0px;}
        li {list-style: none;}
        /* content样式 */
        #content{width: 600px;height: 400px;background-color: white;margin: 40px auto;border: 1px solid #808080;}
        /* form样式 */
        #registForm{display: block;}

        /* title样式 */
        #title{height: 40px;width: 600px;font-size: 30px;color: #25BB9B;margin: 30px auto;font-weight: bold;line-height: 40px;border-bottom: 1px solid #f1f4f5;text-align: center;}
        /* li */
        li{display: block;}
        li .label,.r-txt,.tips {display: inline-block;}
        .label{margin: 10px 5px 10px 20px;width: 70px;height: 28px;}
        .r-txt{width: 200px;height: 22px;}
        .r-txt,.tips{margin: 10px;}
        .tips{line-height: 22px;color: darkgray; font-size: 13px;}
        /* input */
        .inptxt{height: 30px;width:200px ;line-height: 20px;border: 1px solid #cfcdc7;background: #fff;color: #999;padding: 5px 0 5px 5px;border-radius: 5px;caret-color:black;}
        /* button */
        .btn{margin:40px;display: inline-block;}
        .button{height: 40px;width: 200px;text-align: center;background-color: #25BB9B;border:none;color:white}
        .btn :hover{cursor: pointer;}
    </style>
</head>
<body>
    <div id = "content" >
        <div id="title">注册</div>
        <form id = "registForm" action="registerVer.jsp" method="POST" name="regForm" onsubmit="return doSubmit()">
            <div id = "layout-bg">
                <ul class="reg-list">
                    <li>
                        <div class="label">注册名称:</div>
                        <div class="r-txt"><input class = "inptxt" type="text" placeholder="请输入名称" name="uname" onblur="checkUname()" /></div>
                        <div class="tips">6~18位有效字符(字母、数字、下划线)</div>
                    </li>
                    <li>
                        <div class="label">注册账号:</div>
                        <div class="r-txt"><input class = "inptxt" type="text" placeholder="请输入账号" name="uaccount" onblur="checkUaccount()" /></div>
                        <div class="tips">6~18位有效字符(字母、数字、下划线)</div>
                    </li>
                    <li>
                        <div class="label">注册密码:</div>
                        <div class="r-txt"><input class = "inptxt" type="password" placeholder="请输入密码" name="upass" onblur="checkUpass()" /></div>
                        <div class="tips">6~18位任意字符</div>
                    </li>

                    <li>
                        <div class="btn" style="margin-left: 110px;">
                            <input class="button" type="submit" value="立即注册"/>
                        </div>
                    </li>

                </ul>

            </div>
        </form>
    </div>

</body>
<script>
    //验证账号函数
    function checkUname(){
        //获取账号信息
        var uname = document.myform.uname;
        //执行验证
        if(uname.value.match(/^\w{6,18}$/) == null){
            alert("账号请输入6~18位有效字符!");
            // console.log(uname.parentNode.nextSibling.nextSibling)
            uname.parentNode.nextSibling.nextSibling.style.color = "red";

            return false;
        }
        uname.parentNode.nextSibling.nextSibling.style.color = "darkgray";
        return true;
    }

    //验证账号函数
    function checkUaccount(){
        //获取账号信息
        var uaccount = document.myform.uaccount;
        //执行验证
        if(uaccount.value.match(/^\w{6,18}$/) == null){
            alert("账号请输入6~18位有效字符!");
            uaccount.parentNode.nextSibling.nextSibling.style.color = "red";

            return false;
        }
        uaccount.parentNode.nextSibling.nextSibling.style.color = "darkgray";
        return true;
    }

    //验证密码函数
    function checkUpass(){
        //获取密码信息
        var upass = document.myform.upass;
        //执行验证
        if(upass.value.match(/^.{6,18}$/) == null){
            alert("密码请输入6~18位!");
            upass.parentNode.nextSibling.nextSibling.style.color = "red";
            return false;
        }
        upass.parentNode.nextSibling.nextSibling.style.color = "darkgray";
        return true;
    }
    //表单提交
    function doSubmit(){
        return checkUaccount() && checkUpass() && checkUname();
    }

</script>
</html>

registerVer.jsp

<%@ page import="java.io.PrintWriter" %>
<%@ page import="com.zh.User" %>
<%@ page import="com.zh.Register" %><%--
  Created by IntelliJ IDEA.
  User: zlz1314
  Date: 2020/9/6
  Time: 19:30
  To change this template use File | Settings | File Templates.
--%>
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
    <title>register</title>
</head>
<body>
<%
    PrintWriter writer = response.getWriter();
    String uname = request.getParameter("uname");
    String uaccount = request.getParameter("uaccount");
    String upass = request.getParameter("upass");
    User user = new User(uname,uaccount,upass);
    boolean status = new Register().register(user);
    if (!status){
        session.setAttribute("name",uname);
        writer.write("<script>alert('注册成功!即将跳转到登录界面!');location.href='login.jsp'</script>");
    }else{
        writer.write("<script>alert('注册失败!');location.href='register.jsp'</script>");
    }
%>
</body>
</html>

verification.jsp

<%@ page import="com.zh.Login" %>
<%@ page import="com.zh.User" %>
<%@ page import="java.io.PrintWriter" %>
<%--
  Created by IntelliJ IDEA.
  User: zlz1314
  Date: 2020/9/6
  Time: 19:04
  To change this template use File | Settings | File Templates.
--%>
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
    <title>verification</title>
</head>
<body>
    <%
        PrintWriter writer = response.getWriter();
        String uaccount = request.getParameter("uaccount");
        String upass = request.getParameter("upass");
        User user = new User(null,uaccount,upass);
        String uname = new Login().login(user);
        if (uname != null){
            session.setAttribute("name",uname);
            writer.write("<script>alert('登录成功!');location.href='main.jsp'</script>");
        }else{
            writer.write("<script>alert('登录失败,请检查你的账号密码!');location.href='login.jsp'</script>");
        }
    %>

</body>
</html>

下面是一些类:
DruidUtil.java

package com.zh;

import com.alibaba.druid.pool.DruidDataSourceFactory;

import javax.sql.DataSource;
import java.sql.Connection;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
import java.util.Properties;

public class DruidUtil {

    private static DataSource ds;
    static{
        try {
            Properties ppt = new Properties();
            ppt.load(DruidUtil.class.getClassLoader().getResourceAsStream("druid.properties"));
            ds = DruidDataSourceFactory.createDataSource(ppt);
        } catch (Exception e) {
            e.printStackTrace();
        }
    }


    /**
     * 从连接池中取出一个连接给用户
     * @return 数据库链接
     */
    public static Connection getConnection(){
        try {
            return ds.getConnection();
        } catch (SQLException throwables) {
            throwables.printStackTrace();
        }
        return null;
    }


    public static void close(Connection conn, Statement state, ResultSet rs){
        try {
            rs.close();
        } catch (Exception throwables) {
            throwables.printStackTrace();
        }
        try {
            state.close();
        } catch (Exception throwables) {
            throwables.printStackTrace();
        }
        try {
            conn.close();
        } catch (Exception throwables) {
            throwables.printStackTrace();
        }
    }
}

Login.java

package com.zh;

import java.sql.*;

/**
 * @Author: deemoHui
 * @Description: 登录逻辑
 * @Date Created in 2020-09-04 11:40
 * @Modified By:
 */
public class Login {
    public String login(User user) {
        String status = null;
        try {
            Connection conn = DruidUtil.getConnection();
            PreparedStatement state = null;
            if (conn != null) {
                state = conn.prepareStatement("select uname from user where account = ? and password = ?");
                state.setString(1,user.getAccount());
                state.setString(2,user.getPassword());
                ResultSet resultSet = state.executeQuery();
                resultSet.next();
                status = resultSet.getString("uname");
                state.close();
                conn.close();
            }
        } catch (SQLException e) {
            e.printStackTrace();
        }
        return status;
    }
}

Register.java

package com.zh;

import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.SQLException;

/**
 * @Author: deemoHui
 * @Description:
 * @Date Created in 2020-09-06 14:08
 * @Modified By:
 */
public class Register {
    public boolean register(User user) {
        boolean status = false;
        try {
            Connection conn = DruidUtil.getConnection();
            PreparedStatement state = null;
            if (conn != null) {
                state = conn.prepareStatement("INSERT INTO user VALUES(NULL,?,?,?)");
                state.setString(1,user.getName());
                state.setString(2,user.getAccount());
                state.setString(3,user.getPassword());
                status = state.execute();
                state.close();
                conn.close();
            }
        } catch (SQLException e) {
            e.printStackTrace();
        }
        return status;
    }
}

User.java

package com.zh;

import java.util.Objects;

/**
 * @Author: deemoHui
 * @Description: 用户类
 * @Date Created in 2020-09-04 11:38
 * @Modified By:
 */
public class User {
    private String name;
    private String account;
    private String password;

    public User() {
    }

    public User(String name, String account, String password) {
        this.name = name;
        this.account = account;
        this.password = password;
    }

    public String getAccount() {
        return account;
    }

    public void setAccount(String account) {
        this.account = account;
    }

    public String getPassword() {
        return password;
    }

    public void setPassword(String password) {
        this.password = password;
    }

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    @Override
    public boolean equals(Object o) {
        if (this == o) return true;
        if (o == null || getClass() != o.getClass()) return false;
        User user = (User) o;
        return Objects.equals(name, user.name) &&
                Objects.equals(account, user.account) &&
                Objects.equals(password, user.password);
    }

    @Override
    public int hashCode() {
        return Objects.hash(name, account, password);
    }

    @Override
    public String toString() {
        return "User{" +
                "name='" + name + '\'' +
                ", account='" + account + '\'' +
                ", password='" + password + '\'' +
                '}';
    }
}

还有druid.properties和上一次的一样
运行效果:
image.pngimage.png
image.pngimage.pngimage.png
image.png