1)web.xml定义一些大的方向性的东西,如
<!-- Action Servlet Mapping -->
<servlet-mapping>
<servlet-name>actionServlet</servlet-name>
<url-pattern>*.do</url-pattern>
</servlet-mapping>
servlet-mapping标签代表了数据的作用形式。*.do代表了这个标签是关于所有*.do文件就处理的。如 <a href="regist.do">新用户注册</a> 这种指向的标签都会交给<action-mappings>标签处理。
2)struts-config.xml定义一些小的具体的调度关系:
2-1)、标签 //该标签处理了所有*.do 的动作
<action-mappings>
<action path="/login" type="classmate.LoginAction" name="formBean1" scope="request" input="/login.jsp" />
<action path="/regist" forward="/regist.jsp"/>
</action-mappings>
该标签定义了WEB.XML的细化:login.do对应LoginAction类来处理(会自动调用其execute函数,我们只需要重载该函数)。Regist.do由regist.jsp页面来处理。如此将*.do的所有处理做了细分。巧妙
在页面中可以通过<logic:redirect page="/logic-forward.do"/>或<a href="regist.do">新用户注册</a>等来调用这些action
2-2)、标签
<global-forwards>
<forward name="failed" path="/error.jsp"/>
<forward name="successed" path="/right.jsp"/>
</global-forwards>
该标签是为bean中调用页面跳跃的一些标签。比如跳到/right.jsp页面。调用
A)return mapping.findForward("successed"); // 宣布ActionMapping mapping。
B)在页面调用为:
<logic:redirect forward="welcome"/>
2-3)、如下的Bean调用比一般的JSP简单多了。声明标签
<form-beans>
<form-bean name="formBean1" type="classmate.UserForm"/>
</form-beans>
那么以后任何形式的<form action="***.do" method="post">其内部都可以在处理类中自动调用符合该标签下声明的bean元件来获取数据。
2、 Bean扩展标签:
1)<bean:define>对bean的整体性控制
n 定义一个新的bean<bean:define id="test1" value="this is a test"/>
n 用原来的bean定义一个新的bean<bean:define id="test2" name="test1"/>
n 用原来bean的某属性定义一个新的bean
<jsp:useBean id="bean1" scope="page" class="test.UserForm"/>
<jsp:setProperty name="bean1" property="psw" value="tiger"/>
<bean:define id="test3" name="bean1" property="psw"/>
<%=test3%><br>
n 定义BEAN的使用范围:
<bean:define id="bean2" name="bean1" scope="page" toScope="session"/>
2)<bean:include >对其他页面或action的调用
l page方式:(调用了action-mappingS标签)
<br>
<bean:include id="var1" page="/other.do" />
<%=var1%><br>
<%=var1%> <hr>
l forward方式:(调用了forward标签)
l
<br>
<bean:include id="var2" forward="test1" />
<%=var2%> <hr>
l href方式:<br>
测试信息来自不同的Application(或Server)
<bean:include id="var3" href="http://localhost:9000/S01_Begin/" />
<%=var3%>
3、 数据库连接:
在TOMCAT5上配置STRUTS数据源:
1:下载MySql的JDBC驱动
mysql-connector-java-3.0.16-ga-bin.jar (google一下)
2:创建MySql数据库名字:test
3:创建MySql数据库表:
CREATE TABLE `test` (
`username` varchar(20) NOT NULL default ''
) TYPE=MyISAM;
/*Data for the table `test` */
insert into `test` values ('rajesh'),('George'),('Vikas'),('Prakash'),('Mahesh');
4:在struts-config.xml的data-source中的元素应该是这样:
MYSQL:
<data-sources>
<data-source key="oracleDB1" type="com.mysql.jdbc.jdbc2.optional.MysqlDataSource">
<set-property property="url" value="jdbc:mysql://localhost/test" />
<set-property property="user"
value="root"/>
<set-property property="password"
value="111111"/>
<set-property property="autoCommit"
value="true"/>
</data-source>
</data-sources>
ORACLE:
<data-sources>
<data-source key="oracleDB1" type="org.apache.commons.dbcp.BasicDataSource">
<set-property property="driverClassName"
value="mysql.jdbc.driver.OracleDriver" />
<set-property property="url"
value="jdbc:mysql:thin:@127.0.0.1:1521:ZGYDB" />
<set-property property="maxActive"
value="5"/>
<set-property property="username"
value=""/>
<set-property property="password"
value=""/>
<set-property property="autoCommit"
value="true"/>
</data-source>
</data-sources>