简述:

配置JNDI 查找Tomcat 中server.xml中定义的数据源

步骤:

1. 修改elipse的数据源server.xml

主要修改如下,

1. 添加下面这段Context文本 其中StudentManagementWeb是项目名称

  1. <Context docBase="StudentManagementWeb" path="/StudentManagementWeb" reloadable="true" source="org.eclipse.jst.jee.server:StudentManagementWeb">
  2. <Resource name="jdbc/smw" auth="Container" type="javax.sql.DataSource"
  3. maxActive="100" maxIdle="30" maxWait="10000"
  4. username="root" password="sql" driverClassName="com.mysql.jdbc.Driver"
  5. url="jdbc:mysql://localhost:3306/smw"/>
  6. </Context>

2.修改项目的web.xml文件

添加如下字段,用来查找数据源

  1. <resource-ref>
  2. <description>DB Connection</description>
  3. <res-ref-name>jdbc/smw</res-ref-name>
  4. <res-type>javax.sql.DataSource</res-type>
  5. <res-auth>Container</res-auth>
  6. </resource-ref>

3. 修改Hibernate配置文件,其中 mapping resourse 为自定义的model对象

  1. <session-factory>
  2. <property name="connection.datasource">java:comp/env/jdbc/smw</property>
  3. <property name="dialect">
  4. org.hibernate.dialect.MySQLDialect
  5. </property>
  6. <property name="show_sql">true</property><!-- show sql statement -->
  7. <!-- mapping files -->
  8. <mapping resource="smw/model/Student.hbm.xml"/>
  9. <mapping resource="smw/model/CourseSelection.hbm.xml"/>
  10. <mapping resource="smw/model/Course.hbm.xml"/>
  11. </session-factory>

4. Hibernate的session builder

  1. Configuration cfg = new Configuration().configure();
  2. factory = cfg.buildSessionFactory();   //build Session Factory

完成上述四步就做到了JNDI查找数据源的配置了

下面是四个文件的完整代码

