java使用JNDI 获取weblogic配置的数据源 连接数据库
1、引入jars 在C:\Program Files1\bea\weblogic92\server\lib下面(我只选择weblogic.jar IDE给我加一堆)
代码中webdev是我配置的数据源
import java.sql.Connection; import java.util.Properties; import javax.naming.Context; import javax.naming.InitialContext; import javax.sql.DataSource; public class Test { public static void main(String args[]) { try { Properties pro = new Properties(); pro.setProperty(Context.PROVIDER_URL, "t3://localhost:7001"); pro.setProperty(Context.INITIAL_CONTEXT_FACTORY,"weblogic.jndi.T3InitialContextFactory"); Context ctx = new InitialContext(pro); DataSource ds = (DataSource) ctx.lookup("webdev"); Connection cn = ds.getConnection(); System.out.println(cn); } catch (Exception ex) { ex.printStackTrace(); } } }
如果程序运行在容器中了,就不用写下面的了。
Properties pro = new Properties() ; pro.setProperty(Context.PROVIDER_URL,"t3://localhost:7001") ; pro.setProperty(Context.INITIAL_CONTEXT_FACTORY,"weblogic.jndi.T3InitialContextFactory") ;
因为已经在上下文中了,直接
try { Context ctx = new InitialContext(); DataSource ds = (DataSource) ctx.lookup("webdev"); connection = ds.getConnection(); } catch (SQLException e) { e.printStackTrace(); } catch (NamingException e) { e.printStackTrace(); }
参考:
类比jboss中通过JNDI获得的EJB SessionBean的代码
try { Properties props = new Properties(); // 设置Jboss服务器的JNDI驱动的类名 props.setProperty(Context.INITIAL_CONTEXT_FACTORY,"org.jnp.interfaces.NamingContextFactory"); // 设置Jboss服务器提供命名服务的URL props.setProperty(Context.PROVIDER_URL, "localhost:1099"); InitialContext ctx = new InitialContext(props); // looking up SessionBean departmentDao = (DepartmentDao) ctx.lookup("DepartmentDaoBean/remote"); } catch (NamingException e) { e.printStackTrace(); } catch (Exception ex) { ex.printStackTrace(); }
同样,如果程序运行在jboss容器中,直接以下代码
Context ctx = new InitialContext();