• JSP速过教程


    JSP速过教程:轻松入门Java服务器页面开发

    Java服务器页面(JavaServer Pages,简称JSP)是一种用于开发动态网页的技术,它允许开发人员嵌入Java代码和特定的JSP标签在HTML页面中。本教程将带你快速入门JSP开发,为你展示基本概念和实用技巧。
    jsp标签通常使用<% %>作为标签的开头和结尾

    JSP执行过程

    JSP页面在服务器端被转换为Java servlets,然后在服务器上执行,产生的结果(通常是一个HTML页面)被发送到客户端。以下是Java执行JSP的基本过程:

    1. 请求JSP页面 :用户在Web浏览器中输入JSP页面的URL或点击相关的链接,向服务器发起请求。
    2. 服务器解析JSP文件:服务器接收到请求后,会首先检查JSP文件是否存在。如果存在,服务器会使用JSP引擎(一种将JSP代码转化为Java代码的程序)来解析JSP文件。
    3. 生成Java Servlet:JSP引擎将JSP文件转化为一个Java servlet。在这个过程中,所有的JSP脚本元素(<% %>)和内置标签(如等)都会被转换为Java代码。
    4. 执行Java Servlet:一旦JSP文件被转换为Java servlet,服务器就会执行这个servlet。在这个过程中,Java代码会被执行,并且可能会与数据库或者其他服务器资源进行交互。
    5. 生成HTML:在Java servlet执行的过程中,可能会生成HTML代码,或者其他的响应数据。这些数据会被放入一个HTTP响应对象中。
    6. 返回HTML到客户端:最后,服务器会将生成的HTML代码(或者其他类型的响应数据)发送到客户端,然后在用户的浏览器中显示出来。

    以上就是Java执行JSP的基本过程。需要注意的是,这个过程并不是线性的,也就是说,在一个JSP页面被请求和执行的过程中,可能会涉及到多次的解析和编译。例如,如果JSP页面的数据需要从数据库中获取,那么在第一次请求该页面时,JSP引擎可能需要先将JSP文件转化为Java servlet,然后在执行servlet的过程中访问数据库,获取数据。如果这些数据发生改变,那么在下一次请求该页面时,可能需要重新执行这个过程。

    1. 环境搭建

    首先,确保你的系统中已经安装了Java开发环境。然后,下载并安装一个Java Web服务器,比如Apache Tomcat。

    2. 创建第一个JSP页面

    在Tomcat的webapps目录下创建一个新文件夹(比如mywebapp),在该文件夹内创建一个JSP文件(比如index.jsp)。

    
    
    
        我的第一个JSP页面
    
    
        

    Hello, World! This is my first JSP page.

    <% String message = "Welcome to JSP!"; out.println("

    " + message + "

    "); %>
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13

    运行tomcat,在浏览器中访问http://localhost:8080/mywebapp/index.jsp,你将看到你的第一个JSP页面。

    3. JSP基本语法

    • 声明变量和方法
      语法格式:可以同时声明多个,以分号隔开即可。
    <%! declaration; [ declaration; ]+ ... %>
    
    • 1
    <%! int count = 0; %>
    <%! void increaseCount() { count++; } %>
    
    • 1
    • 2
    • 表达式:在HTML中嵌入Java表达式。
      语法格式:<%= 表达式 %>,直接在两个百分号之间写代码即可。

    Count: <%= count %>

    • 1
    • 脚本片段:包含一段Java代码。
      脚本程序可以包含任意量的Java语句、变量、方法或表达式,只要它们在脚本语言中是有效的。
    <%
        for (int i = 0; i < 5; i++) {
            out.println("Iteration: " + i + "
    "); } %>
    • 1
    • 2
    • 3
    • 4
    • 5

    4. JSP指令

    • 页面指令:设置全局属性,通常放在JSP文件的顶部。
    <%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%>
    
    • 1
    • 包含文件:包含其他文件的内容。
      包含文件用于将一个或多个jsp作为组件插入另一个jsp文件中,可以提高代码的复用
    <%@ include file="header.jsp" %>
    
    • 1

    示例如下所示:
    页面1:

    
    <%@ page contentType="text/html;charset=UTF-8" language="java" isErrorPage="true" %>
    
    <%@ include file="success.jsp" %>
    <html>
    <head>
        <title>Error Pagetitle>
    head>
    <body>
        <h1> you have operated failedh1>
        
        <%@ include file="success.jsp" %>
    body>
    html>
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14

    页面2:

    <%@ page contentType="text/html;charset=UTF-8" language="java" %>
    <html>
    <head>
        <title>Success Pagetitle>
    head>
    <body>
         <h1> you have operated successfullyh1>
    body>
    html>
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9

    5. JSP标签库

    JSP标签库(JSTL)提供了更丰富的标签,用于简化JSP页面的开发。

    • 引入JSTL库:下载JSTL库并放入WEB-INF/lib目录下。
    <%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c" %>
    
    • 1
    • 使用循环标签
    
        

    Iteration: ${i}

    • 1
    • 2
    • 3

    6. 处理用户输入

    JSP也可以处理用户输入,比如表单提交。

    • 1
    • 2
    • 3
    • 4

    process.jsp中处理表单数据。

    <%@ page import="java.io.*" %>
    <%
        String username = request.getParameter("username");
        out.println("Hello, " + username + "!");
    %>
    
    • 1
    • 2
    • 3
    • 4
    • 5

    这就是一个简单的JSP页面,它可以接受用户输入并显示相应的消息。

    7. JSP Cookie

    cookie是客户-服务器通话过程中维持状态的一种技术,存储在客户端,或者说浏览器。
    cookie通常在http信息头中设置。
    以下是常用的jsp处理cookie的方法:

    1. 创建Cookie对象
    Cookie cookie = new Cookie("username", "John");
    
    • 1
    1. 设置Cookie的属性
    // 设置`Cookie`的过期时间
    cookie.setMaxAge(3600); // 1小时
    
    • 1
    • 2
    1. 设置Cookie的路径
    // 设置`Cookie`的路径
    cookie.setPath("/myapp");
    
    • 1
    • 2
    1. 设置Cookie的域
    // 设置`Cookie`的域
    cookie.setDomain(".myapp.com");
    
    • 1
    • 2
    1. 设置Cookie的HTTP头信息
    // 设置`Cookie`的HTTP头信息
    cookie.setHttpOnly(true); // 不允许客户端脚本访问
    cookie.setSecure(true); // 只允许HTTPS协议访问
    
    • 1
    • 2
    • 3
    1. 添加Cookie到响应
    response.addCookie(cookie);
    
    • 1
    1. 获取Cookie对象
    Cookie cookie = request.getCookies()[0];
    
    • 1
    1. 删除Cookie
    Cookie cookie = new Cookie("username", null);
    cookie.setMaxAge(0); // 设置过期时间为0,即立即删除
    response.addCookie(cookie);
    
    • 1
    • 2
    • 3

    以下是一个完整的Cookie处理的示例:

    <%@ page import="java.util.*" %>
    <%
        Cookie cookie = new Cookie("username", "John");
        cookie.setMaxAge(3600); // 设置过期时间为1小时
        cookie.setPath("/myapp"); // 设置路径
        cookie.setDomain(".myapp.com"); // 设置域
        cookie.setHttpOnly(true); // 不允许客户端脚本访问
        cookie.setSecure(true); // 只允许HTTPS协议访问
        response.addCookie(cookie); // 添加Cookie到响应
    
        Cookie[] cookies = request.getCookies();
        if(cookies != null){
            for(Cookie c : cookies){
                if(c.getName().equals("username")){
                    out.println("username: " + c.getValue());
                }
            }
        }
    
        Cookie delCookie = new Cookie("username", null);
        delCookie.setMaxAge(0); // 设置过期时间为0,即立即删除
        response.addCookie(delCookie); // 删除Cookie
    %>
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23

    在这个示例中,我们首先创建了一个名为usernameCookie对象,并设置了它的属性。然后,我们将这个Cookie对象添加到了响应中。接着,我们从请求中获取了所有的Cookie对象,并输出了名为usernameCookie的值。最后,我们创建了一个名为usernameCookie对象,并设置了它的过期时间为0,即立即删除,然后将这个Cookie对象添加到了响应中,从而删除了这个Cookie

    8、Jsp Session

    http协议是无状态的,所谓的无状态就是不记录本次会话和上次会话的联系,被认为是无关联的。
    所以通过cookie和session来保存会话的关系。cookie保存在客户端(浏览器),session保存在服务器用来识别或标识客户端请求。

    以下是jsp中一些常用的session对象的使用方法和代码示例:

    1. 获取session对象
    session = request.getSession();
    
    • 1
    1. 设置session属性
    session.setAttribute("username", "John");
    
    • 1
    1. 获取session属性
    String username = (String) session.getAttribute("username");
    
    • 1
    1. 删除session属性
    session.removeAttribute("username");
    
    • 1
    1. 获取sessionID
    String sessionId = session.getId();
    
    • 1
    1. 检查session是否有效
    boolean isSessionValid = session.isNew();
    
    • 1
    1. 设置session过期时间
    session.setMaxInactiveInterval(3600); // 设置过期时间为1小时
    
    • 1
    1. 获取session对象的生命周期
    int maxInactiveInterval = session.getMaxInactiveInterval();
    
    • 1

    以下是一个完整的session处理的示例:

    <%@ page import="java.util.*" %>
    <%
        String username = "John";
        session.setAttribute("username", username);
        String username2 = (String) session.getAttribute("username");
        if(username2.equals(username)){
            out.println("session is valid");
        }
        session.removeAttribute("username");
        String sessionId = session.getId();
        session.setMaxInactiveInterval(3600); // 设置过期时间为1小时
        int maxInactiveInterval = session.getMaxInactiveInterval();
        session.invalidate(); // 销毁session
    %>
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14

    在这个示例中,我们首先设置了session属性,并获取了这个属性的值。然后,我们检查了session是否有效。接着,我们删除了session属性,并获取了session的ID。然后,我们设置了session的过期时间为1小时,并获取了session对象的生命周期。最后,我们销毁了session

    9、JSP日期处理

    Jsp中对于时间和日期的处理和java中类似。通过Date创建时间对象,通过getTime()方法获取毫秒数,也可以使用SimpleDateFormat对时间进行格式化。
    以下是一些常用的方法:

    1. Boolean after(Date date):比较时间是否在给定时间之后
    2. Boolean before(Date date):比较时间是否在给定时间之后
    3. int compareTo(Date date):与给定时间进行比较,相等为0,早于为负,晚于为正
    4. boolean equals(Date date):相等为true’
    5. long getTime():返回毫秒数
    6. void setTime(long time):根据毫秒数设置时间
    7. String toString():转为字符串

    10、Jsp转发和重定向

    1. 转发使用response.getRequestDispatcher("str").forward(request,response);
    2. 重定向使用request.sendRedirect("str");
      详细说明重定向和转发可以查看这篇文章点击跳转
  • 相关阅读:
    网络安全(黑客)自学
    03【C语言 & 趣味算法】(值得品味的一道题)打鱼还是晒网?结构体的简单应用。函数的应用。判断闰年的应用。求指定日期距1990年1月1日的天数。
    zibbix安装部署
    户外暴晒测试系统太阳光模拟器
    吴恩达作业ex5:Regularized Linear Regression and Bias v.s. Variance
    PFSK130 3BSE002616R1 无源滤波器的定义
    三星正在开发HBM4,预计2025年推出
    【解决方案】Java 互联网项目中消息通知系统的设计与实现(上)
    对boot项目拆分成cloud项目的笔记
    python 机器视觉 车牌识别 - opencv 深度学习 机器学习 计算机竞赛
  • 原文地址:https://blog.csdn.net/weixin_45915647/article/details/133898013