(一)创建过滤器
1.新建类继承AbstractInterceptor实现intercept方法
2.在XML中配置过滤器 当用户使用了自定义的拦截器的时候默认的就不使用了,所有要显示调用
<interceptors>
配置自定意过滤器
<interceptor name="inter" class="www.ljc.wpone.Intepter"></interceptor>
配置拦截器栈 方便使用
<interceptor-stack name="mystck">
<interceptor-ref name="inter"/>
引人默认的过滤器
<interceptor-ref name="defaultStack" />
</interceptor-stack>
</interceptors>
定义默认调用拦截器
<default-interceptor-ref name="mystck"></default-interceptor-ref>
3.方法过滤器继承MethodFilterInterceptor实现doIntercept方法
4.配置在struts.xml中当使用:
<interceptor-ref name="mm">
需要拦截 includeMethods优先级高于excludeMethods
<param name="includeMethods">execute</param>
不需要拦截
<param name="excludeMethods">execute</param>
</interceptor-ref>
(二)阻止数据的重复提交 避免数据库负担
1.添加token拦截器到action中默认是没有该拦截器的
<interceptor-ref name="token"/>
2.在页面添加<s:token/>标签 注意:返回的错误信息类型不是input是invalid.token
<result name="invalid.token">/regst.jsp</result>
3.定义属性String token 提供get,set
(三)Ajax封装数据json文件 `
1.导入struts2-json-plugin-2.3.15.3.jar 在package中继承extends="json-default"
2.设置返回值类型为type="json"
(四)log4日志信息打印
1.加载包log4j-1.2.17.jar
//创建log4j对象
private Log log = LogFactory.getLog(Toke.class);
输出信息
log.info("香港我想去");
2.写配置文件 src下新建log4j.properties输出信息,写出文件信息 设置优先级别 以及输出源
log4j.rootLogger=DEBUG,mylog,stdout
log4j.appender.mylog=org.apache.log4j.FileAppender
指定输出文件的地址
log4j.appender.mylog.file=D:/log.txt
log4j.appender.mylog.layout=org.apache.log4j.SimpleLayout
把日志信息输出到文件
log4j.appender.stdout=org.apache.log4j.ConsoleAppender
log4j.appender.stdout.target=System.out
log4j.appender.stdout.layout=org.apache.log4j.PatternLayout
log4j.appender.stdout.layout.ConversionPattern=%d %5p [%c:%L] - %m%n
log4j的七种级别
all<debug<info<warn<error<fetal<off 但是apache只支持四种 debug,info,warn,error,
(五)注解 只能当前Action使用,不能复用
1.在action方法前添加@Before @After
@Before
public String before() {
}
@After
public String after() {
}
2..配置<interceptor name="anno" class="com.opensymphony.xwork2.interceptor.annotations.AnnotationWorkflowInterceptor" />添加到拦截器当中去
(六)结果集监听器
1.编写一个类实现PreResultListener接口,实现void beforeResult(ActionInvocation invocation,String resultCode);方法 resultCode获取的是Action类相应方法的返回字符串
2.在需要它的Inteceptor中注册这个监听器类。在doIntercept方法中通过invocation.addPreResultListener(new 上面的监听器类());进行注册
3.监听器的执行时期在Action类返回结果之后,Inteceptor回调语句之前执行
1.新建类继承AbstractInterceptor实现intercept方法
2.在XML中配置过滤器 当用户使用了自定义的拦截器的时候默认的就不使用了,所有要显示调用
<interceptors>
配置自定意过滤器
<interceptor name="inter" class="www.ljc.wpone.Intepter"></interceptor>
配置拦截器栈 方便使用
<interceptor-stack name="mystck">
<interceptor-ref name="inter"/>
引人默认的过滤器
<interceptor-ref name="defaultStack" />
</interceptor-stack>
</interceptors>
定义默认调用拦截器
<default-interceptor-ref name="mystck"></default-interceptor-ref>
3.方法过滤器继承MethodFilterInterceptor实现doIntercept方法
4.配置在struts.xml中当使用:
<interceptor-ref name="mm">
需要拦截 includeMethods优先级高于excludeMethods
<param name="includeMethods">execute</param>
不需要拦截
<param name="excludeMethods">execute</param>
</interceptor-ref>
(二)阻止数据的重复提交 避免数据库负担
1.添加token拦截器到action中默认是没有该拦截器的
<interceptor-ref name="token"/>
2.在页面添加<s:token/>标签 注意:返回的错误信息类型不是input是invalid.token
<result name="invalid.token">/regst.jsp</result>
3.定义属性String token 提供get,set
(三)Ajax封装数据json文件 `
1.导入struts2-json-plugin-2.3.15.3.jar 在package中继承extends="json-default"
2.设置返回值类型为type="json"
(四)log4日志信息打印
1.加载包log4j-1.2.17.jar
//创建log4j对象
private Log log = LogFactory.getLog(Toke.class);
输出信息
log.info("香港我想去");
2.写配置文件 src下新建log4j.properties输出信息,写出文件信息 设置优先级别 以及输出源
log4j.rootLogger=DEBUG,mylog,stdout
log4j.appender.mylog=org.apache.log4j.FileAppender
指定输出文件的地址
log4j.appender.mylog.file=D:/log.txt
log4j.appender.mylog.layout=org.apache.log4j.SimpleLayout
把日志信息输出到文件
log4j.appender.stdout=org.apache.log4j.ConsoleAppender
log4j.appender.stdout.target=System.out
log4j.appender.stdout.layout=org.apache.log4j.PatternLayout
log4j.appender.stdout.layout.ConversionPattern=%d %5p [%c:%L] - %m%n
log4j的七种级别
all<debug<info<warn<error<fetal<off 但是apache只支持四种 debug,info,warn,error,
(五)注解 只能当前Action使用,不能复用
1.在action方法前添加@Before @After
@Before
public String before() {
}
@After
public String after() {
}
2..配置<interceptor name="anno" class="com.opensymphony.xwork2.interceptor.annotations.AnnotationWorkflowInterceptor" />添加到拦截器当中去
(六)结果集监听器
1.编写一个类实现PreResultListener接口,实现void beforeResult(ActionInvocation invocation,String resultCode);方法 resultCode获取的是Action类相应方法的返回字符串
2.在需要它的Inteceptor中注册这个监听器类。在doIntercept方法中通过invocation.addPreResultListener(new 上面的监听器类());进行注册
3.监听器的执行时期在Action类返回结果之后,Inteceptor回调语句之前执行