比如:经常在Action中都须要获取当前登录的User,就须要获取Session。然后从Session获取当前登录的User,由于这些步骤都是反复操作,能够想办法在拦截器中进行实现。能够自己定义一个接口。仅仅要你的Action实现了这个接口。就在自己定义拦截器中进行注入。

即从拦截器中获取Session,然后设置进行注入。

简单的样例:

一个自己定义接口,仅仅要Action实现这个接口,就在拦截器中进行注入

package com.atguigu.surveypark.struts2;

import com.atguigu.surveypark.model.User;

/**
* 用户关注
*/
public interface UserAware {
public void setUser(User user);
}

一个自己定义拦截器(登录拦截器):在拦截器中获取action的实例,假设实现上面的接口就进行注入。即调用接口的方法。

package com.atguigu.surveypark.struts2.interceptor;

import com.atguigu.surveypark.model.User;
import com.atguigu.surveypark.struts2.UserAware;
import com.atguigu.surveypark.struts2.action.BaseAction;
import com.atguigu.surveypark.struts2.action.LoginAction;
import com.atguigu.surveypark.struts2.action.RegAction;
import com.opensymphony.xwork2.ActionInvocation;
import com.opensymphony.xwork2.interceptor.Interceptor; /**
* 登陆拦截器
*/
public class LoginInterceptor implements Interceptor { private static final long serialVersionUID = 4230211839075439660L; public void destroy() {
} public void init() {
} @SuppressWarnings("rawtypes")
public String intercept(ActionInvocation arg0) throws Exception {
BaseAction action = (BaseAction) arg0.getAction();
if(action instanceof LoginAction
|| action instanceof RegAction){
return arg0.invoke();
}
else{
User user = (User) arg0.getInvocationContext().getSession().get("user");
if(user == null){
//去登陆
return "login" ;
}
else{
//放行
if(action instanceof UserAware){
//注入user给action
((UserAware)action).setUser(user);
}
return arg0.invoke();
}
}
}
}

Action:一个实现接口的Action

package com.atguigu.surveypark.struts2.action;

import java.util.List;

import javax.annotation.Resource;

import org.springframework.context.annotation.Scope;
import org.springframework.stereotype.Controller; import com.atguigu.surveypark.model.Survey;
import com.atguigu.surveypark.model.User;
import com.atguigu.surveypark.service.SurveyService;
import com.atguigu.surveypark.struts2.UserAware; /**
* SurveyAction
*/
@Controller
@Scope("prototype")
public class SurveyAction extends BaseAction<Survey> implements UserAware{ private static final long serialVersionUID = 2438909978838628762L; //注入SurveyService
@Resource
private SurveyService surveyService ; //调查集合
private List<Survey> mySurveys ; //接受user对象
private User user; public List<Survey> getMySurveys() {
return mySurveys;
} public void setMySurveys(List<Survey> mySurveys) {
this.mySurveys = mySurveys;
} /**
* 查询我的调查列表
*/
public String mySurveys(){
this.mySurveys = surveyService.findMySurveys(user);
return "mySurveyListPage" ;
} /**
* 新建调查
*/
public String newSurvey(){
this.model = surveyService.newSurvey(user);
return "designSurveyPage" ;
} //注入User对象
public void setUser(User user) {
this.user = user ;
}
}

struts.xml:拦截器注冊

<?

xml version="1.0"?>
<!DOCTYPE struts PUBLIC
"-//Apache Software Foundation//DTD Struts Configuration 2.3//EN"
"http://struts.apache.org/dtds/struts-2.3.dtd">
<struts>
<!-- 主题 -->
<constant name="struts.ui.theme" value="simple" />
<!-- 开发模式 -->
<constant name="struts.devMode" value="true" /> <package name="surveyparkPkg" extends="struts-default" namespace="/">
<interceptors>
<!-- 注冊登陆拦截器 -->
<interceptor name="loginInterceptor" class="com.atguigu.surveypark.struts2.interceptor.LoginInterceptor" />
<!-- 定义拦截器栈 -->
<interceptor-stack name="surveyparkStack">
<interceptor-ref name="loginInterceptor" />
<interceptor-ref name="defaultStack" />
</interceptor-stack>
</interceptors> <!-- 定义默认栈 -->
<default-interceptor-ref name="surveyparkStack" /> <!-- 定义全局结果 -->
<global-results>
<result name="login">/index.jsp</result>
</global-results> <!-- regAction -->
<action name="RegAction_*" class="regAction" method="{1}">
<result name="regPage">/reg.jsp</result>
<result name="input">/reg.jsp</result>
<result name="success">/index.jsp</result>
</action>
<!-- loginAction -->
<action name="LoginAction_*" class="loginAction" method="{1}">
<result name="loginPage">/index.jsp</result>
<result name="input">/index.jsp</result>
<result name="success">/index.jsp</result>
</action> <!-- SurveyAction -->
<action name="SurveyAction_*" class="surveyAction" method="{1}">
<result name="mySurveyListPage">/mySurveyList.jsp</result>
<result name="designSurveyPage">/designSurvey.jsp</result>
</action>
</package>
</struts>

