附三个struts 1 的开源项目
-------------------- ------------ -------------分析 Struts1+mysql 文章系统.rar
------------------struts-bean,struts-html,struts-logic
·struts-html标签库。这个库可以被用来生成动态HTML用户界面和窗体。
·struts-bean标签库。在将JavaBean代码放入JSP 页面时这个库提供实质性的加强的功能以改善其性能,它由标签提供。
·struts-logic标签库。这个库可管理有条件的文本生成,在对象集合中循环以重复生成输出文本和应用程序流程管理。
·struts-template标签库。在为具有相同的风格或格式生成动态JSP模板时,这个库所提供的标签会有很大的帮助。
---------------struts2 中 action 跟 actionsupport 的区别
都是通过execute函数执行
actionsupport这个工具类在实现了action接口的基础上还定义了一个validate()方法,重写该方法,它会在execute()方法之前执行,如校验失败
,统能将视图转入input处,必须在配置该Action时配置input属性。
另外,actionsupport还提供了一个getText(String key)方法还实现国际化,该方法从资源文件上获取国际化信息.
--------------------- java.util.Locale
1:java.util.Locale的主要用途是什么?
java.util.Locale主要在软件的本地化时使用。它本身没有什么功能,更多的是作为一个参数辅助其他方法完成输出的本地化。
2:java.util.Locale简单测试:
package one;
import java.util.Locale;
public class LocaleOne {
public static void main(String[] args) {
Locale myLocale = Locale.getDefault();
System.out.println(myLocale.getCountry());
System.out.println(myLocale.getLanguage());
System.out.println(myLocale.getDisplayCountry());
System.out.println(myLocale.getDisplayLanguage());
}
}
输出如下:
CN
zh
中国
中文
---------------------------------
action目录 extends Action
FormBeans 目录 表实体
FunctionBeans 目录 业务层【数据库】
Resources 资源 中英文
Utils 扩展层 其它类 连接数据库 上传 日期处理
------------------获取分类list
<jsp:useBean id="articleClasses" class="com.tiandinet.StrutsArticle.FunctionBeans.GetArticleClasses"/>
//列表方式一
<logic:iterate id="aClasses" name="articleClasses" property="coll">
<tr>
<td onMouseOver="this.bgColor='#FFFFFF'" onMouseOut="this.bgColor=''"> <html:link
page="/articleListAction.do" paramId="classId" paramName="aClasses" paramProperty="classId"><bean:write name="aClasses"
property="className" /></html:link></td>
</tr>
</logic:iterate>
//列表方式二
<logic:iterate id="aClasses" name="articleClasses" property="coll">
<tr bgcolor="#FFFFFF" onMouseOver="this.bgColor='#EEEEEE'" onMouseOut="this.bgColor='#FFFFFF'">
<td width="150"> <bean:write name="aClasses" property="className" /></td>
<td width="150"> <bean:write name="aClasses" property="classId" /></td>
<td width="100" align="center"><html:link page="/articleClassManageDeleteAction.do" paramId="classId"
paramName="aClasses" paramProperty="classId" οnclick="return confirmDelete()"><font color="#FF0000"><bean:message
key="SA.classManage.delete" /></font></html:link></td>
</tr>
</logic:iterate>
public GetArticleClasses()
{
try
{
Connection conn = DBConnection.getConnection();
if(conn != null)
{
Statement stmt = conn.createStatement();
ResultSet rs = stmt.executeQuery("SELECT * FROM
`com_tiandinet_jsp_struts_article_class` ORDER BY `id`");
while(rs.next())
{
ArticleClass ac = new ArticleClass();
ac.setId(rs.getInt("id"));
ac.setClassId(rs.getString("class"));
ac.setClassName(rs.getString("name"));
this.coll.add(ac);
}
rs.close();
conn.close();
}
else
{
this.coll = null;
}
}
catch(Exception e)
{
this.coll = null;
}
}
-------------------------添加分类 /articleClassManageAction.do?action=add
if(action == null || !action.equals("add"))
{
return mapping.findForward("showArticleClassManage");
}
else
{
ArticleClassForm acf = (ArticleClassForm)form;
ArticleClassManage acm = new ArticleClassManage();
MessageResources msg = this.getResources(request);
if(acm.addNewClass(acf))
{
request.setAttribute("message", msg.getMessage(local, "SA.classManage.success"));
}
else
{
request.setAttribute("message", msg.getMessage(local, "SA.classManage.fail"));
}
return mapping.findForward("showMessage");
}
ArticleClassManage.java
public boolean addNewClass(ArticleClassForm acf)
{
if(acf == null || acf.getClassName() == null || acf.getClassId() == null)
return false;
String query = "INSERT INTO `com_tiandinet_jsp_struts_article_class` (`class`,`name`) VALUES
(?,?)";
int ok = 0;
try
{
PreparedStatement ps = this.conn.prepareStatement(query);
ps.setString(1,acf.getClassId());
ps.setString(2,acf.getClassName());
ok = ps.executeUpdate();
}
catch(SQLException sqle)
{
ok = 0;
}
try
{
this.conn.close();
}
catch(SQLException sqle2)
{
}
if(ok == 1)
return true;
else
return false;
}
---------------------------------------------------------1 struts2 struts.xml
<struts>
<package name="example" namespace="/example" extends="struts-default">
<!-- 定义一个Action名称为HelloWorld,实现类为example.HelloWorld.java-->
<action name="HelloWorld" class="example.HelloWorld">
<!-- 任何情况下都转入到/example/HelloWorld.jsp -->
<result>/example/HelloWorld.jsp</result>
</action>
<action name="Login_*" method="{1}" class="example.Login">
<!-- 返回input时,转入到/example/login.jsp -->
<result name="input">/example/Login.jsp</result>
<!-- 重定向到Menu的Action -->
<result type="redirect-action">Menu</result>
</action>
<action name="*" class="example.ExampleSupport">
<result>/example/{1}.jsp</result>
</action>
</package>
</struts>
*<result name="input">/example/Login.jsp</result>
以上表示当execute方法返回input的字符串时,跳转到/example/Login.jsp。定义rusult元素时,可以指定两个属性:type和name。
其中name指定了execute方法返回的字符串,而type指定转向的资源类型,此处转向的资源可以是JSP,也可以是 FreeMarker等,甚至是另一个Action。
-----------------------------------------------------2struts1 struts-config.xml
Struts配置文件的<form-beans>元素用来配置所有的ActionForm Bean。<form-beans>元素可以包含多个<form-bean>子元素,它代表单个的ActionForm Bean。
同一个ActionForm可以和多个Action映射。在<action>元素中,name和scope属性分别指定ActionForm的名字和范围,validate属性指定是否执行表单验证。
<form-bean name="aritcleClassForm "
type="com.tiandinet.StrutsArticle.FormBeans.ArticleClassForm " />
<action name="aritcleClassForm " scope="request"
path="/articleClassManageAction"
type="com.tiandinet.StrutsArticle.Actions.ArticleClassManageAction ">
<forward name="showArticleClassManage"
path="/ShowArticleClassManage.jsp" />
</action>
#添加分类 /articleClassManageAction.do?action=add
<action scope="request" path="/articleClassManageDeleteAction"
type="com.tiandinet.StrutsArticle.Actions.ArticleClassManageDeleteAction">
<forward name="showArticleClassManage"
path="/ShowArticleClassManage.jsp" />
</action>
<form-bean name="serchForm "
type="org.apache.struts.action.DynaActionForm" dynamic="true">
<form-property name="key" initial=""
type="java.lang.String" />
</form-bean>
<action name="serchForm " scope="request" path="/searchAction"
type="com.tiandinet.StrutsArticle.Actions.SearchAction">
<forward name="showSearchResult"
path="/ShowSearchResult.jsp" />
<form-bean name="articleForm "
type="com.tiandinet.StrutsArticle.FormBeans.ArticleForm " />
<action name="articleForm " scope="request"
path="/articlePostAction"
type="com.tiandinet.StrutsArticle.Actions.ArticlePostAction ">
<forward name="showArticlePost" path="/ShowArticlePost.jsp" />
</action>
<form-bean name="articleIdForm "
type="org.apache.struts.action.DynaActionForm" dynamic="true">
<form-property name="id" initial="0"
type="java.lang.Integer" />
</form-bean>
<form-bean name="articleIdForm "
type="org.apache.struts.action.DynaActionForm" dynamic="true">
<form-property name="id" initial="0"
type="java.lang.Integer" />
</form-bean>
------------------------------------- struts-config.xml配置说明
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE struts-config PUBLIC
"-//Apache Software Foundation//DTD Struts Configuration 1.1//EN"
"http://jakarta.apache.org/struts/dtds/struts-config.dtd">
<!-- struts-config.xml中的元素必须按照上述doc指令中的dtd文档定义顺序书写,本例即遵从了dtd定义顺序 -->
<!-- struts-config是整个xml的根元素,其他元素必须被包含其内 -->
<struts-config>
<!--
名称:data-sources
描述:data-sources元素定义了web App所需要使用的数据源
数量:最多一个
子元素:data-source
-->
<data-sources>
<!--
名称:data-source
描述:data-source元素定义了具体的数据源
数量:任意多个
属性:
@key:当需要配置多个数据源时,相当于数据源的名称,用来数据源彼此间进行区别
@type:可以使用的数据源实现的类,一般来自如下四个库
Poolman,开放源代码软件
Expresso,Jcorporate
JDBC Pool,开放源代码软件
DBCP,Jakarta
-->
<data-source key="firstOne" type="org.apache.commons.dbcp.BasicDataSource">
<!--
名称:set-property
描述:用来设定数据源的属性
属性:
@autoCommit:是否自动提交 可选值:true/false
@description:数据源描述
@driverClass:数据源使用的类
@maxCount:最大数据源连接数
@minCount:最小数据源连接数
@user:数据库用户
@password:数据库密码
@url:数据库url
-->
<set-property property="autoCommit" value="true"/>
<set-property property="description" value="Hello!"/>
<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/helloAdmin"/>
</data-source>
</data-sources>
<!--
名称:form-beans
描述:用来配置多个ActionForm Bean
数量:最多一个
子元素:form-bean
-->
<form-beans>
<!--
名称:form-bean
描述:用来配置ActionForm Bean
数量:任意多个
子元素:form-property
属性:
@className:指定与form-bean元素相对应的配置类,一般默认使用org.apaceh.struts.config.FormBeanConfig,如果自定义,则必须继承 FormBeanConfig
@name:必备属性!为当前form-bean制定一个全局唯一的标识符,使得在整个Struts框架内,可以通过该标识符来引用这个ActionForm Bean。
@type:必备属性!指明实现当前ActionForm Bean的完整类名。
-->
<form-bean name="Hello" type="myPack.Hello">
<!--
名称:form-property
描述:用来设定ActionForm Bean的属性
数量:根据实际需求而定,例如,ActionForm Bean对应的一个登陆Form中有两个文本框,name和password,ActionForm Bean中也有这两个字段,则此处编写两个form-property来设定属性
属性:
@className:指定与form-property相对应的配置类,默认是org.apache.struts.config.FormPropertyConfig,如果自定义,则必须继承FormPropertyConfig类
@name:所要设定的ActionForm Bean的属性名称
@type:所要设定的ActionForm Bean的属性值的类
@initial:当前属性的初值
-->
<form-property name="name" type="java.lang.String"/>
<form-property name="number" type="java.lang.Iteger" initial="18"/>
</form-bean>
</form-beans>
<!--
名称:global-exceptions
描述:处理异常
数量:最多一个
子元素:exception
-->
<global-exceptions>
<!--
名称:exception
描述:具体定义一个异常及其处理
数量:任意多个
属性:
@className:指定对应exception的配置类,默认为org.apache.struts.config.ExceptionConfig
@handler:指定异常处理类,默认为org.apache.struts.action.ExceptionHandler
@key:指定在Resource Bundle种描述该异常的消息key
@path:指定当发生异常时,进行转发的路径
@scope:指定ActionMessage实例存放的范围,默认为request,另外一个可选值是session
@type:必须要有!指定所需要处理异常类的名字。
@bundle:指定资源绑定
-->
<exception
key=""hello.error
path="/error.jsp"
scope="session"
type="hello.HandleError"/>
</global-exceptions>
<!--
名称:global-forwards
描述:定义全局转发
数量:最多一个
子元素:forward
-->
<global-forwards>
<!--
名称:forward
描述:定义一个具体的转发
数量:任意多个
属性:
@className:指定和forward元素对应的配置类,默认为org.apache.struts.action.ActionForward
@contextRelative:如果为true,则指明使用当前上下文,路径以“/”开头,默认为false
@name:必须配有!指明转发路径的唯一标识符
@path:必须配有!指明转发或者重定向的URI。必须以"/"开头。具体配置要与contextRelative相应。
@redirect:为true时,执行重定向操作,否则执行请求转发。默认为false
-->
<forward name="A" path="/a.jsp"/>
<forward name="B" path="/hello/b.do"/>
</global-forwards>
<!--
名称:action-mappings
描述:定义action集合
数量:最多一个
子元素:action
-->
<action-mappings>
<!--
名称:action
描述:定义了从特定的请求路径到相应的Action类的映射
数量:任意多个
子元素:exception,forward(二者均为局部量)
属性:
@attribute:制定与当前Action相关联的ActionForm Bean在request和session范围内的名称(key)
@className:与Action元素对应的配置类。默认为org.apache.struts.action.ActionMapping
@forward:指名转发的URL路径
@include:指名包含的URL路径
@input:指名包含输入表单的URL路径,表单验证失败时,请求会被转发到该URL中
@name:指定和当前Acion关联的ActionForm Bean的名字。该名称必须在form-bean元素中定义过。
@path:指定访问Action的路径,以"/"开头,没有扩展名
@parameter:为当前的Action配置参数,可以在Action的execute()方法中,通过调用ActionMapping的getParameter()方法来获取参数
@roles:指定允许调用该Aciton的安全角色。多个角色之间用逗号分割。处理请求时,RequestProcessor会根据该配置项来决定用户是否有调用该Action的权限
@scope:指定ActionForm Bean的存在范围,可选值为request和session。默认为session
@type:指定Action类的完整类名
@unknown:值为true时,表示可以处理用户发出的所有无效的Action URL。默认为false
@validate:指定是否要先调用ActionForm Bean的validate()方法。默认为true
注意:如上属性中,forward/include/type三者相斥,即三者在同一Action配置中只能存在一个。
-->
<action path="/search"
type="addressbook.actions.SearchAction"
name="searchForm"
scope="request"
validate="true"
input="/search.jsp">
<forward name="success" path="/display.jsp"/>
</action>
</action-mappings>
<!--
名称:controller
描述:用于配置ActionServlet
数量:最多一个
属性:
@bufferSize:指定上传文件的输入缓冲的大小.默认为4096
@className:指定当前控制器的配置类.默认为org.apache.struts.config.ControllerConfig
@contentType:指定相应结果的内容类型和字符编码
@locale:指定是否把Locale对象保存到当前用户的session中,默认为false
@processorClass:指定负责处理请求的Java类的完整类名.默认org.apache.struts.action.RequestProcessor
@tempDir:指定文件上传时的临时工作目录.如果没有设置,将才用Servlet容器为web应用分配的临时工作目录.
@nochache:true时,在相应结果中加入特定的头参数:Pragma ,Cache-Control,Expires防止页面被存储在可数浏览器的缓存中,默认为false
-->
<controller
contentType="text/html;charset=UTF-8"
locale="true"
processorClass="CustomRequestProcessor">
</controller>
<!--
名称:message-resources
描述:配置Resource Bundle.
数量:任意多个
属性:
@className:指定和message-resources对应的配置类.默认为org.apache.struts.config.MessageResourcesConfig
@factory:指定资源的工厂类,默认为org.apache.struts.util.PropertyMessageResourcesFactory
@key:
@null:
@parameter:
-->
<message-resources
null="false"
parameter="defaultResource"/>
<message-resources
key="images"
null="false"
parameter="ImageResources"/>
<!--
名称:plug-in
描述:用于配置Struts的插件
数量:任意多个
子元素:set-property
属性:
@className:指定Struts插件类.此类必须实现org.apache.struts.action.PlugIn接口
-->
<plug-in
className="org.apache.struts.validator.ValidatorPlugIn">
<!--
名称:set-property
描述:配置插件的属性
数量:任意多个
属性:
@property:插件的属性名称
@value:该名称所配置的值
-->
<set-property
property="pathnames"
value="/WEB-INF/validator-rules.xml,/WEB-INF/vlaidation.xml"/>
</plug-in>
</struts-config>