我创建一个Web应用程序(WAR)并将其部署在Tomcat上。在 webapp中, 有一个带有表单的页面,管理员可以在其中输入一些配置数据。我不想将此数据存储在DBMS中,而只是存储在文件系统上的XML文件中。放在哪里?
我想将文件放在部署应用程序本身的目录树中的某个位置。我的配置文件应该在 WEB-INF 目录中吗?还是放在其他地方?
在servlet中使用Java代码查找目录的绝对路径是什么?还是可以通过相对路径访问它?
我们要做的是将其放置在服务器上的单独目录中(您可以使用/ 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”(或其他位置)中打开文件,它将找到正确的东西。硬编码该路径对于我来说似乎是无害的。