el表达式的使用教程

接热心网友:内部静态类的要求,今天它来了,时尚高端,无人能敌,数据获取,快于荒谬。
首先我们进行项目数据库的创建,
在这里插入图片描述然后根据数据库写出实体类

package entity;

public class Entity {
    private Integer id;
    private String name;
    private String dept;

    public Entity() {
    }

    public Entity(Integer id, String name, String dept) {
        this.id = id;
        this.name = name;
        this.dept = dept;
    }

    public Integer getId() {
        return id;
    }

    public void setId(Integer id) {
        this.id = id;
    }

    public String getName() {
        return name;
    }

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

    public String getDept() {
        return dept;
    }

    public void setDept(String dept) {
        this.dept = dept;
    }
}

配置数据库连接:用德鲁伊进行连接
首先写出配置文件druid.properties:

# 加载数据库驱动
driverClassName=com.mysql.jdbc.Driver
# 连接数据库的url,db1表示数据库名,useSSL=false表示不使用SSL规范
url=jdbc:mysql://127.0.0.1:3306/sunhill?useSSL=false&characterEncoding=UTF-8&serverTimezone=UTC
# 用户登录数据库的账号和密码
username=root
password=123
# 初始化连接数量
initialSize=5
# 最大连接数量
maxActive=10
# 最大等待时间
maxWait=3000

创建数据库封装连接工具类,增加连接安全性。

package JdbcUtils;

import com.alibaba.druid.pool.DruidDataSourceFactory;

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

public class DataSourceUtils {
    /**
     * DataSource 数据库连接池对象
     */
    private static DataSource dataSource;

    /**
     * 私有化构造方法
     */
    private DataSourceUtils() {
    }

    /**
     * 使用静态代码块加载配置文件
     */
    static {
        try {
            // 读取配置文件
            Properties properties = new Properties();
            InputStream resourceAsStream = DataSourceUtils.class.getClassLoader().getResourceAsStream("druid.properties");
            properties.load(resourceAsStream);
            // 获取数据库连接池
            dataSource = DruidDataSourceFactory.createDataSource(properties);
        } catch (Exception e) {
            e.printStackTrace();
        }
    }

    /**
     * 封装获取连接方法
     *
     * @return
     * @throws SQLException
     */
    public static Connection getConnection() {
        try {
            return dataSource.getConnection();
        } catch (Exception e) {
            e.printStackTrace();
            return null;
        }
    }

    /**
     * 封装关闭连接方法
     */
    public static void close(Connection connection, Statement statement, ResultSet resultSet) {
        if (connection != null) {
            try {
                connection.close();
            } catch (SQLException throwables) {
                throwables.printStackTrace();
            }
        }
        if (statement != null) {
            try {
                statement.close();
            } catch (SQLException throwables) {
                throwables.printStackTrace();
            }
        }
        if (resultSet != null) {
            try {
                resultSet.close();
            } catch (SQLException throwables) {
                throwables.printStackTrace();
            }
        }
    }
}

然后进行Dao层的书写:

package Dao;

import JdbcUtils.DataSourceUtils;
import entity.Entity;


import java.sql.*;
import java.util.ArrayList;
import java.util.List;

import static JdbcUtils.DataSourceUtils.*;
import static com.alibaba.druid.util.JdbcUtils.close;

public class Dao {
    Connection connection = null;
    ResultSet resultset = null;
    PreparedStatement preparedStatement = null;
    public List<Entity> TaogetAll() throws SQLException {

        try {
            connection = getConnection();
            //获取编译者执行者对象,防止sql语句注入的问题
            preparedStatement = connection.prepareStatement("select * from Taotianci");
            //执行我们的sql语句
            resultset = preparedStatement.executeQuery();
            ArrayList<Entity> entities = new ArrayList<>();
            while (resultset.next()) {
                //获取数据库中的信息
                Integer id = resultset.getInt("id");
                String name = resultset.getString("name");
                String dept = resultset.getString("dept");
                Entity entity = new Entity(id, name, dept);
                entities.add(entity);
                System.out.println(entities);

            }
            return entities;
        } catch (Exception e) {
            e.printStackTrace();
            return null;
        } finally {
            // 释放资源
         resultset.close();
         preparedStatement.close();
         connection.close();
        }
    }
}

然后进行Service层:

package Service;

import Dao.Dao;
import entity.Entity;

import java.sql.SQLException;
import java.util.List;

public class Service {
  public   static Dao dao=new Dao();

    public  List<Entity> TaogetAll() throws SQLException {
        return dao.TaogetAll();
    }
}

然后进行Servlet层的书写

package Servlet;

import Service.Service;
import entity.Entity;
import jakarta.servlet.ServletException;
import jakarta.servlet.annotation.WebServlet;
import jakarta.servlet.http.HttpServlet;
import jakarta.servlet.http.HttpServletRequest;
import jakarta.servlet.http.HttpServletResponse;

