中国IT动力,最新最全的IT技术教程
最新100篇 | 推荐100篇 | 专题100篇 | 排行榜 | 搜索 | 在线API文档
首 页 | 程序开发 | 操作系统 | 软件应用 | 图形图象 | 网络应用 | 精文荟萃 | 教育认证 | 硬件维护 | 未整理篇 | 站长教程
ASP JS PHP工程 ASP.NET 网站建设 UML J2EESUN .NET VC VB VFP 网络维护 数据库 DB2 SQL2000 Oracle Mysql
服务器 Win2000 Office C DreamWeaver FireWorks Flash PhotoShop 上网宝典 CorelDraw 协议大全 网络安全 微软认证
硬件维护  CPU  主板  硬盘  内存  显卡  显示器  键盘鼠标  声卡音箱  打印机  机箱电源  BIOS  网卡  C#  Java  Delphi  vs.net2005
  当前位置:> 程序开发 > 编程语言 > Java > 综合文章
配置struts应用[4]---struts-config.xml的配置1
作者:未知 时间:2005-07-27 22:41 出处:CSDN 责编:chinaitpower
              摘要:配置struts应用[4]---struts-config.xml的配置1

Struts应用启动时,会把Struts配置文件中的配置信息读入到内存中,并把他们放到config包中相关javaBean类的实例中,org.apache.struts.config包中的每一个类都和Struts配置文件中特定的配置元素对应,例如,<action>元素和ActionMapping类对应,<forward>元素和ActionForward类对应。

<struts-config>元素

<struts-config>元素是Struts配置文件的根元素,和它对应的配置类为org.apche.struts.config.ModuleConfig类。<struts-config>元素有8个子元素,它的DTD定义如下:

<!ELEMENT struts-config(data-source?,form-beans?,global-exception?,global-forwards?,

action-mapping?,controller?,message-resources*,plug-in*)

>

定义Struts配置文件,必须按照上面DTD规定的顺序进行配置,否则将报错。

<data-sources>元素

<data-sources>元素用来配置应用所需要的数据源。

<data-sources>元素包含零个,一个或多个<data-source>子元素。<data-source>元素用于配置特定的数据源,它可以包括多个<set-property>子元素。<set-property>元素用于设置数据源的各种属性。例如:

<data-sources>

    <data-source type=”org.apche.commons.dbcp.BasicDataSource”>

        <set-property property=”autoCommit” value=”true”/>

        <set-property property=”description” value=”MySQL Data Source”/>

        <set-property property=”driverClass” value=”com.mysql.jdbc.Driver”/>

        <set-property property=”maxCount” value=”10”/>

        <set-property property=”minCount” value=”2”/>

<set-property property=”user” value=”root”/>

<set-property property=”password” value=””/>

<set-property property=”url” value=”jdbc:mysql://localhost:3306/addressbooksample”/>

    </data-source>

</data-sources>

下表包含几种比较流行的数据源:

名称

供应商

URL

Poolman

开放源代码软件

http://sourceforge.net/projects/poolman

Expresso

Jcorporate

http://www.jcorporate.com

JDBC Pool

开放源代码软件

http://www.bitmechanic.com/projects/jdbcpool

DBCP

Jakarta

http://jakarta.apache.org/commons/index.html

上面的实例使用的是DBCP数据源。

配置完数据源后,就可以在Action类中访问数据源,在org.apache.struts.action.Action类中定义了getDataSource(HttpRequest)方法,可以用于获取数据源对象的引用。示例如下:   

public ActionForward execute(ActionMapping mapping,

ActionForm form,

HttpServletRequest request,

HttpServletResponse response) throws Exception

{

    javax.sql.DataSource dataSource;//定义数据源对象

    java.sql.Connection myConnection;//定义联接对象

    try{

       dataSource=getDataSource(request);//从配置文件中读取数据源信息并进行配置

       myConnection=dataSource.getConnection();//建立一个数据源连接实例

        }

    catch(SQLException sqle){

        getServlet().log(“Connection.process”,sqle);

        }

    finally{

            try{

                myConnection.close();

                }

            catch(SQLException e){

                getServlet().log(“Connection.close”,e);

                }

}// end finally

}//end execute

在配置文件中声明多个数据源的方法:

可以通过为每一个数据源分配唯一的key值,通过该值来标识特定的数据源。例如:

<data-sources>

    <data-source key=”A” type=”org.apache.commons.dbcp.BasicDataSource”>

        <set-property property=”autoCommit” value=”true”/>

        <set-property property=”description” value=”MySQL Data Source”/>

        <set-property property=”driverClass” value=”com.mysql.jdbc.Driver”/>

        <set-property property=”maxCount” value=”10”/>

        <set-property property=”minCount” value=”2”/>

<set-property property=”user” value=”root”/>

<set-property property=”password” value=””/>

<set-property property=”url” value=”jdbc:mysql://localhost:3306/addressbooksample”/>

    </data-source>

    <data-source key=”B” type=”org.apache.commons.dbcp.BasicDataSource”>

    ……properties as before……

    </data-source>

</data-sources>

Action类中通过以下方式访问特定的数据源:

    dataSourceA=getDataSource(request,”A”);

    dataSourceB=getDataSource(request,”B”);


关闭本页
 
首页 | 投资与合作 | 服务条款 | 隐私政策 | 收藏本站 | 设为首页 | 新用户注册 | 免责声明 | 使用帮助
Copyright ©2005-2008 chinaitpower.com All rights reserved. www.chinaitpower.com 版权所有