java - WEB-INF 在 Java EE Web 应用程序中的用途是什么?

标签 java servlets war java-ee-7 web-inf

我正在开发具有以下源代码目录结构的 Java EE Web 应用程序:

src/main/java                 <-- multiple packages containing Java classes
src/test/java                 <-- multiple packages containing JUnit tests
src/main/resources            <-- includes properties files for textual messages
src/main/webapp/resources     <-- includes CSS, images and all Javascript files
src/main/webapp/WEB-INF
src/main/webapp/WEB-INF/tags
src/main/webapp/WEB-INF/views

我感兴趣的文件夹是 WEB-INF:它包含 web.xml、用于设置 servlet 的 XML 文件、Spring bean 连接上下文和 JSP 标记以及意见。我试图了解是什么限制/定义了这个结构。例如。 JSP 文件总是必须在 WEB-INF 中还是可以在其他地方? WEB-INF 中还有其他内容吗?维基百科的WAR files条目提到用于 Java 类的 classes 和用于 JAR 文件的 lib - 不确定除了其他源文件位置之外,我是否已经完全掌握了何时需要这些。

最佳答案

Servlet 2.4 specification关于 WEB-INF 的说法(第 70 页):

A special directory exists within the application hierarchy named WEB-INF. This directory contains all things related to the application that aren’t in the document root of the application. The WEB-INF node is not part of the public document tree of the application. No file contained in the WEB-INF directory may be served directly to a client by the container. However, the contents of the WEB-INF directory are visible to servlet code using the getResource and getResourceAsStream method calls on the ServletContext, and may be exposed using the RequestDispatcher calls.

这意味着 WEB-INF 资源可由您的 Web 应用程序的资源加载器访问,而不是直接对公众可见。

这就是为什么许多项目将它们的资源(如 JSP 文件、JAR/库和它们自己的类文件或属性文件或任何其他敏感信息)放在 WEB-INF 文件夹中的原因。否则,可以使用简单的静态 URL 访问它们(例如,对于加载 CSS 或 Javascript 很有用)。

尽管从技术角度来看,您的 JSP 文件可以在任何地方。例如,在 Spring 中,您可以将它们显式配置为 WEB-INF:

<bean id="viewResolver" class="org.springframework.web.servlet.view.InternalResourceViewResolver"
    p:prefix="/WEB-INF/jsp/" 
    p:suffix=".jsp" >
</bean>

维基百科WAR files中提到的WEB-INF/classesWEB-INF/lib文件夹article 是运行时 Servlet 规范所需的文件夹示例。

区分项目的结构和生成的 WAR 文件的结构很重要。

项目的结构在某些情况下会部分反射(reflect) WAR 文件的结构(对于静态资源,例如 JSP 文件或 HTML 和 JavaScript 文件,但情况并非总是如此。

从项目结构到生成的 WAR 文件的转换是通过构建过程完成的。

虽然您通常可以自由设计自己的构建过程,但现在大多数人会使用标准化方法,例如 Apache Maven . Maven 为项目结构中的哪些资源映射到生成的工件中的哪些资源(在本例中生成的工件是 WAR 文件)定义了默认值。在某些情况下,映射由普通复制过程组成,在其他情况下,映射过程包括转换,例如过滤或编译等。

一个例子:WEB-INF/classes 文件夹稍后将包含所有已编译的 java 类和资源(src/main/javasrc/main/resources) 需要被Classloader加载才能启动应用。

另一个示例:WEB-INF/lib 文件夹稍后将包含应用程序所需的所有 jar 文件。在 maven 项目中,依赖项是为您管理的,maven 会自动将所需的 jar 文件复制到 WEB-INF/lib 文件夹中。这解释了为什么您在 maven 项目中没有 lib 文件夹。

关于java - WEB-INF 在 Java EE Web 应用程序中的用途是什么?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55831863/

相关文章:

java - 无法将 Gson JsonObject 转换为 POJO 类

java - 数组是按降序、升序还是无序排序?

java - 交互式 NLP 词性 (POS) 标记 - 强制某些术语成为特定标记

java - 如何访问tomcat session 上下文?

java - Jclouds无法创建实例

java - 如何使用 Commons 文件上传从选择字段中检索多个值?

servlets - 在 Vaadin 14 应用程序中将 `UI` 对象范围状态存储在哪里?

java - 从 JAVA 内部强制重新加载 JAVA WAR

java - Maven war 插件 - 包括 WAR 中的其他文件

java - 使用 jar 文件而不是类的 Tomcat 部署问题