springboot jndi禁用

本文介绍了解决高版本SpringBoot项目WAR包部署时遇到的JNDI名称未找到问题的方法。通过在项目的根目录下创建spring.properties文件并设置spring.jndi.ignore=true来禁用JNDI查询,从而避免错误的发生。

摘要:在实际项目开发中使用springboot的时候,可以使用jar包的方式运行项目,也可以将springboot项目打成war包使用。springboot war包运行可能会出现 [localhost-startStop-1] DEBUG org.springframework.jndi.JndiLocatorDelegate - Converted JNDI name [java:comp/env/LOGGING.pattern_level] not found - trying original name [LOGGING.pattern_level]. javax.naming.NameNotFoundException: Name [LOGGING.pattern_level] is not bound in this Context. Unable to find [LOGGING.pattern_level]

。反正就是诸如此类的问题吧。

上述的问题,在高版本的spring boot中会出现的,低版本不会出现这个问题。因为高版本中引入了JNDI查询的操作。

解决方案:

在项目的根目录中新建spring.properties配置文件,如下图所示:

    添加属性以及值,如下所示:

spring.jndi.ignore=true

原理

打开StandardServletEnvironment类,该类中的customizePropertySources方法如下:

public static final String JNDI_PROPERTY_SOURCE_NAME = "jndiProperties";
protected void customizePropertySources(MutablePropertySources propertySources) {
propertySources.addLast(new StubPropertySource(SERVLET_CONFIG_PROPERTY_SOURCE_NAME));
propertySources.addLast(new StubPropertySource(SERVLET_CONTEXT_PROPERTY_SOURCE_NAME));
if (JndiLocatorDelegate.isDefaultJndiEnvironmentAvailable()) {
propertySources.addLast(new JndiPropertySource(JNDI_PROPERTY_SOURCE_NAME));
}
    super.customizePropertySources(propertySources);
}
JndiLocatorDelegate.isDefaultJndiEnvironmentAvailable()代码如下:
public static final String IGNORE_JNDI_PROPERTY_NAME = "spring.jndi.ignore";
private static final boolean shouldIgnoreDefaultJndiEnvironment =
SpringProperties.getFlag(IGNORE_JNDI_PROPERTY_NAME);
public static boolean isDefaultJndiEnvironmentAvailable() {
//如果忽略jndi则返回false
if (shouldIgnoreDefaultJndiEnvironment) {
return false;
}
	try {
                  //准备jndi环境
        new InitialContext().getEnvironment();
        return true;
}
catch (Throwable ex) {
        return false;
}
}


通过上文可知:

1、如果我们需要忽略jndi则可以配置spring.jndi.ignore值为true即可。

2、在哪里配置呢?我们不妨跟进SpringProperties类中的getFlag方法。

spring.jndi.ignore获取原理

SpringProperties类的getFlag方法如下所示:

public static boolean getFlag(String key) {
    return Boolean.parseBoolean(getProperty(key));
}

继续跟进getProperty方法,如下所示:

public static String getProperty(String key) {
       //获取spring.jndi.ignore值
String value = localProperties.getProperty(key);
if (value == null) {
    try {//获取系统的变量
    value = System.getProperty(key);
    }
        catch (Throwable ex) {
    }
    }
    return value;
}

上述的方法可以总结如下:

从localProperties集合中获取spring.jndi.ignore属性,如果没有获取到则直接从环境变量中进行获取。localProperties集合在哪里初始化的呢?我们看一下SpringProperties类中的静态代码块,如下所示:

private static final String PROPERTIES_RESOURCE_LOCATION = "spring.properties";
static {
try {
    ClassLoader cl = SpringProperties.class.getClassLoader();
    URL url = (cl != null ? cl.getResource(PROPERTIES_RESOURCE_LOCATION) :ClassLoader.getSystemResource(PROPERTIES_RESOURCE_LOCATION));
    if (url != null) {
        logger.info("Found 'spring.properties' file in local classpath");
        InputStream is = url.openStream();
        try {
            localProperties.load(is);
        }
        finally {
            is.close();
            }
    }
    }
catch (IOException ex) {
}
}

看到上面的代码,我们明白了,原来这里是直接读取跟目录中的spring.properties文件中的所有属性。看到这里,焕然大悟。原来如此。

ok,本文暂时讲解到这里。后续我们讲解更多的jndi使用。

### Spring Boot与宝兰德中间件的适配方法 #### 配置Spring Boot项目以支持宝兰德中间件 为了使Spring Boot应用程序能够在宝兰德中间件上运行,需要完成以下几个方面的调整: 1. **导入必要的依赖项** 在`pom.xml`文件中引入宝兰德中间件所需的特定库。这些库通常用于处理JNDI、事务管理以及EJB集成等功能。以下是示例配置: ```xml <dependency> <groupId>com.bland</groupId> <artifactId>bland-jndi-support</artifactId> <version>1.0.0</version> </dependency> ``` 2. **修改Spring Boot启动类** 如果使用的是Spring Boot 2.x版本,则可以通过`spring.factories`机制加载自定义组件[^2];而在3.x及以上版本中,推荐通过`META-INF/spring/org.springframework.boot.autoconfigure.AutoConfiguration.imports`文件来实现相同功能。 3. **设置线程超时时间** 调整`sprin.lifecycle.timeout-per-shutdown-phase`参数以适应宝兰德中间件的需求。默认情况下,此值为30秒,但在某些复杂场景下可能需要更长时间[^3]。可以在`application.properties`或`application.yml`中进行如下配置: ```properties spring.lifecycle.timeout-per-shutdown-phase=60s ``` 4. **数据源配置** 宝兰德中间件提供了自己的连接池解决方案,因此可以禁用HikariCP或其他内置的数据源,并切换到由宝兰德托管的JNDI资源。例如,在`application.properties`中指定以下属性: ```properties spring.datasource.jndi-name=jdbc/MyDataSource spring.datasource.type=com.bland.jdbc.BlandDataSource ``` 5. **日志框架兼容性** 确保使用的日志记录器(如Logback或SLF4J)能够正常工作于宝兰德环境中。有时需额外添加桥接器以解决冲突问题。 #### 示例代码片段 下面展示了一个简单的Spring Boot应用如何与宝兰德中间件交互的例子: ```java import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Service; @Service public class BlandService { @Autowired private MyRepository myRepository; public void processData() { // 假设这里调用了某个持久化操作 myRepository.save(new Entity()); } } ``` ---
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值