有时候会做权限判断,如果没有做登陆那么有些页面就不能被访问,这个时候做一个全局拦截器就可以搞定。具体的配置如下:
首先定义一个类,实现interceptor接口或者abstractinterceptor借口,并实现里面的方法。init()和destroy()方法不用操心。我们主要关注interceptor()方法,在这里面我们可以做相信的权限判断。我这里实现的是interceptor接口。
public class LoginInterceptor implements Interceptor{
@Override
public void destroy() {
}
@Override
public void init() {
}
@Override
public String intercept(ActionInvocation arg0) throws Exception {
System.out.println("In....interceptor");
Map<String,Object> session = arg0.getInvocationContext().getSession();//获取session
if(session.get("login")!=null)
{
return arg0.invoke();//已经登录继续执行
}else
{
return "login";//返回登录页面,当然这个只是个result
}
}
}
Ok,接下来就是配置了。下面来看Struts.xml的配置。首先配置一个package,让它继承自struts-default。然后配置我们自己的拦截器。配置一个全局结果映射。
<package name="all" extends="struts-default">
<interceptors>
<!-- 自定义的拦截器 -->
<interceptor name="my_interceptor" class="com.xxxx.xxxxx.interceptor.LoginInterceptor"></interceptor>
<!-- 定义拦截器栈 -->
<interceptor-stack name="myinterceptor_stack">
<!-- 默认拦截器 -->
<interceptor-ref name="defaultStack"></interceptor-ref>
<!-- 自定义拦截器 -->
<interceptor-ref name="my_interceptor"></interceptor-ref>
</interceptor-stack>
</interceptors>
<!-- 默认拦截器 -->
<default-interceptor-ref name="myinterceptor_stack"></default-interceptor-ref>
<!-- 全局结果集 -->
<global-results>
<result name="login">/index.jsp</result>
</global-results>
</package>
OK,接下来就就跟平常写配置文件没啥区别了,只是让其它包继承自我们自己的加了拦截器的包就可以了
<package name="Struts" extends="all">
<action name="Test" class="com.xxxx.xxxx.action.TestAction">
<result name="success">/success.jsp</result>
<result name="erroe">/error.jsp</result>
</action>
</package>
Ok,当然了,这是一个全局的,对所有的action都会进行拦截。那么至少我们要留出一个登录的action才能正常登录,那么这个时候只需要在另外一个不继承加了拦截器的包里定义action就可以了。