我正在开发一个具有以下源代码目录结构的 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. TheWEB-INF
node is not part of the public document tree of the application. No file contained in theWEB-INF
directory may be served directly to a client by the container. However, the contents of theWEB-INF
directory are visible to servlet code using thegetResource
andgetResourceAsStream
method calls on theServletContext
, and may be exposed using theRequestDispatcher
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/classes
和 WEB-INF/lib
文件夹本文是 Servlet 规范在运行时所需的文件夹示例。
区分项目的结构和生成的 WAR 文件的结构非常重要。
项目的结构在某些情况下会部分反射(reflect) WAR 文件的结构(对于 JSP 文件或 HTML 和 JavaScript 文件等静态资源,但情况并非总是如此。
从项目结构到生成的 WAR 文件的转换是通过构建过程完成的。
虽然您通常可以自由地设计自己的构建过程,但现在大多数人会使用标准化方法,例如 Apache Maven 。除此之外,Maven 定义了项目结构中的哪些资源映射到结果工件中的哪些资源的默认值(在本例中,结果工件是 WAR 文件)。在某些情况下,映射由纯复制过程组成,在其他情况下,映射过程包括转换,例如过滤或编译等。
一个示例:WEB-INF/classes
文件夹稍后将包含所有已编译的 Java 类和资源(src/main/java
和src/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/