import java.io.IOException;
import java.sql.SQLException;
import java.util.List;
@WebServlet("/tao")
public class Show extends HttpServlet {
    private Service Service = new Service();
    @Override
    protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
        List<Entity> Entitys= null;

        try {
            Entitys = Service.TaogetAll();
        } catch (SQLException e) {
            throw new RuntimeException(e);
        }
        req.setAttribute("people", Entitys);
        req.getRequestDispatcher("tao.jsp").forward(req,resp);
    }


    @Override
    protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
        List<Entity> Entitys= null;

        try {
            Entitys = Service.TaogetAll();
        } catch (SQLException e) {
            throw new RuntimeException(e);
        }
        req.setAttribute("people", Entitys);
        req.getRequestDispatcher("tao.jsp").forward(req,resp);
    }
}

然后进入重点tao.jsp界面

<%--
  Created by IntelliJ IDEA.
  User: qinhaidong
  Date: 2022/10/22
  Time: 12:27
  To change this template use File | Settings | File Templates.
--%>
<%@ taglib prefix="c" uri="http://java.sun.com/jstl/core_rt" %>
<%@ page isELIgnored="false"  %>
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<head>
    <title>展示界面</title>
</head>
<body>
<table>
    <tr>
        <th align="center">编号</th>
        <th align="center">姓名</th>
        <th align="center">系别</th>
    </tr>
    <c:forEach items="${people}" var="p">
        <tr>
            <th align="center">${p.id}</th>
            <th align="center">${p.name}</th>
            <th align="center">${p.dept}</th>
        </tr>
    </c:forEach>
</table>
</body>
</html>


注意看里面我们先写出使用c标签的指令<%@ taglib prefix=“c” uri=“http://java.sun.com/jstl/core_rt” %>,同时我们也要导入相应的 taglib 指令jar包。
在这里插入图片描述
然后我们在里面进行 <c:forEach items="${people}" var="p"> <tr> <th align="center">${p.id}</th> <th align="center">${p.name}</th> <th align="center">${p.dept}</th> </tr> </c:forEach>
这个的书写,记住item里面的 p e o p l e 是 S e r v l e t 里面的一定要进行对应:然后就可以进行这个声明 v a r = ′ p ′ 然后下面的东西就可以进行 e l 表达式获取数据库里面的属性 ‘ < t h a l i g n = " c e n t e r " > {people}是Servlet里面的一定要进行对应: 然后就可以进行这个声明var='p' 然后下面的东西就可以进行el表达式获取数据库里面的属性` <th align="center"> peopleServlet里面的一定要进行对应:然后就可以进行这个声明var=p然后下面的东西就可以进行el表达式获取数据库里面的属性<thalign="center">{p.id}
p . n a m e < / t h > < t h a l i g n = " c e n t e r " > {p.name}</th> <th align="center"> p.name</th><thalign="center">{p.dept}`
看获取成功图
在这里插入图片描述

       大家感觉怎摸样呢,el表达式是不是很简单啊!
       小伙伴们快去和ttc去试一试把!
