Idea JSTL 500
Idea 提示 java.lang.NoClassDefFoundError: javax/servlet/jsp/tagext/TagLibraryValidator
环境配置
错误提示
java.lang.NoClassDefFoundError: javax/servlet/jsp/tagext/TagLibraryValidator
解决方案
这是由于tomcat10以上的的版本和无法使用以前的jstl的jar包的版,所以更换jstl的jar包即可
- 将jslt.jar和standard.jar 更换为 jakarta.servlet.jsp.jstl-2.0.0.jar 和 jakarta.servlet.jsp.jstl-api-2.0.0.jar
旧引入语句
<%@ taglib uri="http://java.sun.com/jstl/core" prefix="c" %>
该 URI 用于 JSTL 1.0,但您实际上使用的是 JSTL 1.2,它使用带有附加/jsp路径的 URI(因为发明 EL 表达式的 JSTL 自从 1.1 版集成为 JSP 2.0 的一部分(早在 2001 年发布!)为了在纯 JSP 中共享/重用 EL 逻辑
新引入语句
<%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>
在 Tomcat 10+ 上安装 JSTL
如果您已经在 Tomcat 10 或更高版本(第一个 Jakartified 版本,使用
jakarta.*
包而不是包),请通过此
唯一
依赖项
javax.*
使用 JSTL 2.0 :
<dependency>
<groupId>org.glassfish.web</groupId>
<artifactId>jakarta.servlet.jsp.jstl</artifactId>
<version>2.0.0</version>
</dependency>
非 Maven 用户可以通过将以下两个物理文件放入
/WEB-INF/lib
Web 应用程序项目的文件夹中来实现相同的目的(
绝对不要
将标准 *.jar 或任何松散的 .tld 文件放入其中!如有必要,请删除它们)。
- jakarta.servlet.jsp.jstl-2.0.0.jar (这是 EE4J 的 JSTL 2.0 impl)
- jakarta.servlet.jsp.jstl-api-2.0.0.jar (这是 JSTL 2.0 API)
在 Tomcat 9 上安装 JSTL-
如果您还没有使用 Tomcat 10,但仍使用 Tomcat 9 或更早版本,请通过此 唯一 依赖项使用 JSTL 1.2(这与 Tomcat 9 / 8 / 7 / 6 / 5 兼容,但不是更早版本):
<dependency>
<groupId>org.glassfish.web</groupId>
<artifactId>jakarta.servlet.jsp.jstl</artifactId>
<version>1.2.6</version>
</dependency>
非 Maven 用户可以通过将以下两个物理文件放入
/WEB-INF/lib
Web 应用程序项目的文件夹中来实现相同的目的(
绝对不要
将标准 *.jar 或任何松散的 .tld 文件放入其中!如有必要,请删除它们)。
- jakarta.servlet.jsp.jstl-1.2.6.jar (这是 EE4J 的 JSTL 1.2 impl)
- jakarta.servlet.jsp.jstl-api-1.2.7.jar (这是 JSTL 1.2 API)
在普通 JEE 服务器上安装 JSTL
如果您实际上使用的是普通的 Jakarta EE 服务器,例如 WildFly、Payara、TomEE、GlassFish、WebSphere、OpenLiberty、WebLogic 等,而不是准系统 servlet 容器,例如 Tomcat、Jetty、Undertow 等,那么您
不需要
完全显式安装 JSTL。普通的 Jakarta EE 服务器
已经
提供了开箱即用的 JSTL。换句话说,您不需要将 JSTL 添加到
pom.xml
或删除 webapp 中的任何 JAR/TLD 文件。仅
provided
范围内的 Jakarta EE 坐标就足够了:
<dependency>
<groupId>jakarta.platform</groupId>
<artifactId>jakarta.jakartaee-api</artifactId>
<version><!-- 9.1.0, 9.0.0, 8.0.0, etc depending on your server --></version>
<scope>provided</scope>
</dependency>
确保 web.xml 版本正确
此外,您还应该确保您的声明
至少
web.xml
符合Servlet 2.4,因此不是 Servlet 2.3 或更早版本。否则 JSTL 标记内的 EL 表达式将依次失效。选择与您的目标容器匹配的最高版本,并确保您的任何地方都没有,否则仍会触发 Servlet 2.3 模式。这是一个与 Servlet 5.0 (Tomcat 10) 兼容的示例:
<!DOCTYPE>web.xml
<?xml version="1.0" encoding="UTF-8"?>
<web-app
xmlns="https://jakarta.ee/xml/ns/jakartaee"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="https://jakarta.ee/xml/ns/jakartaee https://jakarta.ee/xml/ns/jakartaee/web-app_5_0.xsd"
version="5.0">
<!-- Config here. -->
</web-app>
这是一个与 Servlet 4.0 (Tomcat 9) 兼容的示例:
<?xml version="1.0" encoding="UTF-8"?>
<web-app
xmlns="http://xmlns.jcp.org/xml/ns/javaee"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"