众所周知,Struts2的大部分功能都是通过拦截器实现的,就算是Struts2的启动也是使用Servlet的拦截器启动的,下
面我们来说一下自定义Struts2拦截器,其实只要是学过Servlet的拦截器,就应该明白大概原理,基本上是差不多的。
首先需要写一个类,实现Struts2的指定接口,com.opensymphony.xwork2.interceptor.Interceptor;
package com.bird.action;import com.opensymphony.xwork2.ActionContext;import com.opensymphony.xwork2.ActionInvocation;import com.opensymphony.xwork2.interceptor.Interceptor;public class PermissionInterceptor implements Interceptor { private static final long serialVersionUID = 1L; public void destroy() { // TODO Auto-generated method stub } public void init() { // TODO Auto-generated method stub } public String intercept(ActionInvocation action) throws Exception { Object value = ActionContext.getContext().getSession().get("user"); if(value != null) return action.invoke(); ActionContext.getContext().put("message", "您没有权限登录"); return "message"; }}
和Servlet拦截器类似,主要都是在intercept这个方法上了,这里判断session里面是否有值,如果有值就调用拦截器后
面的Action的方法,这样就完成了拦截器的任务,没有servlet里面的拦截器链。下面的工作就是注册拦截器,在
struts.xml这个配置文件里面这样配置。
<package name="niao" namespace="/t" extends="struts-default"> <interceptors> <interceptor name="permission" class="com.bird.action.PermissionInterceptor"/> <interceptor-stack name="permissionStack"> <interceptor-ref name="defaultStack"></interceptor-ref> <interceptor-ref name="permission"></interceptor-ref> </interceptor-stack> </interceptors> <global-results> <result name="message">/WEB-INF/jsp/hello.jsp</result> </global-results> <action name="login_*" class="com.bird.action.Login" method="{1}"> <interceptor-ref name="permissionStack"/> <result name="success">/WEB-INF/jsp/hello.jsp</result> </action> </package>
这里启用了拦截器栈,这个意思是因为一旦你定义了自己的拦截器就把struts默认的拦截器都给屏蔽掉了,这样的话
很多struts的功能就不能使用了,所以使用了拦截器栈,这样把struts默认的和你自定义的都放在了一个堆栈中,实现
了自定义和默认的拦截器的同时使用,默认堆栈的名称为defalutStack,这个名字可以在struts-default.xml文件里面找
到,不能写错了。然后定义了一个全局信息处理页面,最后在action定义里面直接把拦截器堆栈放到里面去就行了。
总体感觉还是挺简单的,至少和servlet差不多
再分享一下我老师大神的人工智能教程吧。零基础!通俗易懂!风趣幽默!还带黄段子!希望你也加入到我们人工智能的队伍中来!https://blog.csdn.net/jiangjunshow