atitit.jndi的架构与原理以及资源配置and单元測试实践

1. jndi架构 1

2. jndi实现原理
3

3. jndi资源配置 3

3.1. resin  <database>  节点 3

3.2. tomcat    <resource 标签 4

3.3. 自己定义资源 5

4. JNDI測试支持: 5

4.1. D:\workspace\wxb\src\jndi4t.xml 6

4.2. applicationContext.xml 7

4.3. jdbc.properties 7

4.4. other----maybe help ful code 8

5. 參考 8

1. jndi架构

为什么会有jndi

jndi诞生的理由似乎非常easy。

随着分布式应用的发展,远程訪问对象訪问成为经常使用的方法。尽管说通过Socket等编程手段仍然可实现远程通信。但依照模式的理论来说,仍是有其局限性的。RMI技术。RMI-IIOP技术的产生。使远程对象的查找成为了技术焦点。JNDI技术就应运而生。JNDI技术产生后,就可方便的查找远程或是本地对象。

作者:: 老哇的爪子 Attilax 艾龙。  EMAIL:1466519819@qq.com

转载请注明来源: http://blog.csdn.net/attilax

1. try{

2.     Context initCtx = new javax.naming.InitialContext();

3.     Context envCtx = (Context)initCtx.lookup("java:comp/env");    //官方的example写法

4.     DataSource ds = (DataSource)envCtx.lookup("jdbc/YourDataBase"); // 或以下这样写:

5.     // DataSource ds = (DataSource)intCtx.lookup("java:comp/env/jdbc/YourDataBase");

6.     return ds.getConnection();

7. }catch(Exception e){

8.     throw e;

9. }

2. jndi实现原理

hgjg0k0n1m 10级  分类: JAVA语言  被浏览42次  2013.07.09

yingwang2011

採纳率:51% 10级 2013.07.09

jndi类似一个大map 将一些资源以key-value的形式放到jndi。 须要的时候再用key查询出来。 value,可能是一个字符串也可能是一个对象。

3. jndi资源配置

3.1. resin  <database>  节点

<database>

<jndi-name>jndi/wxb_site_new</jndi-name>

<driver type="com.mysql.jdbc.Driver">

