我正在开发具有以下源代码目录结构的 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
文件夹article 是运行时 Servlet 规范所需的文件夹示例。
区分项目的结构和生成的 WAR 文件的结构很重要。
项目的结构在某些情况下会部分反射(reflect) WAR 文件的结构(对于静态资源,例如 JSP 文件或 HTML 和 JavaScript 文件,但情况并非总是如此。
从项目结构到生成的 WAR 文件的转换是通过构建过程完成的。
虽然您通常可以自由设计自己的构建过程,但现在大多数人会使用标准化方法,例如 Apache Maven . Maven 为项目结构中的哪些资源映射到生成的工件中的哪些资源(在本例中生成的工件是 WAR 文件)定义了默认值。在某些情况下,映射由普通复制过程组成,在其他情况下,映射过程包括转换,例如过滤或编译等。
一个例子:WEB-INF/classes
文件夹稍后将包含所有已编译的 java 类和资源(src/main/java
和src/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/