• Tomcat 5 5 JNDI Resource 配置


    Tomcat 5.5 JNDI Resource 配置

    Author Blog:http://blog.csdn.net/fenglibing

    该文是对Tomcat 5.5 JNDI Resource配置的翻译,文章中主要提到对<resource-ref>的配置操作,有我做一些取舍,原文的地址为:

    http://tomcat.apache.org/tomcat-5.5-doc/jndi-resources-howto.html

    一、简介

    Tomcat 5 中,每个WEB应用程序的初使化环境(InitialContext)可以配置于$CATALINA_HOME/conf/server.xml<Context>节点中,也可以配置每个WEB应用程序环境(Context)于单独的XML文件中,如将每个WEB应用的配置放于$CATALINA_HOME/conf/Catalina/localhost目录下,名称可以为任意。

    Tomcat 5为整个服务维护一个独立的全局资源命名空间,它们被配置于$CATALINA_HOME/conf/server.xml<GlobalNameingResources>节点,你可以通过使用<ResourceLink>节点开放这些资源给WEB应用程序。

     

    这些定义的资源,可以被定义于你当前的WEB应用的WEB应用布署描述(/WEB-INF/web.xml)文件中的以下节点使用:

    l         <env-entry> :环境实体(Environment entry),一个单值参数(a single-value parameter)可以用于配置应用程序如何操作。

    l         <resource-ref>:资源引用(Resource reference),典型的应用为JDBC DataSourceJavaMail Session,或者配置于Tomcat5中的自定义对象工厂。

    l         <resource-env-ref>:资源环境引用(Resource environment reference),增加于Servlet 2.4中的resource-ref校验,这种可以简化资源配置,不需要授权信息。

     

    InitialContextWEB应用程序初使化的时候就被配置了,并且可以被WEB应用程序访问(只读的方式),所有配置的实体及资源,都放于JNDI命名空间的"java:comp/env"区。因此一个典型的资源访问,这里指对JDBC DataSource的访问,就像下面这样:

    //Obtain our environment naming context

    Context initCtx = new InitialContext();

    Context envCtx = (Context) initCtx.lookup("java:comp/env");

     

    //Look up our data source

    DataSource ds = (DataSource)

    envCtx.lookup("jdbc/EmployeeDB");

     

    //Allocate and use a connection from the pool

    Connection conn = ds.getConnection();

    ... use this connection to access the database ...

    conn.close();

     

     

    二、配置JNDI资源

    每个可访问的JNDI资源配置于<Context>节点的如下节点:

    l         <Environment> - scalar environment实体配置名称及值,这些实体通过JNDI InitialContext开发给WEB应用程序(与在WEB应用布署描述文件(/WEB-INF/web.xml)中增加<env-entry>节点配置相同)

    l         <Resource> - 配置应用于WEB应用程序的资源名称及数据类型(与在WEB应用布署描述文件(/WEB-INF/web.xml)中增加<resource-ref>节点配置相同)

    l         <ResourceLink> - 为定义于全局JNDI环境中的资源增加链接,这些资源链访问定义于<Server>节点下的<GlobalNamingResources>的资源。

    l         <Transaction> - 为在java:comp/UserTransaction中有效的初使化UserTransaction对象实例增加资源工厂。

     

    三、TOMCAT标准资源工厂

    Tomcat 5 包括一系列的标准资源工厂,它们可以为你的WEB应用程序提供服务,并且配置灵活(配置于$CATALINA_HOME/conf/server.xml),不需要修改WEB应用程序及布署描述。

           注意:在标准资源工厂中,只有"JDBC Data Source""User Transaction"工厂可以移植到其它非TOMCAT平台,其它的标准资源工厂,包括你编写的自定义资源工厂,都只可以在TOMCAT下运行,不可以移植到其它的平台。

    JDBC数据源

    1、安装JDBC驱动

    JDBC驱动放于目录$CATALINA_HOME/common/lib

    2、/WEB-INF/web.xml增加配置

     <resource-ref>

      <description>JDBC数据源配置实例</description>

      <res-ref-name>jdbc/TestDB</res-ref-name>

      <res-type>javax.sql.DataSource </res-type>

      <res-auth>Container</res-auth>

    </resource-ref>

    3、配置TOMCAT资源工厂

     <Context ...>

      ...

      <Resource name="jdbc/TestDB" auth="Container"

                type="javax.sql.DataSource"

                factory="org.apache.commons.dbcp.BasicDataSourceFactory"

                username="dbusername" password="dbpassword"

                driverClassName="net.sourceforge.jtds.jdbc.Driver"

                url="jdbc:jtds:sqlserver://testServer:1433/DB"

                maxActive="8" maxIdle="4"/>

      ...

    </Context>

    相关属性说明:

    name:JDBC数据源的名称。

    auth:

    type:当前配置资源的类别。

    factory:数据源工厂,默认为"org.apache.commons.dbcp.BasicDataSourceFactory"

    driverClassName - 驱动的全路径类名。

    maxActive - 当前数据源支持的最大并发数。

    maxIdle - 连接池中保留最大数目的闲置连接数。

    maxWait - 当连接池中无连接时的最大等待毫秒数,在等当前设置时间过后还无连接则抛出异常。

    username - 访问数据库的用户名

    password - 访问数据库的密码

    url - JDBC驱动的连接字符串

    validationQuery - 在返回应用之前,用于校验当前连接是否有效的SQL语句,如果指定了,当前查询语句至少要返回一条记录。

     

    4、实例JAVA程序

    Context initCtx = new InitialContext();

    Context envCtx = (Context) initCtx.lookup("java:comp/env");

    DataSource ds = (DataSource)

      envCtx.lookup("jdbc/TestDB");

     

    Connection conn = ds.getConnection();

    ... use this connection to access the database ...

    conn.close();

     

    JavaMail Session

    Tomcat 5 包括一个标准的、用于创建javax.mail.Session session实例的资源工厂,该工厂将会自动连接配置于server.xml中的SMTP服务器。在这种情况下,具体的应用完全不用去管email服务的配置环境,只需要在需要的时候,做简单的请求、获取预配置的session

    1、安装JAR

    点击这里下载JavaMailJAR包,JavaMail依赖于Java Activation Framework,因而也需要下载

    2、web.xml配置

    <resource-ref>

      <description>JavaMail配置</description>

      <res-ref-name>mail/Session</res-ref-name>

      <res-type>javax.mail.Session</res-type>

      <res-auth>Container</res-auth>

    </resource-ref>

    3、配置$CATALINA_HOME/conf/server.xml

    <Context ...>

      ...

      <Resource name="mail/Session" auth="Container"

                type="javax.mail.Session"

                mail.smtp.host="localhost"/>

      ...

    </Context>

    注:默认的邮件服务端口为25,如果不是,则需要修改mail.smtp.host属性为指定的主机,如mail.smtp.host="localhost:26"

    4、JAVA示例程序

    ......

    Context initCtx = new InitialContext();

    Context envCtx = (Context) initCtx.lookup("java:comp/env");

    Session session = (Session) envCtx.lookup("mail/Session");

     

    Message message = new MimeMessage(session);

    message.setFrom(new InternetAddress(request.getParameter("from"));

    InternetAddress to[] = new InternetAddress[1];

    to[0] = new InternetAddress(request.getParameter("to"));

    message.setRecipients(Message.RecipientType.TO, to);

    message.setSubject(request.getParameter("subject"));

    message.setContent(request.getParameter("content"), "text/plain");

    Transport.send(message);

    ......

     

    如果文章对你用,请支持万事如意网址导航

    再分享一下我老师大神的人工智能教程吧。零基础!通俗易懂!风趣幽默!还带黄段子!希望你也加入到我们人工智能的队伍中来!https://blog.csdn.net/jiangjunshow

  • 相关阅读:
    SQL SERVER 2008的元数据视图
    SQL Server 2008 中的 XML 功能
    SQL SERVER 2008的层次结构支持
    C#打包程序
    SQL SERVER 2008的top增强
    SQL SERVER导出数据字典
    SQL SERVER 2008的转置函数PIVOT
    SQL SERVER 2008的SQLCMD模式
    SQL SERVER 2008传递表值参数
    SQL Server 2005导出表中数据的SQL脚本形式(即INSERT语句)
  • 原文地址:https://www.cnblogs.com/skiwdhwhssh/p/10341874.html
Copyright © 2020-2023  润新知