server.xml

  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!--
  3. Licensed to the Apache Software Foundation (ASF) under one or more
  4. contributor license agreements.  See the NOTICE file distributed with
  5. this work for additional information regarding copyright ownership.
  6. The ASF licenses this file to You under the Apache License, Version 2.0
  7. (the "License"); you may not use this file except in compliance with
  8. the License.  You may obtain a copy of the License at
  9. http://www.apache.org/licenses/LICENSE-2.0
  10. Unless required by applicable law or agreed to in writing, software
  11. distributed under the License is distributed on an "AS IS" BASIS,
  12. WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  13. See the License for the specific language governing permissions and
  14. limitations under the License.
  15. --><!-- Note:  A "Server" is not itself a "Container", so you may not
  16. define subcomponents such as "Valves" at this level.
  17. Documentation at /docs/config/server.html
  18. --><Server port="8005" shutdown="SHUTDOWN">
  19. <!--APR library loader. Documentation at /docs/apr.html -->
  20. <Listener SSLEngine="on" className="org.apache.catalina.core.AprLifecycleListener"/>
  21. <!--Initialize Jasper prior to webapps are loaded. Documentation at /docs/jasper-howto.html -->
  22. <Listener className="org.apache.catalina.core.JasperListener"/>
  23. <!-- Prevent memory leaks due to use of particular java/javax APIs-->
  24. <Listener className="org.apache.catalina.core.JreMemoryLeakPreventionListener"/>
  25. <!-- JMX Support for the Tomcat server. Documentation at /docs/non-existent.html -->
  26. <Listener className="org.apache.catalina.mbeans.ServerLifecycleListener"/>
  27. <Listener className="org.apache.catalina.mbeans.GlobalResourcesLifecycleListener"/>
  28. <!-- Global JNDI resources
  29. Documentation at /docs/jndi-resources-howto.html
  30. -->
  31. <GlobalNamingResources>
  32. <!-- Editable user database that can also be used by
  33. UserDatabaseRealm to authenticate users
  34. -->
  35. <Resource auth="Container" description="User database that can be updated and saved" factory="org.apache.catalina.users.MemoryUserDatabaseFactory" name="UserDatabase" pathname="conf/tomcat-users.xml" type="org.apache.catalina.UserDatabase"/>
  36. </GlobalNamingResources>
  37. <!-- A "Service" is a collection of one or more "Connectors" that share
  38. a single "Container" Note:  A "Service" is not itself a "Container",
  39. so you may not define subcomponents such as "Valves" at this level.
  40. Documentation at /docs/config/service.html
  41. -->
  42. <Service name="Catalina">
  43. <!--The connectors can use a shared executor, you can define one or more named thread pools-->
  44. <!--
  45. <Executor name="tomcatThreadPool" namePrefix="catalina-exec-"
  46. maxThreads="150" minSpareThreads="4"/>
  47. -->
  48. <!-- A "Connector" represents an endpoint by which requests are received
  49. and responses are returned. Documentation at :
  50. Java HTTP Connector: /docs/config/http.html (blocking & non-blocking)
  51. Java AJP  Connector: /docs/config/ajp.html
  52. APR (HTTP/AJP) Connector: /docs/apr.html
  53. Define a non-SSL HTTP/1.1 Connector on port 8080
  54. -->
  55. <Connector connectionTimeout="20000" port="8080" protocol="HTTP/1.1" redirectPort="8443"/>
  56. <!-- A "Connector" using the shared thread pool-->
  57. <!--
  58. <Connector executor="tomcatThreadPool"
  59. port="8080" protocol="HTTP/1.1"
  60. connectionTimeout="20000"
  61. redirectPort="8443" />
  62. -->
  63. <!-- Define a SSL HTTP/1.1 Connector on port 8443
  64. This connector uses the JSSE configuration, when using APR, the
  65. connector should be using the OpenSSL style configuration
  66. described in the APR documentation -->
  67. <!--
  68. <Connector port="8443" protocol="HTTP/1.1" SSLEnabled="true"
  69. maxThreads="150" scheme="https" secure="true"
  70. clientAuth="false" sslProtocol="TLS" />
  71. -->
  72. <!-- Define an AJP 1.3 Connector on port 8009 -->
  73. <Connector port="8009" protocol="AJP/1.3" redirectPort="8443"/>
  74. <!-- An Engine represents the entry point (within Catalina) that processes
  75. every request.  The Engine implementation for Tomcat stand alone
  76. analyzes the HTTP headers included with the request, and passes them
  77. on to the appropriate Host (virtual host).
  78. Documentation at /docs/config/engine.html -->
  79. <!-- You should set jvmRoute to support load-balancing via AJP ie :
  80. <Engine name="Catalina" defaultHost="localhost" jvmRoute="jvm1">
  81. -->
  82. <Engine defaultHost="localhost" name="Catalina">
  83. <!--For clustering, please take a look at documentation at:
  84. /docs/cluster-howto.html  (simple how to)
  85. /docs/config/cluster.html (reference documentation) -->
  86. <!--
  87. <Cluster className="org.apache.catalina.ha.tcp.SimpleTcpCluster"/>
  88. -->
  89. <!-- The request dumper valve dumps useful debugging information about
  90. the request and response data received and sent by Tomcat.
  91. Documentation at: /docs/config/valve.html -->
  92. <!--
  93. <Valve className="org.apache.catalina.valves.RequestDumperValve"/>
  94. -->
  95. <!-- This Realm uses the UserDatabase configured in the global JNDI
  96. resources under the key "UserDatabase".  Any edits
  97. that are performed against this UserDatabase are immediately
  98. available for use by the Realm.  -->
  99. <Realm className="org.apache.catalina.realm.UserDatabaseRealm" resourceName="UserDatabase"/>
  100. <!-- Define the default virtual host
  101. Note: XML Schema validation will not work with Xerces 2.2.
  102. -->
  103. <Host appBase="webapps" autoDeploy="true" name="localhost" unpackWARs="true" xmlNamespaceAware="false" xmlValidation="false">
  104. <!-- SingleSignOn valve, share authentication between web applications
  105. Documentation at: /docs/config/valve.html -->
  106. <!--
  107. <Valve className="org.apache.catalina.authenticator.SingleSignOn" />
  108. -->
  109. <!-- Access log processes all example.
  110. Documentation at: /docs/config/valve.html -->
  111. <!--
  112. <Valve className="org.apache.catalina.valves.AccessLogValve" directory="logs"
  113. prefix="localhost_access_log." suffix=".txt" pattern="common" resolveHosts="false"/>
  114. -->
  115. <Context docBase="StudentManagementWeb" path="/StudentManagementWeb" reloadable="true" source="org.eclipse.jst.jee.server:StudentManagementWeb">
  116. <Resource name="jdbc/smw" auth="Container" type="javax.sql.DataSource"
  117. maxActive="100" maxIdle="30" maxWait="10000"
  118. username="root" password="sql" driverClassName="com.mysql.jdbc.Driver"
  119. url="jdbc:mysql://localhost:3306/smw"/>
  120. </Context>
  121. </Host>
  122. </Engine>
  123. </Service>
  124. </Server>

