要在struts1.2中使用拦截器,必须使用到以下三个包:
1:saif-0.1.jar
2:saif-spring.jar
3:spring.jar
把以上三个包放入到自己J2EE工程中的web-inf/lib目录下,然后建立拦截器类,如:
package cn.softjob.util;
import java.io.IOException;
import java.sql.SQLException;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import net.sf.struts.saif.ActionHaveForwardInterceptor;
import org.apache.struts.action.Action;
import org.apache.struts.action.ActionForm;
import org.apache.struts.action.ActionForward;
import org.apache.struts.action.ActionMapping;
import cn.softjob.ap.enterNormalExitCheck.business.EnterNormalExitCheckBusiness;
import cn.softjob.ap.enterNormalExitCheck.form.EnterNormalExitCheckForm;
/
public ActionForward beforeAction(Action action, ActionMapping mapping, ActionForm form,
HttpServletRequest request, HttpServletResponse response)
throws IOException, ServletException {
//获得用户请求URL
String url = request.getRequestURL().toString();
if (request.getQueryString() != null && !"".equals(request.getQueryString())) {
url = url + "?" +request.getQueryString();
}
EnterNormalExitCheckForm enterNormalExitCheckForm = new EnterNormalExitCheckForm();
//从session中取得企业用户ID
String enterid = (String)request.getSession().getAttribute("enterprise_id") ;
//向form中设置企业用户ID
enterNormalExitCheckForm.setEnterId(enterid) ;
EnterNormalExitCheckBusiness enterNormal = new EnterNormalExitCheckBusiness();
String forward = "" ;
//断断企业用户是否已经登陆
if ((enterid == null || "".equals(enterid)) || (url.indexOf("enterprisesMain.do") != -1)) {
//判断是否从登陆页面过来
if ((url.indexOf("enterprisesLogin.do") != -1) || (url.indexOf("enterprisesMain.do") != -1)) {
String enName = String.valueOf(request.getParameter("username")) ;
request.setAttribute("enterName", enName) ;
//得到企业用户名
enterNormalExitCheckForm.setEnterName(enName) ;
//得到企业用户密码
enterNormalExitCheckForm.setEtnerPwd(String.valueOf(request.getParameter("password"))) ;
//验证企业用户是否存在
boolean isExit = enterNormal.checkEnterUser(enterNormalExitCheckForm, request) ;
request.getSession().setAttribute("enterprise_id", enterNormalExitCheckForm.getEnterId()) ;
if (isExit) {
//验证企业用户直接从登陆画面过来
boolean flag = enterNormal.checkNormalExitForLogin(enterNormalExitCheckForm ,request) ;
if (flag) {
//上次没有正常退出或者在其他地方被登陆,不能进行后续操作
request.setAttribute("flagEnter", "noexit") ;
//request.setAttribute("lastLoginTime", enterNormalExitCheckForm.getLastLoginTime()) ;
forward = "notNormalExite" ;
} else {
request.setAttribute("enterUrl", url) ;
forward = "successNormal" ;
}
} else {
//如果此用户不存在,回到登陆页面,并显示错误提示信息
request.setAttribute("enterUrl", url) ;
forward = "successNormal" ;
}
} else {
//如果没有登陆就转发到登陆页面
forward = "enterLoginfailure" ;
}
} else {
//验证企业用户上次是否正常退出,如果退出时间为空返回true,否则返回false
boolean flag = enterNormal.checkNormalExitForOther(enterNormalExitCheckForm ,request) ;
if (flag) {
//已经正常退出,可以进行后续操作
request.setAttribute("enterUrl", url) ;
forward = "successNormal" ;
} else {
//被用户强制退出或者在其他地方被登陆,不能进行后续操作
request.setAttribute("flagEnter", "ztexit") ;
request.setAttribute("enterName", enterNormalExitCheckForm.getEnterName()) ;
request.setAttribute("lastLoginTime", enterNormalExitCheckForm.getLastLoginTime()) ;
forward = "notNormalExite" ;
}
}
try {
enterNormal.closeConnection() ;
} catch (SQLException e) {
e.printStackTrace();
}
return mapping.findForward(forward);
}
}
值得注意的是:是否正常退出验证,最好就放在这儿做,如果放到其他action中做的话,可能出现循环,我刚开始就只在这个拦截器中什么验证也没有做,只把请求转发到我自己写的一个分发式action,这个分发式action才实现了是否正常退出的验证,结果就现了死循环.最后想了想,觉得这样做不对,应该把验证放到拦截器中,如果验证通过了,则进行后续操作,反之则进入错误画面.
第二步:配置interceptor-config.xml文件,在此文件中添加要拦截的Action:
?xml version="1.0"?>
<interceptor-config>
<interceptor name="displayInterceptor" type="cn.softjob.util.DisplayInterceptor"/>
<!-- 用户登陆 -->
<action type="/enterprisesLogin">
<interceptor name="displayInterceptor" />
</action>
<!-- 职位发布 -->
<action type="/postJob">
<interceptor name="displayInterceptor" />
</action>
<action type="/postsManage">
<interceptor name="displayInterceptor" />
</action>
<!-- 应聘管理 -->
<action type="/candiResume">
<interceptor name="displayInterceptor" />
</action>
<action type="/statisticsCandidates">
<interceptor name="displayInterceptor" />
</action>
<action type="/favoritesTalent">
<interceptor name="displayInterceptor" />
</action>
<action type="/interviewRecords">
<interceptor name="displayInterceptor" />
</action>
<action type="/enterpriseRecycle">
<interceptor name="displayInterceptor" />
</action>
<!-- 无忧简历 -->
<action type="/KeyWordSearchInitalsAction">
<interceptor name="displayInterceptor" />
</action>
<action type="/AdvancedSearchInitalsAction">
<interceptor name="displayInterceptor" />
</action>
<action type="/enterpriseSearch">
<interceptor name="displayInterceptor" />
</action>
<action type="/newResumeResultAction">
<interceptor name="displayInterceptor" />
</action>
<action type="/studentssearch">
<interceptor name="displayInterceptor" />
</action>
<!-- 系统设置 -->
<action type="/qyInforManagement">
<interceptor name="displayInterceptor" />
</action>
</interceptor-config>
第三步:配置struts-config.xml:
<plug-in className="net.sf.struts.saif.SAIFSpringPlugin">
<set-property property="interceptor-config" value="/WEB-INF/interceptor-config.xml" />
</plug-in>
最后,重启服务器服务器,就可以在struts中实现拦截器的功能啦!
分享到:
相关推荐
使用Struts1.2拦截器的基本步骤如下: 1. **定义拦截器类**:创建一个实现`Interceptor`接口的Java类,通常需要重写`intercept()`方法。在这个方法里,你可以添加你需要的逻辑,如记录日志、性能监控等。 2. **...
7. **Interceptor(拦截器)**:虽然Struts1.2的核心版本不包含拦截器,但可以通过扩展实现,提供在请求处理流程中的预处理和后处理功能,如日志记录、权限检查等。 8. **Internationalization(国际化)**:Struts...
10. **Plug-in架构**:Struts1.2的插件架构允许开发者扩展框架功能,例如添加自定义拦截器(Interceptor)来实现额外的业务逻辑或安全控制。 11. **Struts标签库**:Struts1.2提供了丰富的标签库,如logic标签、...
Struts1.2是该框架的一个早期版本,虽然现在已经被Struts2所取代,但在许多遗留系统中仍然广泛使用。本教程将深入探讨Struts1.2的核心概念、功能以及与Struts2的区别。 一、Struts框架基础 1. **MVC模式**:Struts...
Struts1.2是Apache软件基金会的一个开源项目,它是一个基于MVC(Model-View-Controller)设计模式的Java Web应用程序框架。这个框架的主要目的是...通过实际操作,可以更深入理解Struts1.2框架的工作原理和使用方法。
本文将详细介绍Struts1.2和Struts2.0两个版本的主要API和开发中的关键知识点。 **Struts1.2 API** 在Struts1.2版本中,主要的API包括Action、Form Bean、ActionServlet、ActionMapping、ActionForward等核心组件。...
5. **拦截器(Interceptor)**:拦截器是Struts1.2增强功能的重要部分,它们允许在Action执行前后插入额外的逻辑,如日志、权限检查等。 6. **标签库(Taglib)**:Struts1.2提供了丰富的JSP标签,如`s:form`、`s:...
拦截器是Struts 1.2的一个重要特性,它允许在Action调用前后插入自定义逻辑,如日志记录、权限检查等。 **8. 数据源集成** Struts 1.2可以方便地与各种数据源(如JNDI、Apache DBCP等)集成,提供数据库连接管理。 ...
- **配置文件(struts-config.xml)**:Struts的核心配置文件,用于定义Action、ActionForm和视图之间的映射关系,以及国际化资源、拦截器等配置信息。 #### 四、Struts标签库 Struts框架提供了一套丰富的标签库,...
通常,这样的文件会定义Bean的实例化、属性注入,以及与Struts1.2相关的拦截器、控制器或服务的配置。例如,可能会有类似以下的配置: ```xml ``` 在上面的例子中,`myAction` Bean是Struts1.2中的Action,...
1. **ActionServlet**:这是STRUTS1.2的核心组件,是一个实现了Servlet API的控制器,负责拦截HTTP请求,将请求分发到相应的Action。 2. **ActionForm**:表单对象,用于在Controller和View之间传递数据,通常对应...
4. **添加Struts1.2 Form, Action & Jsp**:通过选择myEclipse > Web > Struts > Struts1.2,然后选择Struts1.2 Form, Action & Jsp模板,开始创建Struts的实例。 5. **填写Use Case和Super Class**:在创建新组件时...
- 拦截器是Struts1.2的一个重要特性,可以添加额外的功能,如日志记录、权限检查等。虽然在简单的例子中可能没有涉及,但了解其工作原理有助于进一步掌握Struts1.2。 8. **部署描述符**: - `web.xml`文件是应用...
- 使用Struts提供的拦截器来处理请求,确保请求能够正确地路由到目标资源。 5. **其他建议**: - 对于大型项目,推荐使用构建工具(如Maven或Gradle)来管理静态资源的版本控制和依赖关系。 - 在开发过程中,...
9. **Plug-in架构**:Struts 1.2的插件机制允许开发者添加自定义功能,如拦截器、标签库等,增强了框架的可扩展性。 10. **标签库**:Struts 1.2提供了一系列的JSP标签,如logic标签、bean标签、html标签等,简化了...
在Struts1.2中,开发者可以利用Interceptor(拦截器)增强功能,例如日志记录、事务管理、权限控制等。此外,Struts1.2还支持国际化和本地化,使得应用程序可以适应不同的语言环境。 学习这个案例源代码,你可以...
4. **拦截器**:深入理解拦截器的概念,编写自定义拦截器,以及如何在配置中使用拦截器栈。 5. **表单验证**:使用Struts 2内置的验证框架进行客户端和服务器端的数据验证。 6. **国际化**:如何实现应用的多语言...
- **拦截器**:通过使用 Struts 的拦截器机制,可以在请求处理流程中自动设置或获取 `Locale`。 #### 五、最佳实践 - **资源文件命名规范**:资源文件应按照 `_locale` 的形式命名,例如 `messages_zh_...