关于weblogic对jndi的spi接口实现问题

    技术2022-05-11  63

    sun提供jndi规范,通过这个接口规范把名称和对象联系起来。但是怎么实现在于中间厂商对这个spi接口的实现。先看下面的代码:public static void main(String args[]){Properties properties = new Properties();properties.put(Context.INITIAL_CONTEXT_FACTORY,"weblogic.jndi.WLInitialContextFactory");properties.put(Context.PROVIDER_URL,"t3://server1:7001");properties.put(Context.SECURITY_PRINCIPAL,"username");properties.put(Context.SECURITY_CREDENTIALS,"password");Properties properties1 = new Properties();properties1.put(Context.INITIAL_CONTEXT_FACTORY,"weblogic.jndi.WLInitialContextFactory"); properties1.put(Context.PROVIDER_URL,"t3://server2:7001");// properties1.put(Context.SECURITY_PRINCIPAL,null);// properties1.put(Context.SECURITY_CREDENTIALS,null);try {System.out.println("新建context="+properties);Context context2= new InitialContext(properties1);Context context=new InitialContext(properties);context.close();System.out.println("新建context="+properties1); context2.lookup("cn/com/soosoo/test"); context2.close();

    } catch (NamingException e) { e.printStackTrace();}}

    大家可能目前还不知道这段代码有什么问题,运行应该也没有什么问题,很不幸的告诉你,运行的结果会出现一个security异常。大概描述是说在context2.lookup 的时候,weblogic的spi实现会拿context中设置的用户去连接context2中的服务器。很多人会想不通这一点,说实话我自己开始都不是很相信这事实。因为在context2之前把context还关了。为什么会出现这中情况。目前weblogic对jndi接口实现的时候,把上下文环境的用户存入一个堆栈。当利用上下文环境进行查找对象的时候,如果发现其没有用户名和密码,weblogic会在当前内存栈里面pop出来进行连接。这样当如果没有conetxt这个上下文环境的初始化设置的时候,就不会出现任何问题。解决这情况的有两个途径。1,所有的context都设置用户和密码,2,在进行context操作之前完成所有context2的获取工作。也就是 System.out.println("新建context="+properties);Context context2= new InitialContext(properties1); System.out.println("新建context="+properties1); context2.lookup("cn/com/soosoo/test"); context2.close();Context context=new InitialContext(properties);context.close();

    特别是在大家做j2ee应用集成时候需要注意这个问题,因为你可能会出现多个业务系统服务的调用。

     

    最新回复(0)