web.xml

  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://java.sun.com/xml/ns/javaee" xmlns:web="http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd" xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd" id="WebApp_ID" version="2.5">
  3. <display-name>StudentManagementWeb</display-name>
  4. <welcome-file-list>
  5. <welcome-file>Login.jsp</welcome-file>
  6. </welcome-file-list>
  7. <resource-ref>
  8. <description>DB Connection</description>
  9. <res-ref-name>jdbc/smw</res-ref-name>
  10. <res-type>javax.sql.DataSource</res-type>
  11. <res-auth>Container</res-auth>
  12. </resource-ref>
  13. <context-param>
  14. <param-name>log4jConfigLocation</param-name>
  15. <param-value>/WEB-INF/log4j.properties</param-value>
  16. </context-param>
  17. <!-- Define LOG4J Listener -->
  18. <listener>
  19. <listener-class>org.springframework.web.util.Log4jConfigListener</listener-class>
  20. </listener>
  21. <servlet>
  22. <!-- define the name of Servlet -->
  23. <servlet-name>dispatcherServlet</servlet-name>
  24. <!-- Servlet implementation class -->
  25. <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
  26. <!-- initialize the context -->
  27. <init-param>
  28. <param-name>contextConfigLocation</param-name>
  29. <!-- load configuration -->
  30. <param-value>/WEB-INF/applicationContext.xml</param-value>
  31. </init-param>
  32. <!-- set loading priority -->
  33. <load-on-startup>1</load-on-startup>
  34. </servlet>
  35. <servlet-mapping>
  36. <servlet-name>dispatcherServlet</servlet-name>
  37. <url-pattern>*.do</url-pattern>
  38. </servlet-mapping>
  39. </web-app>

hibernate.cfg.xml

  1. <?xml version='1.0' encoding='UTF-8'?>
  2. <!DOCTYPE hibernate-configuration PUBLIC
  3. "-//Hibernate/Hibernate Configuration DTD 3.0//EN"
  4. "http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd">
  5. <hibernate-configuration>
  6. <session-factory>
  7. <!--         <property name="dialect">Database Dialect
  8. org.hibernate.dialect.MySQLDialect
  9. </property>
  10. <property name="connection.url">URL of the database
  11. jdbc:mysql://localhost:3306/smw
  12. </property>
  13. <property name="connection.username">root</property>user name
  14. <property name="connection.password">sql</property>password
  15. <property name="connection.driver_class">connect driver
  16. com.mysql.jdbc.Driver
  17. </property> -->
  18. <property name="connection.datasource">java:comp/env/jdbc/smw</property>
  19. <property name="dialect">
  20. org.hibernate.dialect.MySQLDialect
  21. </property>
  22. <property name="show_sql">true</property><!-- show sql statement -->
  23. <!-- mapping files -->
  24. <mapping resource="smw/model/Student.hbm.xml"/>
  25. <mapping resource="smw/model/CourseSelection.hbm.xml"/>
  26. <mapping resource="smw/model/Course.hbm.xml"/>
  27. </session-factory>
  28. </hibernate-configuration>

HibernateUtil.java

    1. package smw.utils;
    2. import org.hibernate.Session;
    3. import org.hibernate.SessionFactory;
    4. import org.hibernate.cfg.Configuration;
    5. public class HibernateUtil {
    6. private static SessionFactory factory;
    7. static{
    8. try{
    9. Configuration cfg = new Configuration().configure();
    10. factory = cfg.buildSessionFactory();   //build Session Factory
    11. }catch(Exception e){
    12. System.out.println("static of HibernateUtil: " + e.getMessage());
    13. }
    14. }
    15. /**
    16. * @return SessionFactory
    17. */
    18. public static SessionFactory getSessionFactory(){
    19. return factory;
    20. }
    21. /**
    22. * get Session
    23. * @return Session
    24. */
    25. public static Session getSession(){
    26. return factory.openSession();
    27. }
    28. /**
    29. * close Session
    30. * @param session
    31. */
    32. public static void closeSession(Session session){
    33. if(session != null){
    34. if(session.isOpen()){
    35. session.close();
    36. }
    37. }
    38. }
    39. }

http://blog.csdn.net/anialy/article/details/8237448

