关闭

struts1的拦截器1_1

3203人阅读 评论(1) 收藏 举报

SAIF(Struts Action Invocation Framework)是一个开源组件,它让Struts框架具备Action拦截器与IOC的功能 1.将saif.jar包放入你的lib中。 2.创建Interceptor类。 3.写interceptor配置文件:interceptor-config.xml。这个配置文件中指定了interceptor类和要被拦截的action。 4.在struts-config.xml中指定加载interceptor-config.xml。

我们都知道Struts默认没有实现AOP,这和WebWork2想比确实矮了一截,还好,有人(Lars Hoss 和 Don Brown)意识到这点,编写SAIF(Struts Action Invocation Framework)弥补了这个缺陷,下面就是SAIF的使用介绍。

SAIF的安装很简单:首先将saif-0.1.jar文档复制到WEB-INF/lib目录下即可,然后修改struts-config.xml文档,将SAIF以plugin方式添加到struts-config.xml文档中,如下:


<plug-in className="net.sf.struts.saif.SAIFPlugin">
<set-property property="interceptor-config" value="/WEB-INF/interceptor-config.xml" />
</plug-in>

最后,编写interceptor-config.xml文档,进行相关拦截器的声明,这样您就完成SAIF的安装和设定,下面我们将以一个现时的例子来阐述SAIF的使用及其长处。

我们现在有这个一个需求,在OA中,拟定人能够修改自己发的通知,其他人均不能修改,只能查看。我们撰写了两个Action:EditNoticeAction和ViewNoticeAction,我们传给这两个Action的参数时通知的编码:noticeId。通知对象的代码如下(Hibernate的PO方式):


public class NoticePO
{
private Integer id; //编码
private String title; //标题
private String content; //内容
private Integer authorId; //发布人编码
private Date publishedDate; //发布日前

//getter and setter methods
……….
}

同时我们拥有两个jsp文档:viewnotice.jsp和editnotice.jsp,这样我们在Action中根据noticeId将NoticePO构建出来,然后传给jsp页面,jsp负责将数据显示出来,这样的流程就完毕啦。但是我们在实现中忘记了这个一点,权限的设定。所以我们需要对EditNoticeAction进行拦截操作,也就是在EditNoticeAction操作完毕后,将session中的用户id和NoticePO中的authorId进行对比,假如相同,表示是该通知的拟定人,指向editnotice.jsp页面,否则,指向viewnotice.jsp页面。新建EditNoticeInterceptor,实现如下:


public class EditNoticeInterceptor extends DefaultInterceptor
{
public ActionForward afterAction(Action action, ActionMapping mapping,
ActionForm form, HttpServletRequest request,
HttpServletResponse response) throws IOException, ServletException
{
Integer userId=(Integer)request.getSession().getAttribute(“User_ID”);
NoticePO notice=( NoticePO)request.getAttribute(“notice”);
if(notice.getAuthorId()==userId)
{
return mapping.findForward(“view”);
}
return null;
}
}

这样我们就完成了拦截器的代码编写,下面就是在interceptor-config.xml对拦截器进行声明。


<?xml version="1.0" encoding="gb2312"?>
<!DOCTYPE interceptor-config SYSTEM "http://struts.sourceforge.net/saif.dtd">
<interceptor name="EditNoticeActionInterceptor"
type="net.jetmaven.interceptor.EditNoticeActionInterceptor"/>
<action type="net.jetmaven.action.EditNoticeAction">
<interceptor name="EditNoticeActionInterceptor"/>
</action>
</interceptor-config>

这样我们就完成了我们既定的需求,通过介入拦截器完全地将权限和业务逻辑分开啦。

最后再说说SAIF,SAIF默认的拦截方法没有返回值,而在这里我们使用ActionForward作为返回值,目的就是想更改原先的流程,返回值为空表示继续原先流程,返回值不为空标识修改以前的流程,这样觉得更容易理解点,和实际情况更贴切。SAIF的拦截器能够重叠使用,就是针对某一Action能够有多个拦截器,这一点也是很有用的,我们同样更加返回值来判定是否终止这个链,假如返回值为空,标识继续该链,否则终止该链,立即返回。



0
0

查看评论
* 以上用户言论只代表其个人观点,不代表CSDN网站的观点或立场
    个人资料
    • 访问:591039次
    • 积分:8927
    • 等级:
    • 排名:第2217名
    • 原创:327篇
    • 转载:40篇
    • 译文:0篇
    • 评论:24条
    最新评论