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 文件夹本文是 Servlet 规范在运行时所需的文件夹示例。

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

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

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

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

一个示例:WEB-INF/classes 文件夹稍后将包含所有已编译的 Java 类和资源(src/main/javasrc/main/resources)需要由类加载器加载以启动应用程序。

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

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

相关文章:

java - 带有 spring 引导的 rabbitmq 中的异常

java - 在 Tomcat/Coyote 上更改反斜杠行为

java - 使用 Stripes/Tomcat 对流式 CSV 进行错误编码

java - 如何测试服务器端是否出现错误,并输出客户端

java - 创建可执行的 WAR 文件

java - 如何在Eclipse中使用Java显示模拟时间?

java - 重命名文件夹中的所有文件 Java

Javascript 跨域请求到 Glassfish 4 服务器?

java - 从 Tomcat 项目创建 java 安装程序 (war)

tomcat - 从网络共享按需将 war 文件部署到 Tomcat 中?