配置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”);

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值