gpt4 book ai didi

java - 配置上下文查找以查找 Tomcat 8 上的 JNDI 资源环境

转载 作者:行者123 更新时间:2023-11-30 08:10:56 25 4
gpt4 key购买 nike

我有一个 servlet,它有一个类需要从 Tomcat 8 的全局 JNDI 资源中引用一个值。我在 Tomcat server.xml 文件中定义了资源:

<GlobalNamingResources>

<Environment name="MAX_LANDMARK_RESULT" value="100000" type="java.lang.Integer" override="false"/>

</GlobalNamingResources>

我在 webapp context.xml 中定义了一个资源链接:

<?xml version="1.0" encoding="UTF-8"?>
<Context antiJARLocking="true" path="/pathname">
<ResourceLink name="MAX_QUERY" global="MAX_LANDMARK_QUERY" type="java.lang.Integer"/>
</Context>

我还在 servlet web.xml 中定义了引用:

<resource-env-ref>
<resource-env-ref-name>MAX_LANDMARK_QUERY</resource-env-ref-name>
<resource-env-ref-type>java.lang.Integer</resource-env-ref-type>
</resource-env-ref>

我正尝试在我的 servlet 中引用它,如下所示:

try {
Context ct = new InitialContext();
Context ctx = (Context) ct.lookup("java:comp/env");
MAX_QUERY_SIZE = (Integer)ctx.lookup("MAX_QUERY");
} catch (NamingException ex) {
MAX_QUERY_SIZE = 99999;
}

我已经三重检查了我如何设置 XML 文件,它们应该是正确的,所以我确定问题出在我如何定义 ct.lookup("java:comp/env"); 行。我如何定义它以便它找到正确的资源而不是抛出 NamingException?

编辑:所以我一直在深入调试器并检查我的上下文,MAX_QUERY 显示为链接到 MAX_LANDMARK_QUERY 的继承资源链接。在拉取该资源链接时,我是否应该做一些特殊的事情,以便它在我的代码中引用 MAX_LANDMARK_QUERY?

最佳答案

对于遇到同样问题的其他人,我找到了解决方案。

<Environment>应该在 Tomcat context.xml 文件中定义。这是您必须为值做出的唯一定义。

在你的代码中,你应该这样调用它:

Context ctx = new InitialContext();
value = (valuetype) ctx.lookup("java:/comp/env/valueName");

关于java - 配置上下文查找以查找 Tomcat 8 上的 JNDI 资源环境,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31437564/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com