<url><![CDATA[jdbc:mysql://localhost:3306/wxb_site_new?useUnicode=true&characterEncoding=utf-8]]></url>

<user>root</user>

<password>root</password>

</driver>

<prepared-statement-cache-size>8</prepared-statement-cache-size>

<max-connections>20</max-connections>

<max-idle-time>30s</max-idle-time>

</database>

<!--

<resource>

<max-connections>20</max-connections>

</resource>

-->

</resin>

3.2. tomcat    <resource 标签

resin  的resource 语法

<resource> syntax: (( (@jndi-name | <jndi-name>)?

& (@name | <name>)?

& (@var | <var>)?

& (@mbean-name | <mbean-name>)?

& (@mbean-interface | <mbean-interface>)?),

((@type | <type> | @class | <class>),

<arg>*)?,

(<init>*

& (@local-transaction-optimization | <local-transaction-opt

mization>)?

& <mbean-listener>*

& (@shareable | <shareable>)?))

3.3. 自己定义资源

tomcat默认提供的jndi配置支持对象有限,比較经常使用的有datasource,javabean等,

有时无法满足用户的需求 。

比方须要在构建对象的构造函数中传递參数等情况。

4. JNDI測试支持:

import org.springframework.mock.jndi.SimpleNamingContextBuilder;

D:\workspace\Book\WebRoot\WEB-INF\lib\org.springframework.test-3.1.0.RELEASE.jar

JNDI測试支持:在org.springframework.mock.jndi包下通过了SimpleNamingContextBuilder来来创建JNDI上下文Mock对象,从而无需依赖特定Java EE容器就可以完毕JNDI測试。

參考Junit+spring创建JNDI执行測试用例

public static void main(String[] args) throws IllegalStateException,

NamingException {

// System.setProperty("java.naming.factory.initial", "");

String p = pathx.classPath() + "/";

SpringUtil.locations = new String[] { p + "applicationContext.xml",

p + "jndi4t.xml" };

DataSource ds = (DataSource) SpringUtil.getBean("dataSource");

SimpleNamingContextBuilder builder = new SimpleNamingContextBuilder();

builder.bind("java:/comp/env/jndi/wxb_site_new", ds);

builder.activate();

UserInfoService userInfoService = (UserInfoService) SpringUtil

.getBean("userInfoService");

Dto pDto = new BaseDto();

pDto.put("user_id", "23946449");

UserInfo   userInfo = userInfoService.checkLogin(pDto);

System.out.println(userInfo);

}

有俩个dataSource一样了三ok这了,改成不一样走错蓝。。

4.1. D:\workspace\wxb\src\jndi4t.xml

<?xml version="1.0" encoding="UTF-8"?>

<beans:beans xmlns:beans="http://www.springframework.org/schema/beans"

xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:context="http://www.springframework.org/schema/context"

xmlns:aop="http://www.springframework.org/schema/aop" xmlns:tx="http://www.springframework.org/schema/tx"

xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-3.0.xsd

http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-3.0.xsd

http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-3.0.xsd

http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-3.0.xsd">

<beans:bean id="dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource">

<beans:property name="driverClassName" value="com.mysql.jdbc.Driver" />

<beans:property name="url" value="jdbc:mysql://localhost:3306/wxb_site_new?

useUnicode=true&characterEncoding=utf-8" />

<beans:property name="username" value="root" />

<beans:property name="password" value="root" />

</beans:bean>

</beans:beans>

4.2. applicationContext.xml

<!-- 定义受环境影响易变的变量 -->

<context:property-placeholder location="classpath:jdbc.properties"/>

<!-- 数据源配置,在生产环境使用应用server的数据库连接池 -->

<!--<jee:jndi-lookup id="dataSource" jndi-name="${ds}" ></jee:jndi-lookup> -->

<bean id="dataSource"

class="org.springframework.jndi.JndiObjectFactoryBean">

<property name="jndiName">

<!-- <value>java:comp/env/jdbc/my_center</value> -->

<value>${ds}</value>

</property>

</bean>

4.3.  jdbc.properties

# Properties file for JDBC configuration

#

# Place this file in the root CLASSPATH

#MySQL Connection Configuration

ct.jdbc.driverClassName=com.mysql.jdbc.Driver

ct.jdbc.url=jdbc:mysql://localhost:3306/wxb_site_new?useUnicode=true&characterEncoding=utf-8

ct.jdbc.username=root

ct.jdbc.password=

ds =java\:/comp/env/jndi/wxb_site_new

4.4. other----maybe help ful code

0

String url="localhost:8080";

这是在Weblogic中的写法:

      properties = new Properties();

      properties.put(Context.INITIAL_CONTEXT_FACTORY, "weblogic.jndi.WLInitialContextFactory");

      properties.put(Context.PROVIDER_URL, url);

      //用户是否为空

      if (user != null) {

        properties.put(Context.SECURITY_PRINCIPAL, user);

        properties.put(Context.SECURITY_CREDENTIALS, password == null ?

"" : password);

      }

      Context ctx= new InitialContext(properties);



      DataSource ds =(DataSource) ctx.lookup("java:comp/env/jdbc/OracleDB");

      Connection conn = ds.getConnection();



查找相关资料,把

 properties.put(Context.INITIAL_CONTEXT_FACTORY, "weblogic.jndi.WLInitialContextFactory");

换成相应的tomcat相应的上下文工厂,应该就能够了。

5. 參考

Resin中jndi资源配置 - howareyouo的专栏 - 博客频道 - CSDN.NET.htm

JNDI全攻略(一) - chinaifne - 博客园.htm

TOMCAT自己定义JNDI - 我的java 博客,嘿嘿 - ITeye技术站点.htm

各位谁知道如何在一个測试类的main()函数里訪问tomcat的JNDI数据源 -CSDN论坛-CSDN.NET-中国最大的IT技术社区.htm

高分请教Spring做单元測试的时候假设通过mock虚拟jndi数据源呢_IT知识问答_希赛网.htm

Junit+spring创建JNDI执行測试用例 - CSDN博客.htm

atitit.jndi的架构与原理以及资源配置and单元測试实践的更多相关文章

  1. atitit.jndi的架构与原理以及资源配置and单元测试实践

    atitit.jndi的架构与原理以及资源配置and单元测试实践 1. jndi架构 1 2. jndi实现原理 3 3. jndi资源配置 3 3.1. resin  <database> ...

  2. atitit.软件与sql设计模式原理与本质 大总结attialx总结v6 qc26.docx

    atitit.软件与sql设计模式原理与本质 大总结attialx总结v6 qc26.docx 1.1. 版本历史2 2. 设计模式是什么2 2.1. 模式就是在一种场合下对某个问题的一个解决方案.& ...

  3. Atitit 在线支付系统功能设计原理与解决方案 与目录

    Atitit 在线支付系统功能设计原理与解决方案 与目录 1.1. 支付系统1 1.2. 独立的支付子体系..微服务架构..1 1.3. 参考书籍1 支付战争 [The PayPal Wars:Bat ...

  4. Atitit.数据库存储引擎的原理与attilax 总结

    Atitit.数据库存储引擎的原理与attilax 总结 1. 存储引擎是什么1 2. 其它数据库系统(包括大多数商业选择)仅支持一种类型的数据存储2 3. 表的存储有三个文件:结构+数据+索引2 4 ...

  5. Atitit数据库层次架构表与知识点 attilax 总结

    Atitit数据库层次架构表与知识点 attilax 总结 第一阶段,大概理论(三五天 数据库的类型,网状,层次,树形数据库,kv数据库.Oodb Er模型   sql 并发控制与lock  Acid ...

  6. atitit.木马病毒webshell的原理and设计 java c# .net php.

    atitit.木马病毒webshell的原理and设计 java c# .net php. 1. 隐蔽性 编辑 WebShell后门具有隐蔽性,一般有隐藏在正常文件中并修改文件时间达到隐蔽的,还有利用 ...

  7. Atitit.数据库存储引擎的原理与attilax 总结

    Atitit.数据库存储引擎的原理与attilax 总结 1. 存储引擎是什么1 2. 其它数据库系统(包括大多数商业选择)仅支持一种类型的数据存储2 3. 表的存储有三个文件:结构+数据+索引2 4 ...

  8. Atitit 延迟绑定架构法attilax总结

    Atitit 延迟绑定架构法attilax总结 配置文件的延迟绑定1 Api属性与方法的回调延迟绑定1 后期绑定和前期绑定2 延迟调用2 用 Java 语言延迟绑定2 什么是推迟绑定 C++3 配置文 ...

  9. Atitit 图像处理 深刻理解梯度原理计算.v1 qc8

    Atitit 图像处理 深刻理解梯度原理计算.v1 qc8 1.1. 图像处理  梯度计算  基本梯度 内部梯度 外部梯度 方向梯度1 2. 图像梯度就是图像边缘吗?2 1.1. 图像处理  梯度计算 ...

随机推荐

  1. numeric and int in sql server

    类型映射 https://docs.microsoft.com/en-us/dotnet/framework/data/adonet/sql-server-data-type-mappings C#关 ...

  2. jni java与c++交互返回三维数组jobjectArray

    1.在java里创建一个类,在类里添加静态方法调用c++的类库dll,在java里创建要返回数组的函数.在java的main方法里创建返回后的测试方法. package cn.gov.cma.cnn. ...

  3. Windows下使用python绘制caffe中.prototxt网络结构数据可视化

    准备工具: 1. 已编译好的pycaffe 2. Anaconda(python2.7) 3. graphviz 4. pydot  1. graphviz安装 graphviz是贝尔实验室开发的一个 ...

  4. Session原理、安全以及最基本的Express和Redis实现

    Session原理.安全以及最基本的Express和Redis实现 https://segmentfault.com/a/1190000002630691

  5. 安卓开发--HttpDemo01

    package com.cnn.httpdemo01; import android.app.Activity; import android.content.Intent; import andro ...

  6. POJ 3013 Dijkstra

    从1节点最短路,,然后再乘一下权值就OK了 //By SiriusRen #include <queue> #include <cstdio> #include <cst ...

  7. 《剑指offer》二维数组中的查找

    一.题目描述 在一个二维数组中,每一行都按照从左到右递增的顺序排序,每一列都按照从上到下递增的顺序排序.请完成一个函数,输入这样的一个二维数组和一个整数,判断数组中是否含有该整数. 二.输入描述 ar ...

  8. ACM-ICPC 2017 Asia Urumqi(第八场)

    A. Coins Alice and Bob are playing a simple game. They line up a row of nnn identical coins, all wit ...

  9. RSA不对称加密

    package sinRsa; import java.io.ByteArrayOutputStream; import java.io.FileInputStream; import java.io ...

  10. PHP7内核剖析之执行流程

    以fpm为例: 1.fpm启动时,会先执行 module_startup, 并随着fpm进程常驻 2.当一个请求到达之后,会执行 request_startup, 进行一些请求初始化工作,然后执行代码 ...