struts2 在拦截器进行注入(依据Action是否实现自己定义接口)的更多相关文章

  1. Struts2默认拦截器栈及内建拦截器使用具体解释

    Struts2内建拦截器介绍:   alias (别名拦截器):同意參数在跨越多个请求时使用不同别名,该拦截器可将多个Action採用不同名字链接起来,然后用于处理同一信息.  autowiring  ...

  2. 简单理解Struts2中拦截器与过滤器的区别及执行顺序

    简单理解Struts2中拦截器与过滤器的区别及执行顺序 当接收到一个httprequest , a) 当外部的httpservletrequest到来时 b) 初始到了servlet容器 传递给一个标 ...

  3. struts2之拦截器

    1. 为什么需要拦截器 早期MVC框架将一些通用操作写死在核心控制器中,致使框架灵活性不足.可扩展性降低, Struts 2将核心功能放到多个拦截器中实现,拦截器可自由选择和组合,增强了灵活性,有利于 ...

  4. 第九篇——Struts2的拦截器

    拦截器: Struts2大多数核心功能都是通过拦截器实现的,每个拦截器完成某项功能: 拦截器方法在Action执行之前或之后执行. 工作原理: 拦截器的执行过程是一个递归的过程 action请求--& ...

  5. Struts2的拦截器是如何使用AOP工作的

    拦截器(interceptor)是Struts2最强大的特性之一,也可以说是struts2的核心,拦截器可以让你在Action和result被执行之前或之后进行一些处理.同时,拦截器也可以让你将通用的 ...

  6. Struts2 利用拦截器 interceptor 控制登陆和访问权限

    最近学习了Struts2的登录和权限控制用到的是拦截器,需要在struts.xml中配置,每个action都默认的继承defaultStack,如果你用了别的拦截器,还需要手动引入defaultSta ...

  7. 谈谈 Struts2 的拦截器

    套话 相信非常多人都用过 Struts2 了,当然,对 Struts2 的原理也都比較了解.之前在一个项目中就已经用到了,当初的理解也不过局限在应用的层面上,对于更深层次的原理.机制,了解的并非非常多 ...

  8. java之struts2之拦截器

    1.struts2能完成数据的设置,数据的封装,数据的类型转换,数据的校验等等.struts2是如何来完成这些功能的?struts2的所有功能都是由拦截器来完成的. 2.拦截器是struts2的核心. ...

  9. 12.Struts2自定义拦截器

    12.自定义拦截器        拦截器是Struts2的一个重要特性.因为Struts2的大多数核心功能都是通过拦截器实现的. 拦截器之所以称之为“拦截器”,是因为它可以拦截Action方法的执行, ...

随机推荐

  1. nodejs+mysql入门实例

    此前我已准备好mysql,使用的是PHP的组合包Appserv 手动添加数据库依赖: 在package.json的dependencies中新增, “mysql” : “latest”, { &quo ...

  2. Mac DBeaver Client home is not specified for connection解决办法

    问题: 一般出现这个问题是由于DBeaver 程序无法自动找到数据库的安装目录,在进行数据的导入导出时无法执行,这是因为执行指令需要数据库相关命令的支持. 解决办法: 我用的是mysql,这里拿mys ...

  3. Javascript中的对象(二)

    Javascript是一种基于原型的对象语言,而不是我们比较熟悉的,像C#语言基于类的面向对象的语言.在前一篇文章中,我们已经介绍了Javascript中对象定义的创建.接下来我们来介绍一下Javas ...

  4. python利用os和getopt实现删除指定文件

    工作中经常遇到要删除某些目录下的特定文件 例如删除xxx目录下的所有test开头文件或者.pyc结尾的文件 如果手动删除的话,很麻烦,写个程序自动删除 只需要运行的时候输入路径和文件名即可,不输入文件 ...

  5. web前端入坑第二篇:web前端到底怎么学?干货资料! 【转】

    http://blog.csdn.net/xllily_11/article/details/52145172 版权声明:本文为博主[小北]原创文章,如要转载请评论回复.个人前端公众号:前端你别闹,J ...

  6. Elastic修改副本数量

    分片的个数在创建之后是无法再增加和减少的,除非你另外建一个索引库,而副本是可以在运行的时候,动态增加和减少.因此,在创建索引库时,规划好分片(Shard)是非常重要的,而在插入大量数据时可以先将副本书 ...

  7. maven工程小红叉处理方法

    搞了个Maven工程在Eclipse上,刚开始说JDK版本不对,编译的时候老报错误,很容易搞明白, 本地JDK版本为1.7.0_79: diamond operator is not supporte ...

  8. [转]JQuery - Sizzle选择器引擎原理分析

    原文: https://segmentfault.com/a/1190000003933990 ---------------------------------------------------- ...

  9. poj 2778 AC自己主动机 + 矩阵高速幂

    // poj 2778 AC自己主动机 + 矩阵高速幂 // // 题目链接: // // http://poj.org/problem?id=2778 // // 解题思路: // // 建立AC自 ...

  10. JDK自带内存及线程分析工具

    转载:http://blog.csdn.net/kimylrong/article/details/50970493 查询.监控.分析Java应用程序的时候,我们关注的点主要集中在资源利用,比如CPU ...