博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
springboot jndi禁用
阅读量:6886 次
发布时间:2019-06-27

本文共 3038 字,大约阅读时间需要 10 分钟。

摘要:在实际项目开发中使用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则返回falseif (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使用。

你可能感兴趣的文章
SaltStack快速入门-配置管理
查看>>
批处理研究(QQ绿化和卸载)
查看>>
对比农行与建行网银业务办理流程
查看>>
Oracle 11G RAC 安装图示(一)
查看>>
【xpghost】xp系统启动后迟延问题如何解决
查看>>
浅谈ElasticSearch的嵌套存储模型
查看>>
离开外包又一段时间了
查看>>
aapt 解析android apk
查看>>
Layout Inflation不能这么用
查看>>
APNS远程推送证书的申请和制作——详细解析
查看>>
mongodb2.6.5--FAQ之分片(sharding)
查看>>
快速搭建Web环境 Angularjs + Express3 + Bootstrap3
查看>>
Android卫星菜单:android-satellite-menu
查看>>
Android 事件机制
查看>>
Sugarnms智和网管软件在煤矿监控系统中的应用
查看>>
Android Recyclerview 简单实用 瀑布流等方式,并加入上下拉加载
查看>>
Linux驱动开发学习日记
查看>>
Python3 中 random模块
查看>>
JS中数组的应用
查看>>
SpringCloud学习系列之二 ----- 服务消费者(Feign)和负载均衡(Ribbon)
查看>>