在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
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”);