Hibernate Tomcat JNDI数据源配置(转)的更多相关文章

  1. Linux - tomcat -jndi数据源配置

    Linux - tomcat -jndi数据源配置 tomcat/conf/context .xml 文件中修改如下 <Resource name="/jdbc/--" au ...

  2. Tomcat 6 部署工程总结,使用JNDI数据源配置

    工程需要用JNDI数据源方式部署到tomcat,参考网上文章后,经过配置测试,摸索出来了.     环境说明: 数据库:Oracle9i Web服务器:tomcat-6.0.33 tomcat启动方式 ...

  3. JNDI数据源配置

    一.数据源的由来 在Java开发中,使用JDBC操作数据库的四个步骤如下:   ①加载数据库驱动程序(Class.forName("数据库驱动类");) ②连接数据库(Connec ...

  4. mysql连接超时与jndi数据源配置

    昨天有运营说添加活动不能用了,我就看了一下后台日志,发现访问数据库是报错: at java.lang.Thread.run(Thread.java:722) Caused by: com.mysql. ...

  5. tomcat JNDI Resource 配置

    最近公司的项目慢慢开始向Maven项目迁移, 部分配置文件公共组也帮我们做了些改动,其中在spring的applicationContext.xml中看到了数据连接bean存在两个,一个是jndi 一 ...

  6. Tomcat JNDI + spring配置

    http://hi.baidu.com/lzpsky/item/f9a727ba823257eb4ec7fd27 一.简介 JNDI : Java Naming and Directory Inter ...

  7. Spring jndi数据源配置方法

    xml配置: <bean id="dataSource" class="org.springframework.jdbc.datasource.DriverMana ...

  8. tomcat jndi 数据源

    web.xml <!-- ================================================================================ --& ...

  9. tomcat下context.xml中JNDI数据源配置

    jndi(Java Naming and Directory Interface,Java命名和目录接口)是一组在Java应用中访问命名和目录服务的API.命名服务将名称和对象联系起来,使得我们可以用 ...

随机推荐

  1. 不是技术牛人,如何拿到国内IT巨头的Offer(转)

    不久前,byvoid面阿里星计划的面试结果截图泄漏,引起无数IT屌丝的羡慕敬仰.看看这些牛人,NOI金牌,开源社区名人,三年级开始写Basic…在跪拜之余我们不禁要想,和这些牛人比,作为绝大部分技术屌 ...

  2. 取CPU序列号,获取网卡,取硬盘系列号,获取目录下的文件,强制删除目录

    unit Unit1; interface uses Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms ...

  3. No architectures to compile for (ONLY_ACTIVE_ARCH=YES, active arch=arm64, VALID_ARCHS=armv7 armv7s)

    问题: No architectures to compile for (ONLY_ACTIVE_ARCH=YES, active arch=arm64, VALID_ARCHS=armv7 armv ...

  4. 设计模式之——Factory(工厂模式)

    工厂模式用于,通过统一的创建对象接口来创建对象,而子类可以决定对象的创建方式. class CObject { }; class CCar : public CObject { }; class CF ...

  5. Linux Shell脚本编程--curl命令详解

    用途说明 curl命令是一个功能强大的网络工具,它能够通过http.ftp等方式下载文件,也能够上传文件.其实curl远不止前面所说的那些功能,大家可以通过man curl阅读手册页获取更多的信息.类 ...

  6. 做SEO所要具备的四种能力

    1,不为失败找借口         既然我们选择了做SEO,那么发生网站被降权.被K是常常的事.当这样的情况发生时,大部分站长首先将责任推给百度机制,由于百度更新算法调整遭降权,不是由于他们的优化没有 ...

  7. postgresql优化数据的批量插入

    原文:http://www.cnblogs.com/mchina/archive/2012/08/11/2537393.html 有以下几种方法用于优化数据的批量插入. 1. 关闭自动提交:      ...

  8. Python 实现的下载op海贼王网的图片(网络爬虫)

    没得事就爬一下我喜欢的海贼王上的图片 须要在d盘下建立一个imgcache目录 # -*- coding: utf-8 -*- import urllib import urllib2 import ...

  9. swift 简单语句 控制流语句

    在 Swift 中.有两种类型的语句:简单语句和控制流语句.简单语句是最常见的.用于构造表达式和声明.控制流语句则用于控制程序运行的流程,Swift 中有三种类型的控制流语句:循环语句.分支语句和控制 ...

  10. Android 布局之LinearLayout 子控件weight权重的作用详析(转)

    关于Android开发中的LinearLayout子控件权重android:layout_weigh参数的作用,网上关于其用法有两种截然相反说法: 说法一:值越大,重要性越高,所占用的空间越大: 说法 ...