一尘不染

在Java Web应用程序(WAR)中存储配置文件的最佳位置是什么?

tomcat

我创建一个Web应用程序(WAR)并将其部署在Tomcat上。在 webapp中,
有一个带有表单的页面,管理员可以在其中输入一些配置数据。我不想将此数据存储在DBMS中,而只是存储在文件系统上的XML文件中。放在哪里?

我想将文件放在部署应用程序本身的目录树中的某个位置。我的配置文件应该在 WEB-INF 目录中吗?还是放在其他地方?

在servlet中使用Java代码查找目录的绝对路径是什么?还是可以通过相对路径访问它?


阅读 459

收藏
2020-06-16

共1个答案

一尘不染

我们要做的是将其放置在服务器上的单独目录中(您可以使用/ config,/ opt / config,/ root / config,/ home /
username /
config之类的东西,或任何您想要的东西)。当我们的servlet启动时,它们读取XML文件,从中获取一些东西(最重要的是数据库连接信息),仅此而已。

我问为什么我们要这样做一次。

将所有内容存储在数据库中会很好,但是显然您不能在数据库中存储数据库连接信息。

您可以对代码中的内容进行硬编码,但是由于许多原因,这很难看。如果必须更改信息,则必须重新构建代码并重新部署。如果有人获得了您的代码或WAR文件的副本,那么他们将获得该信息。

将内容放在WAR文件中看起来不错,但是如果您想进行很多更改,则可能不是一个好主意。问题是,如果您必须更改信息,那么下次重新部署它时,它将覆盖该文件,因此您忘记存储在WAR中的版本中所做的任何更改都将被忘记。

文件在文件系统上的特殊位置对我们来说效果很好。它没有太大的缺点。您知道它在哪里,它分开存储,如果它们都需要不同的配置值(因为它不是WAR的一部分),则使部署到多台计算机变得容易。

我能想到的唯一可行的解​​决方案是将除数据库登录信息以外的所有内容保留在数据库中。那将来自通过JVM检索的Java系统属性。这是Hans
Doggen上面提到的Preferences API。我不认为它是在第一次开发我们的应用程序时出现的,如果没有使用的话。

至于访问配置文件的路径,它只是文件系统上的一个文件。您无需担心网络路径。因此,当您的servlet启动时,只需在“
/config/myapp/config.xml”(或其他位置)中打开文件,它将找到正确的东西。硬编码该路径对于我来说似乎是无害的。

2020-06-16