- 浏览: 22640 次
- 性别:
- 来自: 北京
最新评论
1、任何表现层框架都是用来帮我们实现MVC
model1(jsp) -- > model2 (jsp + servlet) -- > MVC
2. Struts1 怎样实现MVC?
2.1 核心控制器
2.1.1 核心控制器 ActionServlet
2.1.2 业务逻辑控制器 Action
2.2 提供了标签,简化V的编写
2.3 表现层框架对M没有支持
3. Struts1 有什么样的缺点? 对servlet的简单封装
3.1 支持的表现层技术单一。
3.2 与servlet api严重耦合 execute()
3.3 代码严重依赖于struts1 的API,属于侵入式设计
4. webwork:opensymphony-- > XWork AOP
5. 如何在项目中使用Struts2
5.1 jar (7 + 2)
5.2 log4j.properties
5.3 提供好配置文件 struts.xml src
5.4 web.xml
5.5 编写业务逻辑控制器
5.6 配置在struts.xml
6.Struts2和Struts1的主要区别:
6.1 设计理念不同,Struts1是对servlet的封装,而Struts2中体现的是AOP的思想
6.2 Struts2的Action非单例
7. 获得表单参数
7.1 属性驱动
7.2 模型驱动, 提供一个特定的JavaBean,用它来收集表单参数以及传递给下个页面的信息
7.2.1 让Action implements ModelDriven
7.2.2 自己创建模型的实例
7.2.3 getModel() 返回创建的模型的实例
7.2.4 结果页面访问信息:model.uname uname
7.3 扩展的属性驱动:本质上还是属性驱动, 属性不是简单属性,而是JavaBean
7.3.1 不需要自己实例化 private LogInfo info;
7.3.2 提供对应的get/set方法
7.3.3 提交页面<input name="info.email">
7.3.4 显示页面: ${info.uname }
8. 如何传递给下个页面信息
8.1 通过实例变量进行传递
8.2 通过Servlet API
9. 在页面如何访问Action传入的信息 , ActionContext <s:debug/>
9.1 Value Stack
9.1.1 el requestScope ${info} ${requestScope.info}
9.1.2 struts2的标签 <s:property />
9.2 Stack Context
9.2.1 el 是哪个就用哪个作用域
9.2.2 struts2的标签 <s:property value="#"/>
10. Configuration Files
10.1 web.xml(可以提供参数,但不会这么来做)
10.2 struts.xml
10.3 struts.properties -- > 用来覆盖defuault.properties(一般将其配置到 struts.xml中的constant里)
10.4 struts-default.xml (package : 4)
10.5 velocity.properties
10.6 struts-default.vm
11. Action
11.1 POJO
11.2 implements Action
11.3 extends ActionSupport(提供了校验国际化的方法,可以简化Action的编写) (*)
12. Package
12.1 解决命名冲突 & 便于管理
12.2 name给包起一个名字,在继承的时候用的上
12.3 extends 继承哪一个, 可以使自定义也可以说struts-default
12.4 namespace: 可以不指明,默认值是namespace="",被称为默认的查找空间
如果指明,必须以/开头,可以只是/,这种情况被称为根命名空间;
一旦为package指明了namespace,则namespace的值必须作为本报内Action访问路径的一部分
12.5 abstract:true表示内部没有配置action
13. 如何在一个Action中包含多个处理单元 public String ()
13.1 动态方法调用
### Set this to false if you wish to disable implicit dynamic method invocation
### via the URL request. This includes URLs like foo!bar.action, as well as params
### like method:bar (but not action:foo).
13.2 把一个物理上的Action映射为多个逻辑上的Action<action method="">
13.3 通配符
### An alternative to implicit dynamic method invocation is to use wildcard
### mappings, such as <action name="*/*" method="{2}" class="actions.{1}">
13.3.1 约定优先 Action method jsp
13.3.2 先找严格匹配的,没有严格匹配的,才考虑通配
13.3.3 只要是通配,按照从上到下的顺序,第一个可以通配成功的被使用
13.3.4 如果有<action name="*" >,必须放到最后面
13.3.5 <default-action-ref name="index" />在包内找不到特定的Action的时候,会使用,
如果通配成功,也认为找到了,default-action-ref无意义。
14. 访问Servlet API
14.1 拿到Map的Servlet API(不包括response)对象
14.1.1 依赖于特定API (*)
ActionContext.getContext().getSession()
(Map<String, Object>) ActionContext.getContext().get("request")) 基本用不上
ActionContext.getContext().getApplication()
14.1.2 依赖于注入(拦截器)
import org.apache.struts2.interceptor.ApplicationAware;
import org.apache.struts2.interceptor.RequestAware;
import org.apache.struts2.interceptor.SessionAware;
14.2 拿到真实类型的Servlet API -- > 最好用el
14.2.1 依赖于特定API (*)
ServletActionContext
14.2.2 依赖于注入(拦截器)
import org.apache.struts2.interceptor.ServletRequestAware;
import org.apache.struts2.interceptor.ServletResponseAware;
import org.apache.struts2.util.ServletContextAware;
15. OGNL: Object Graph Navigation Language 类似于el ,应用在Struts2的标签里面 <s:property value="ognl"/>
16. 简单的校验(——)
if(GenericValidator.isBlankOrNull(uname)||!uname.matches("\\w(4,10)")){
addFieldError("uname", "用户名的长度必须在4到10之间");
flag=true;
}
用户名:<input name="uname"/><s:property value="fieldErrors.uname[0]"/><br>
17. Result
17.1 范围: result(本Action使用) vs global-results(本包的所有Action使用) ,局部优先
17.2 类型: 用于指明当前转向什么样的资源
17.2.1 默认的类型
<result-type type="chain" class="com.opensymphony.xwork2.ActionChainResult"/> Action的链式调
用
<result-type type="dispatcher" class="org.apache.struts2.dispatcher.ServletDispatcherResult"
default="true"/>
<result-type type="redirect" class="org.apache.struts2.dispatcher.ServletRedirectResult"/>
<result-type type="redirectAction" class="org.apache.struts2.dispatcher.ServletActionRedirectResult"/>
两个Action之间如何传递信息:
chain:ActionContext.getContext().put("uid", id);
redirectAction:Session 或者 url :<result type="redirectAction">emailAction?uid=%{id}</result>(在
action中要写id的set及get方法)
17.2.2 可以扩展:<result-type name="chart"
class="org.apache.struts2.dispatcher.ChartResult">
17.2.3 跳转到其它包的Action
<result type="redirectAction">
<param name="actionName">HelloWorld</param>
<param name="namespace">/example</param>
</result>
17.3 定义自己的result-type
17.3.1 extends StrutsResultSupport
17.3.2 重写doExecute(String finalLocation, ActionInvocation invocation),配置的路径
18. 声明式异常处理 dao -- > service - > Action (统一异常处理) try { }catch() {}catch() {}
<exception-mapping result="result的name" exception="异常的类型"></exception-mapping>
18.1 异常是有继承关系: 先找精确的
18.2 既有局部(本Action使用)又有global-exception-mappings(本包所有Action共享)
先找精确,同等级别下,局部优先
18.3 global-exception-mappings最好转向到global-results
18.4 应该怎么去用: global-exception-mappings: <exception-mapping result="error"
exception="java.lang.Exception"></exception-mapping>
Action所特定关心的一些:往往和用户的输入相关, 局部
19. 19.1 ActionContext 19.2 拦截器的顺序问题
20. 编写自己的拦截器
20.1 extends AbstractInterceptor
20.2 implements Interceptor
20.3 配置 struts.xml <interceptors></interceptors>
21. 文件上传(如何给拦截器配置参数)
21.1 method="post" enctype="multipart/form-data"
21.2 Action private File repo;private String repoFileName;private String repoContentType;
21.3 struts.multipart.maxSize=20971520 一次请求最大的大小,如果不满足这个条件,错误信息来自于common-
fileupload
21.4 <!-- fileUpload必须放到前面 ,不放到前面无法转向到input-->
<interceptor-ref name="fileUpload">
<param name="maximumSize">2097152</param>
<param name="allowedExtensions">jpg,bmp</param>
</interceptor-ref>
<interceptor-ref name="defaultStack"></interceptor-ref>
22. token(如何使用额外的拦截器)
22.1提交页面<form><s:token></s:token></form>
22.2<interceptor-ref name="token"></interceptor-ref>
<interceptor-ref name="defaultStack"></interceptor-ref>
<result name="invalid.token">
23. 对现有拦截器进行修改
24. 标签
24.1 Generic Tags
24.1.1 Control Tags
24.1.2 Data Tags
24.2 UI Tags(主题 xhtml)-->界面元素怎样显示
24.2.1 Form Tags
24.2.2 Non-Form UI Tags
24.2.3 Ajax Tags(dojo)
type: object 默认理解为ognl 如果希望强制按照字符串理解‘’
String 默认理解为字符串, 如果希望强制按照ognl理解 %{ }
24.3 修改现有主题 src -- > template -- > simple -- > 哪个不适合,单独提供
24.4 定义新的主题 src -- > template ---> abc(主题的名字)通过 theme.properties指明继承simple
25. 校验: 在真正执行处理单元之前,对用户提交的信息进行基本校验,
如果满足业务要求,执行处理单元,否则转向到由input指向的页面。
25.1 客户端校验(防止用户的误操作) vs 服务器端校验(防止恶意攻击)
25.2 服务器端校验: 手工校验(validate validateXxx) 配置校验(xml-->描述业务规则)
25.3 手工校验: 在Action中重写 validate(不管处理哪个处理单元,都会执行), validateXxx
注:
validateExecute会在execute执行之前来执行
可以在validateExecute去编写业务规则
addFieldError--> 表达error的Map去添加信息
当该方法执行结束以后,如果map不为空,说明有校验错误,不再执行execute
转向到由input指向的页面
任何一个处理单元在执行之前都会调用validate,先判断有无validateXxx方法,有就调用
不管有没有问题出现,都会检查有没有validate,有则执行,当validate执行完后,检查Map
25.4 配置校验: 提供xml-->描述校验规则(1、字段优先 2、规则优先)
ActionClassName-validation.xml < -- > validate
ActionClassName-ActionName-validation.xml <--- > validateXxx(注:此处的ActionName必须要
是.xml配置文件中的action的name)
<validator name="required" class="com.opensymphony.xwork2.validator.validators.RequiredFieldValidator"/>
<validator name="requiredstring"
class="com.opensymphony.xwork2.validator.validators.RequiredStringValidator"/>
<validator name="int" class="com.opensymphony.xwork2.validator.validators.IntRangeFieldValidator"/>
<validator name="long" class="com.opensymphony.xwork2.validator.validators.LongRangeFieldValidator"/>
<validator name="short" class="com.opensymphony.xwork2.validator.validators.ShortRangeFieldValidator"/>
<validator name="double"
class="com.opensymphony.xwork2.validator.validators.DoubleRangeFieldValidator"/>
<validator name="date" class="com.opensymphony.xwork2.validator.validators.DateRangeFieldValidator"/>
<validator name="expression" class="com.opensymphony.xwork2.validator.validators.ExpressionValidator"/>
<validator name="fieldexpression"
class="com.opensymphony.xwork2.validator.validators.FieldExpressionValidator"/>
<validator name="email" class="com.opensymphony.xwork2.validator.validators.EmailValidator"/>
<validator name="url" class="com.opensymphony.xwork2.validator.validators.URLValidator"/>
<validator name="visitor" class="com.opensymphony.xwork2.validator.validators.VisitorFieldValidator"/>
<validator name="conversion"
class="com.opensymphony.xwork2.validator.validators.ConversionErrorFieldValidator"/>
<validator name="stringlength"
class="com.opensymphony.xwork2.validator.validators.StringLengthFieldValidator"/>
<validator name="regex" class="com.opensymphony.xwork2.validator.validators.RegexFieldValidator"/>
<validator name="conditionalvisitor"
class="com.opensymphony.xwork2.validator.validators.ConditionalVisitorFieldValidator"/>
26. 国际化
26.1 资源文件的命名 baseName_语言_国家.properties baseName.properties
26.2 ResourceBundle bundle = ResourceBundle.getBundle("msg", Locale.US);
String message = bundle.getString("key1");
System.out.println(MessageFormat.format(message, "小张"));
26.3 Jsp: <s:property value="%{getText("")}"/> ,但不建议使用;
<s:i18n name="com/pk/conf/user"><s:text/></s:i18n>(在页面中直接申明使用的配置文件)
26.4 Action: getText("key") 使用的资源文件最好是Action级别的或者是package级别
26.5 资源文件有级别
26.5.1 全局资源文件 <constant name="struts.custom.i18n.resources"
value="msg"></constant>
26.5.2 package级别: baseName必须是package,可以被本包及子包所有Action所共享
26.5.3 Action级别:baseName必须和类名一致,同时放在同一个目录下,可以被本Action及子类使用
26.5.4 查找顺序:Action级别 -- 》 package级别 --》 全局资源文件
27. 类型转换
XWork will automatically handle the most common type conversion for you. This includes support for converting
to and from Strings for each of the following:
String
boolean / Boolean
char / Character
int / Integer, float / Float, long / Long, double / Double
dates - uses the SHORT format for the Locale associated with the current request
arrays - assuming the individual strings can be coverted to the individual items
collections - if not object type can be determined, it is assumed to be a String and a new ArrayList is created
在默认的拦截器栈中包含了名为conversionError的拦截器,
如果出现了类型转换错误,该拦截器负责封装fieldError,
并转向到名为input的逻辑视图。
默认情况下,错误的提示信息为:Invalid field value for field "{0}"
如需要改提示信息有如下两种方式:
1、在全局资源文件中提供如下内容xwork.default.invalid.fieldvalue=提示信息
2、在Action作用域,包作用域以及全局资源文件中invalid.fieldvalue.域的名字=提示信息
编写自定义类型转换器有三种方式:建议继承StrutsTypeConverter
编写完自定义类型转换器后,我们需要通过配置告诉Struts2,有两种注册方式:
1、配置全局转换器配置文件:在src下面写一个xwork-conversion.properties的配置文件,其中配置类名和转换
器名
“待转换的类型的全名(包括包路径和类名)=转换器类的全名”对
如:com.pk.vo.Point---com.pk.web.converter.MyConverter
2、应用于某个特定类的类型转换器,做法为在该类的包中添加一个格式为:
“类名-conversion.properties”的配置文件,并在文件中加入
“待转换属性的名字=转换器类的全名”对
28. 和spring的整合(两种整合方式)
28.1 Autowiring: Action是struts2自己管理
默认按照name进行自动装配: struts.objectFactory.spring.autoWire = name
28.1.1 注解 Action: 不用加Controller
28.2 Initializing Actions from Spring: Action交给spring管理
28.2.1 在spring配置Action: scope="prototype"(使配置的bean不是单例的)
28.2.2 修改struts.xml <action class="对应的bean的id">
//由spring管理时可配置注解
28.2.3 注解 Action : @Controller @Scope("prototype")
service: @Service
28.3 When an object is to be created, it uses the class attribute in the Struts
configuration to correspond to the id attribute in the Spring configuration.
If not found, the class will try to be created as usual, then be autowired by Spring.
By default, the framework will at least try to use Spring to create all its objects.
If the object cannot be created by Spring,
then the framework will create the object itself.
model1(jsp) -- > model2 (jsp + servlet) -- > MVC
2. Struts1 怎样实现MVC?
2.1 核心控制器
2.1.1 核心控制器 ActionServlet
2.1.2 业务逻辑控制器 Action
2.2 提供了标签,简化V的编写
2.3 表现层框架对M没有支持
3. Struts1 有什么样的缺点? 对servlet的简单封装
3.1 支持的表现层技术单一。
3.2 与servlet api严重耦合 execute()
3.3 代码严重依赖于struts1 的API,属于侵入式设计
4. webwork:opensymphony-- > XWork AOP
5. 如何在项目中使用Struts2
5.1 jar (7 + 2)
5.2 log4j.properties
5.3 提供好配置文件 struts.xml src
5.4 web.xml
5.5 编写业务逻辑控制器
5.6 配置在struts.xml
6.Struts2和Struts1的主要区别:
6.1 设计理念不同,Struts1是对servlet的封装,而Struts2中体现的是AOP的思想
6.2 Struts2的Action非单例
7. 获得表单参数
7.1 属性驱动
7.2 模型驱动, 提供一个特定的JavaBean,用它来收集表单参数以及传递给下个页面的信息
7.2.1 让Action implements ModelDriven
7.2.2 自己创建模型的实例
7.2.3 getModel() 返回创建的模型的实例
7.2.4 结果页面访问信息:model.uname uname
7.3 扩展的属性驱动:本质上还是属性驱动, 属性不是简单属性,而是JavaBean
7.3.1 不需要自己实例化 private LogInfo info;
7.3.2 提供对应的get/set方法
7.3.3 提交页面<input name="info.email">
7.3.4 显示页面: ${info.uname }
8. 如何传递给下个页面信息
8.1 通过实例变量进行传递
8.2 通过Servlet API
9. 在页面如何访问Action传入的信息 , ActionContext <s:debug/>
9.1 Value Stack
9.1.1 el requestScope ${info} ${requestScope.info}
9.1.2 struts2的标签 <s:property />
9.2 Stack Context
9.2.1 el 是哪个就用哪个作用域
9.2.2 struts2的标签 <s:property value="#"/>
10. Configuration Files
10.1 web.xml(可以提供参数,但不会这么来做)
10.2 struts.xml
10.3 struts.properties -- > 用来覆盖defuault.properties(一般将其配置到 struts.xml中的constant里)
10.4 struts-default.xml (package : 4)
10.5 velocity.properties
10.6 struts-default.vm
11. Action
11.1 POJO
11.2 implements Action
11.3 extends ActionSupport(提供了校验国际化的方法,可以简化Action的编写) (*)
12. Package
12.1 解决命名冲突 & 便于管理
12.2 name给包起一个名字,在继承的时候用的上
12.3 extends 继承哪一个, 可以使自定义也可以说struts-default
12.4 namespace: 可以不指明,默认值是namespace="",被称为默认的查找空间
如果指明,必须以/开头,可以只是/,这种情况被称为根命名空间;
一旦为package指明了namespace,则namespace的值必须作为本报内Action访问路径的一部分
12.5 abstract:true表示内部没有配置action
13. 如何在一个Action中包含多个处理单元 public String ()
13.1 动态方法调用
### Set this to false if you wish to disable implicit dynamic method invocation
### via the URL request. This includes URLs like foo!bar.action, as well as params
### like method:bar (but not action:foo).
13.2 把一个物理上的Action映射为多个逻辑上的Action<action method="">
13.3 通配符
### An alternative to implicit dynamic method invocation is to use wildcard
### mappings, such as <action name="*/*" method="{2}" class="actions.{1}">
13.3.1 约定优先 Action method jsp
13.3.2 先找严格匹配的,没有严格匹配的,才考虑通配
13.3.3 只要是通配,按照从上到下的顺序,第一个可以通配成功的被使用
13.3.4 如果有<action name="*" >,必须放到最后面
13.3.5 <default-action-ref name="index" />在包内找不到特定的Action的时候,会使用,
如果通配成功,也认为找到了,default-action-ref无意义。
14. 访问Servlet API
14.1 拿到Map的Servlet API(不包括response)对象
14.1.1 依赖于特定API (*)
ActionContext.getContext().getSession()
(Map<String, Object>) ActionContext.getContext().get("request")) 基本用不上
ActionContext.getContext().getApplication()
14.1.2 依赖于注入(拦截器)
import org.apache.struts2.interceptor.ApplicationAware;
import org.apache.struts2.interceptor.RequestAware;
import org.apache.struts2.interceptor.SessionAware;
14.2 拿到真实类型的Servlet API -- > 最好用el
14.2.1 依赖于特定API (*)
ServletActionContext
14.2.2 依赖于注入(拦截器)
import org.apache.struts2.interceptor.ServletRequestAware;
import org.apache.struts2.interceptor.ServletResponseAware;
import org.apache.struts2.util.ServletContextAware;
15. OGNL: Object Graph Navigation Language 类似于el ,应用在Struts2的标签里面 <s:property value="ognl"/>
16. 简单的校验(——)
if(GenericValidator.isBlankOrNull(uname)||!uname.matches("\\w(4,10)")){
addFieldError("uname", "用户名的长度必须在4到10之间");
flag=true;
}
用户名:<input name="uname"/><s:property value="fieldErrors.uname[0]"/><br>
17. Result
17.1 范围: result(本Action使用) vs global-results(本包的所有Action使用) ,局部优先
17.2 类型: 用于指明当前转向什么样的资源
17.2.1 默认的类型
<result-type type="chain" class="com.opensymphony.xwork2.ActionChainResult"/> Action的链式调
用
<result-type type="dispatcher" class="org.apache.struts2.dispatcher.ServletDispatcherResult"
default="true"/>
<result-type type="redirect" class="org.apache.struts2.dispatcher.ServletRedirectResult"/>
<result-type type="redirectAction" class="org.apache.struts2.dispatcher.ServletActionRedirectResult"/>
两个Action之间如何传递信息:
chain:ActionContext.getContext().put("uid", id);
redirectAction:Session 或者 url :<result type="redirectAction">emailAction?uid=%{id}</result>(在
action中要写id的set及get方法)
17.2.2 可以扩展:<result-type name="chart"
class="org.apache.struts2.dispatcher.ChartResult">
17.2.3 跳转到其它包的Action
<result type="redirectAction">
<param name="actionName">HelloWorld</param>
<param name="namespace">/example</param>
</result>
17.3 定义自己的result-type
17.3.1 extends StrutsResultSupport
17.3.2 重写doExecute(String finalLocation, ActionInvocation invocation),配置的路径
18. 声明式异常处理 dao -- > service - > Action (统一异常处理) try { }catch() {}catch() {}
<exception-mapping result="result的name" exception="异常的类型"></exception-mapping>
18.1 异常是有继承关系: 先找精确的
18.2 既有局部(本Action使用)又有global-exception-mappings(本包所有Action共享)
先找精确,同等级别下,局部优先
18.3 global-exception-mappings最好转向到global-results
18.4 应该怎么去用: global-exception-mappings: <exception-mapping result="error"
exception="java.lang.Exception"></exception-mapping>
Action所特定关心的一些:往往和用户的输入相关, 局部
19. 19.1 ActionContext 19.2 拦截器的顺序问题
20. 编写自己的拦截器
20.1 extends AbstractInterceptor
20.2 implements Interceptor
20.3 配置 struts.xml <interceptors></interceptors>
21. 文件上传(如何给拦截器配置参数)
21.1 method="post" enctype="multipart/form-data"
21.2 Action private File repo;private String repoFileName;private String repoContentType;
21.3 struts.multipart.maxSize=20971520 一次请求最大的大小,如果不满足这个条件,错误信息来自于common-
fileupload
21.4 <!-- fileUpload必须放到前面 ,不放到前面无法转向到input-->
<interceptor-ref name="fileUpload">
<param name="maximumSize">2097152</param>
<param name="allowedExtensions">jpg,bmp</param>
</interceptor-ref>
<interceptor-ref name="defaultStack"></interceptor-ref>
22. token(如何使用额外的拦截器)
22.1提交页面<form><s:token></s:token></form>
22.2<interceptor-ref name="token"></interceptor-ref>
<interceptor-ref name="defaultStack"></interceptor-ref>
<result name="invalid.token">
23. 对现有拦截器进行修改
24. 标签
24.1 Generic Tags
24.1.1 Control Tags
24.1.2 Data Tags
24.2 UI Tags(主题 xhtml)-->界面元素怎样显示
24.2.1 Form Tags
24.2.2 Non-Form UI Tags
24.2.3 Ajax Tags(dojo)
type: object 默认理解为ognl 如果希望强制按照字符串理解‘’
String 默认理解为字符串, 如果希望强制按照ognl理解 %{ }
24.3 修改现有主题 src -- > template -- > simple -- > 哪个不适合,单独提供
24.4 定义新的主题 src -- > template ---> abc(主题的名字)通过 theme.properties指明继承simple
25. 校验: 在真正执行处理单元之前,对用户提交的信息进行基本校验,
如果满足业务要求,执行处理单元,否则转向到由input指向的页面。
25.1 客户端校验(防止用户的误操作) vs 服务器端校验(防止恶意攻击)
25.2 服务器端校验: 手工校验(validate validateXxx) 配置校验(xml-->描述业务规则)
25.3 手工校验: 在Action中重写 validate(不管处理哪个处理单元,都会执行), validateXxx
注:
validateExecute会在execute执行之前来执行
可以在validateExecute去编写业务规则
addFieldError--> 表达error的Map去添加信息
当该方法执行结束以后,如果map不为空,说明有校验错误,不再执行execute
转向到由input指向的页面
任何一个处理单元在执行之前都会调用validate,先判断有无validateXxx方法,有就调用
不管有没有问题出现,都会检查有没有validate,有则执行,当validate执行完后,检查Map
25.4 配置校验: 提供xml-->描述校验规则(1、字段优先 2、规则优先)
ActionClassName-validation.xml < -- > validate
ActionClassName-ActionName-validation.xml <--- > validateXxx(注:此处的ActionName必须要
是.xml配置文件中的action的name)
<validator name="required" class="com.opensymphony.xwork2.validator.validators.RequiredFieldValidator"/>
<validator name="requiredstring"
class="com.opensymphony.xwork2.validator.validators.RequiredStringValidator"/>
<validator name="int" class="com.opensymphony.xwork2.validator.validators.IntRangeFieldValidator"/>
<validator name="long" class="com.opensymphony.xwork2.validator.validators.LongRangeFieldValidator"/>
<validator name="short" class="com.opensymphony.xwork2.validator.validators.ShortRangeFieldValidator"/>
<validator name="double"
class="com.opensymphony.xwork2.validator.validators.DoubleRangeFieldValidator"/>
<validator name="date" class="com.opensymphony.xwork2.validator.validators.DateRangeFieldValidator"/>
<validator name="expression" class="com.opensymphony.xwork2.validator.validators.ExpressionValidator"/>
<validator name="fieldexpression"
class="com.opensymphony.xwork2.validator.validators.FieldExpressionValidator"/>
<validator name="email" class="com.opensymphony.xwork2.validator.validators.EmailValidator"/>
<validator name="url" class="com.opensymphony.xwork2.validator.validators.URLValidator"/>
<validator name="visitor" class="com.opensymphony.xwork2.validator.validators.VisitorFieldValidator"/>
<validator name="conversion"
class="com.opensymphony.xwork2.validator.validators.ConversionErrorFieldValidator"/>
<validator name="stringlength"
class="com.opensymphony.xwork2.validator.validators.StringLengthFieldValidator"/>
<validator name="regex" class="com.opensymphony.xwork2.validator.validators.RegexFieldValidator"/>
<validator name="conditionalvisitor"
class="com.opensymphony.xwork2.validator.validators.ConditionalVisitorFieldValidator"/>
26. 国际化
26.1 资源文件的命名 baseName_语言_国家.properties baseName.properties
26.2 ResourceBundle bundle = ResourceBundle.getBundle("msg", Locale.US);
String message = bundle.getString("key1");
System.out.println(MessageFormat.format(message, "小张"));
26.3 Jsp: <s:property value="%{getText("")}"/> ,但不建议使用;
<s:i18n name="com/pk/conf/user"><s:text/></s:i18n>(在页面中直接申明使用的配置文件)
26.4 Action: getText("key") 使用的资源文件最好是Action级别的或者是package级别
26.5 资源文件有级别
26.5.1 全局资源文件 <constant name="struts.custom.i18n.resources"
value="msg"></constant>
26.5.2 package级别: baseName必须是package,可以被本包及子包所有Action所共享
26.5.3 Action级别:baseName必须和类名一致,同时放在同一个目录下,可以被本Action及子类使用
26.5.4 查找顺序:Action级别 -- 》 package级别 --》 全局资源文件
27. 类型转换
XWork will automatically handle the most common type conversion for you. This includes support for converting
to and from Strings for each of the following:
String
boolean / Boolean
char / Character
int / Integer, float / Float, long / Long, double / Double
dates - uses the SHORT format for the Locale associated with the current request
arrays - assuming the individual strings can be coverted to the individual items
collections - if not object type can be determined, it is assumed to be a String and a new ArrayList is created
在默认的拦截器栈中包含了名为conversionError的拦截器,
如果出现了类型转换错误,该拦截器负责封装fieldError,
并转向到名为input的逻辑视图。
默认情况下,错误的提示信息为:Invalid field value for field "{0}"
如需要改提示信息有如下两种方式:
1、在全局资源文件中提供如下内容xwork.default.invalid.fieldvalue=提示信息
2、在Action作用域,包作用域以及全局资源文件中invalid.fieldvalue.域的名字=提示信息
编写自定义类型转换器有三种方式:建议继承StrutsTypeConverter
编写完自定义类型转换器后,我们需要通过配置告诉Struts2,有两种注册方式:
1、配置全局转换器配置文件:在src下面写一个xwork-conversion.properties的配置文件,其中配置类名和转换
器名
“待转换的类型的全名(包括包路径和类名)=转换器类的全名”对
如:com.pk.vo.Point---com.pk.web.converter.MyConverter
2、应用于某个特定类的类型转换器,做法为在该类的包中添加一个格式为:
“类名-conversion.properties”的配置文件,并在文件中加入
“待转换属性的名字=转换器类的全名”对
28. 和spring的整合(两种整合方式)
28.1 Autowiring: Action是struts2自己管理
默认按照name进行自动装配: struts.objectFactory.spring.autoWire = name
28.1.1 注解 Action: 不用加Controller
28.2 Initializing Actions from Spring: Action交给spring管理
28.2.1 在spring配置Action: scope="prototype"(使配置的bean不是单例的)
28.2.2 修改struts.xml <action class="对应的bean的id">
//由spring管理时可配置注解
28.2.3 注解 Action : @Controller @Scope("prototype")
service: @Service
28.3 When an object is to be created, it uses the class attribute in the Struts
configuration to correspond to the id attribute in the Spring configuration.
If not found, the class will try to be created as usual, then be autowired by Spring.
By default, the framework will at least try to use Spring to create all its objects.
If the object cannot be created by Spring,
then the framework will create the object itself.
发表评论
-
遮盖层覆盖整个页面
2015-07-08 10:45 592html代码: <body topmargin= ... -
spring注解+restlet
2014-08-26 13:32 651spring注解精解: http://www.douban.c ... -
Spring使用程序方式读取properties文件
2014-07-03 10:37 534Spring使用程序方式读取properties文件 在sp ... -
用javascript取当前系统时间(年、月、日等全)
2013-07-25 14:56 565var myDate = new Date(); myDate ... -
sql--查询数据库的连接数
2013-06-07 14:04 609Oracle: select * from v$sessio ... -
jQuery中设置form表单中action值的方法
2013-04-28 18:16 1153html代码: <form id="myFo ... -
java filter
2013-04-24 23:17 937一、使浏览器不缓存页面的过滤器 Java代码 impo ... -
sql count
2013-04-23 14:33 719连接该服务器的个数: SELECT count(*) FRO ... -
关闭打开页js(兼容浏览器)
2013-04-22 13:17 846<script> function closeSe ... -
sql-修改表
2013-04-11 10:19 713如需在表中添加列,请使用下列语法: ALTER TABLE t ... -
wget 爬虫
2012-11-13 13:34 1458wget 使用指南 wget是一个从网络上自动下载文件的自由工 ... -
dwr的使用
2012-11-11 12:38 810Dwr使用说明 1. 将dwr的ja ... -
Ajax的使用
2012-11-11 12:37 702ajax的使用步骤: 1.需要通过JavaScript创建XM ... -
JAVA数据库连接池
2012-11-09 00:02 731JAVA数据库连接池 基 ... -
事务传播特性和事务隔离级别
2012-11-08 23:48 608事务传播特性了解事务 ... -
ibatis
2012-11-08 23:45 756ibatis: ibatis中dao中的方法在使用sqlMap ... -
懒加载
2012-11-07 19:03 635get和load默认的时候都是立即检索,只有设置lazyloa ... -
HQL语句
2012-11-07 19:01 6171.实体查询 String hql = &qu ... -
类的加载和反射
2012-11-07 18:57 6701. 类的加载、连接和初始 a) 类的加载 i. 当程序主动使 ... -
部分重要SQL语句
2012-11-06 20:13 737TO_CHAR(date, 'fmt') 用于将 ...
相关推荐
这个名为“struts2整理成册.rar”的压缩包显然包含了有关Struts2的详细资料,尤其是包含了一个名为“STRUTS2整理成册.pdf”的PDF文件,我们可以期待它提供了关于Struts2的深入理解和实践指导。 Struts2的核心特性...
【标题】:“ireport + struts2 整理” 【正文】: 在IT行业中,ireport和Struts2是两个非常重要的开源工具,它们分别在报告生成和MVC框架领域有着广泛的应用。ireport是JasperReports库的一个图形化设计工具,...
在“struts2整理的东西补充”这个压缩包中,可能包含了开发者对Struts2框架深入理解和实践的笔记,主要聚焦在OGNL(Object-Graph Navigation Language)的用法、validate验证以及类型转换等方面。以下是对这些知识点的...
### Struts2基础知识整合 #### 一、Struts2表达式与数据访问 在Struts2框架中,可以通过多种方式来访问Action中的属性值或请求范围内的数据。 **1. 使用`%{}`访问Action中的属性** - **语法示例**: ```html ...
本资源包含三本书籍,分别是《struts2权威指南》、《STRUTS2整理成册517》和《starting-struts2-chinese》,这些书籍覆盖了Struts2的基础学习到高级应用,是深入理解和掌握Struts2不可或缺的参考资料。 1. **...
Struts2 框架详解 Struts2 是一个基于 Java Servlet 技术的开源 web 应用程序框架,它提供了一个灵活、可扩展的解决方案来构建企业级 web 应用程序。Struts2 框架的核心是 Action,Action 是一个包含了业务逻辑的 ...
Struts2是一个强大的Java web应用程序框架,用于构建和部署企业级的MVC(Model-View-Controller)架构应用。它是Apache软件基金会旗下 Jakarta项目的一部分,是Struts1的升级版本,提供了更丰富的功能和更好的性能。...
Struts2是一个强大的Java Web应用程序开发框架,它基于MVC(Model-View-Controller)设计模式,为构建可维护、可扩展且结构清晰的Web应用提供了便利。在本复习资料中,我们将深入探讨Struts2的核心概念、主要特性...
### Struts2框架学习笔记整理 #### 一、Struts2框架概述 ##### 1.1 Struts2框架定义 Struts2是一个基于MVC(Model-View-Controller)架构模式的开源Java web应用框架,它能够帮助开发者构建可扩展且易于维护的...
这个资料整理汇总包含了Struts2技术的方方面面,是学习和理解Struts2框架的宝贵资源。 首先,让我们深入了解一下Struts2的核心概念。Struts2是基于Model-View-Controller(MVC)设计模式的,它将业务逻辑、数据和...
这个标题“struts2 各版本所需最少jar包整理”指的是在不同版本的Struts2中,为了最小化项目依赖并确保框架正常运行,需要的最低限度的JAR库集合。 Struts2的核心依赖包括以下几个关键部分: 1. **核心库**:`...
Struts2是一个流行的Java web应用程序框架,它用于构建基于MVC(模型-视图-控制器)架构的Web应用。这个框架提供了强大的控制层,使得开发者能够更有效地管理请求、处理业务逻辑以及展示数据。以下是对Struts2核心...
这个整理的Struts2文件集合可能包含了关于Struts2的核心概念、配置、Action、Result类型、拦截器、插件、安全实践以及与其他技术如Spring、Hibernate集成的相关资料。 在Struts2中,Action类是业务逻辑的主要载体,...
网上很多有关struts2的api文档都是不全的。我经过精心整理出的struts2api文档,非常齐全。
阅读“STRUTS2整理成册.pdf”这份资料,你可以深入理解以上知识点,并通过实践案例来巩固所学。同时,配合博客链接(已提供),可以获取更多实践经验和技巧,从而快速上手Struts2框架,为Java Web开发打下坚实基础。
### Struts2的工作机制原理分析及实例整理 #### 一、概述 Struts2作为一款流行的Java Web开发框架,其设计理念和技术实现相比Struts1.x有着显著的不同。尽管两者名称相似,但从架构到实现方式,Struts2都有了质的...
### Struts2零配置个人整理文档 #### 一、Convention插件详解 ##### 1. 设置结果页面路径 - **背景介绍**:Struts2框架提供了便捷的方式来处理Web请求,并返回响应视图。为了简化配置过程,Struts2提供了一个名为...
Struts2是Java Web开发中一个非常重要的MVC框架,由Apache软件基金会维护。这个"struts2框架2016版资料day01"涵盖了Struts2的基础知识,包括框架的基本架构、核心概念和初步配置。传智播客作为知名的IT教育机构,其...
根据提供的文件信息,我们可以整理出关于Struts2框架的一些关键知识点。尽管原文中的信息较为零散且不完整,但还是可以从中提炼出一些有价值的内容。接下来,我们将详细探讨这些知识点。 ### Struts2简介 Struts2...