在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> 下表包含几种比较流行的数据源:
上面的实例使用的是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”); |
struts-config.xml的配置1
最新推荐文章于 2021-01-05 14:06:59 发布
struts-config.xml的配置1
2007-07-14 11:26