EL表达式的简单介绍 一、JSP EL语言定义 E L(Expression Language) 目的:为了使JSP写起来更加简单。 表达式语言的灵感来自于 ECMAScript 和 XPath 表达式语言,它提供了在 JSP 中简化表达式的方法。它是一种简单的语言,基于可用的命名空间(PageContext 属性)、嵌套属性和对集合、操作符(算术型、关系型和逻辑型)的访问符、映射到 Java 类中静态方法的可扩展函数以及一组隐式对象。 EL 提供了在 JSP 脚本编制元素范围外使用运行时表达式的功能。脚本编制元素是指页面中能够用于在 JSP 文件中嵌入 Java 代码的元素。它们通常用于对象操作以及执行那些影响所生成内容的计算。JSP 2.0 将 EL 表达式添加为一种脚本编制元素。 二、JSP EL简介 1、语法结构 ${expression} 2、[ ]与.运算符 EL 提供“.“和“[ ]“两种运算符来存取数据。 当要存取的属性名称中包含一些特殊字符,如.或?等并非字母或数字的符号,就一定要使用“[ ]“。例如: ${user.My-Name}应当改为${user["My-Name"] } 如果要动态取值时,就可以用“[ ]“来做,而“.“无法做到动态取值。例如: ${sessionScope.user[data]}中data 是一个变量 3、变量 EL存取变量数据的方法很简单,例如:${username}。它的意思是取出某一范围中名称为username的变量。 因为我们并没有指定哪一个范围的username,所以它会依序从Page、Request、Session、Application范围查找。 假如途中找到username,就直接回传,不再继续找下去,但是假如全部的范围都没有找到时,就回传null。 属性范围在EL中的名称 Page PageScope Request RequestScope Session SessionScope Application ApplicationScope 二、JSP EL 中的有效表达式 有效表达式可以包含文字、操作符、变量(对象引用)和函数调用。我们将分别了解这些有效表达式中的每一种: 1、文字 JSP 表达式语言定义可在表达式中使用的以下文字: 文字 文字的值 Boolean true 和 false Integer 与 Java 类似。可以包含任何正数或负数,例如 24、-45、567 Floating Point 与 Java 类似。可以包含任何正的或负的浮点数,例如 -1.8E-45、4.567 String 任何由单引号或双引号限定的字符串。对于单引号、双引号和反斜杠,使用反斜杠字符作为转义序列。必须注意,如果在字符串两端使用双引号,则单引号不需要转义。 Null null 2、操作符 JSP 表达式语言提供以下操作符,其中大部分是 Java 中常用的操作符: 术语 定义 算术型 +、-(二元)、*、/、div、%、mod、-(一元) 逻辑型 and、&&、or、||、!、not 关系型 ==、eq、!=、ne、、gt、=、ge。可以与其他值进行比较,或与布尔型、字符串型、整型或浮点型文字进行比较。 空 空操作符是前缀操作,可用于确定值是否为空。 条件型 A ?B :C。根据 A 赋值的结果来赋值 B 或 C。 3、隐式对象 JSP 表达式语言定义了一组隐式对象,其中许多对象在 JSP scriplet 和表达式中可用: 术语 JSP 页的上下文。它可以用于访问 JSP 隐式对象,如请求、响应、会话、输出、servletContext 等。例如,${pageContext.response} 为页面的响应对象赋值。 此外,还提供几个隐式对象,允许对以下对象进行简易访问: 术语 定义 param 将请求参数名称映射到单个字符串参数值(通过调用 ServletRequest.getParameter (String name) 获得)。getParameter (String) 方法返回带有特定名称的参数。表达式 $(param.name) 相当于 request.getParameter (name)。 paramValues 将请求参数名称映射到一个数值数组(通过调用 ServletRequest.getParameter (String name) 获得)。它与 param 隐式对象非常类似,但它检索一个字符串数组而不是单个值。表达式 ${paramvalues.name) 相当于 request.getParamterValues(name)。 header 将请求头名称映射到单个字符串头值(通过调用 ServletRequest.getHeader(String name) 获得)。表达式 ${header.name} 相当于 request.getHeader(name)。 headerValues 将请求头名称映射到一个数值数组(通过调用 ServletRequest.getHeaders(String) 获得)。它与头隐式对象非常类似。表达式 ${headerValues.name} 相当于 request.getHeaderValues(name)。 cookie 将 cookie 名称映射到单个 cookie 对象。向服务器发出的客户端请求可以获得一个或多个 cookie。表达式 ${cookie.name.value} 返回带有特定名称的第一个 cookie 值。如果请求包含多个同名的 cookie,则应该使用 ${headerValues.name} 表达式。 initParam 将上下文初始化参数名称映射到单个值(通过调用 ServletContext.getInitparameter(String name) 获得)。 除了上述两种类型的隐式对象之外,还有些对象允许访问多种范围的变量,如 Web 上下文、会话、请求、页面: 术语 定义 pageScope 将页面范围的变量名称映射到其值。例如,EL 表达式可以使用 ${pageScope.objectName} 访问一个 JSP 中页面范围的对象,还可以使用 ${pageScope.objectName.attributeName} 访问对象的属性。 requestScope 将请求范围的变量名称映射到其值。该对象允许访问请求对象的属性。例如,EL 表达式可以使用 ${requestScope.objectName} 访问一个 JSP 请求范围的对象,还可以使用 ${requestScope.objectName.attributeName} 访问对象的属性。 sessionScope 将会话范围的变量名称映射到其值。该对象允许访问会话对象的属性。例如: $sessionScope.name} applicationScope 将应用程序范围的变量名称映射到其值。该隐式对象允许访问应用程序范围的对象。 三、特别强调: 1、注意当表达式根据名称引用这些对象之一时,返回的是相应的对象而不是相应的属性。例如:即使现有的 pageContext 属性包含某些其他值,${pageContext} 也返回 PageContext 对象。 2、 注意 表示是否禁用EL语言,TRUE表示禁止.FALSE表示不禁止.JSP2.0中默认的启用EL语言。 四、举例说明 1、例如, 等价于 ${ param.username } 2、例如,但是下面的那句EL语言可以完成如果得到一个username为空,则不显示null,而是不显示值。 userName: pwd: addr: 3、例如: 等价于$ { requestScope.userlist } 4、例如,原理如上例3。 ${ sessionScope.userlist } 1 ${ sessionScope.userlist } 2 ${ applicationScope.userlist } 3 ${ pageScope.userlist } 4 ${uselist} 含义:执行顺序为4 1 2 3。 “.”后面的只是一个字符串,并不是真正的内置对象,不能调用对象。 4、例如, 等价于 ${user.addr} 第一句前面的user,为一个变量。 第二句后面user,必须为在某一个范围里的属性。
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值