struts 拦截器

一 拦截器简介及简单的拦截器实例

  Struts2拦截器是在访问某个Action或者Action的某个方法,在字段前或者之后实施拦截,并且Struts2拦截器是可以插拔的,拦截器是AOP的一种实现。

优点:通用功能的封装,提供可重用性。在struts-default.xml文件中可以看到拦截器栈basicStack.我们在引用的时候引用的是默认的拦截器栈 <default-interceptor-ref name=”defaultStack”/>我们写一个拦截器的例子:看一下拦截器是如何运行的,首先我们建立一个HelloAction:

 public class HelloAction extends ActionSupport{
private String name;
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
private static final long serialVersionUID = 1L;
@Override
public String execute() throws Exception {
This.name=”你好,构造器!”;
System.out.println("默认执行了Action的默认方法");
return SUCCESS;
}
}

之后定义我们自己的拦截器MyInterceptor:

 public class Myinterceptor implements Interceptor{
@Override
public void destroy() {
// TODO Auto-generated method stub
System.out.println("拦截器销毁");
}
@Override
public void init() {
// TODO Auto-generated method stub
System.out.println("拦截器初始化");
}
@Override
public String intercept(ActionInvocation invocation) throws Exception {
// TODO Auto-generated method stub
System.out.println("Action之前调用拦截器!");
String result=invocation.invoke();
System.out.println("Action之后调用拦截器!");
return result;
}
}

result能够返回Action默认方法的调用结果。Struts.xml文件中的配置:

 <struts>
<constant name="struts.enable.DynamicMethodInvocation" value="true"></constant>
<package name="manage" namespace="/" extends="struts-default">
<interceptors>
<interceptor
name="myInterceptor" class="com.java1234.Interceptor.Myinterceptor">
</interceptor>
</interceptors>
<global-results>
<result name="error">error.jsp</result>
</global-results>
<action name="hello" class="com.java1234.Action.HelloAction">
<result name="success">success.jsp</result>
<interceptor-ref name="myInterceptor"></interceptor-ref>
<interceptor-ref name="defaultStack"></interceptor-ref>//默认的拦截器是必须的!
</action>
</package>
</struts> 

Success.jsp核心代码:

 <body>
Name:${name }
</body>

error.jsp代码:

 <body>
错误信息:${error } <br/>
</body>

运行结果显示:

① 拦截器首先会被初始化:

②之后访问http://localhost:8080/Struts2Chap04/hello:

先访问的是拦截器Myinterceptor------->接着访问HelloAction--------->访问拦截器,根据result的值为success进行模板页面跳转到success.jsp页面。拦截器Myinterceptor中的String result=invocation.invoke();可以获取到Action执行后的结果!出现结果为:

二 简单的拦截器实例(登录验证拦截器)

  我们有一个简单功能,就是登录验证,对于登录的用户可以直接访问gril.未登录的用户会跳转到错误页面,需要登录才能由此功能!

So,我们开始吧:首先是建一个Model,命名为User:

 public class User {
private String userName;
private String password;
public String getUserName() {
return userName;
}
public void setUserName(String userName) {
this.userName = userName;
}
public String getPassword() {
return password;
}
public void setPassword(String password) {
this.password = password;
}
}

service判断,UserService:

 public class UserService {
public boolean login(User user){
if("java".equals(user.getUserName())&&"123456".equals(user.getPassword())){
return true;
}else{
return false;
}
}
}

UserAction:

 public class UserAction extends ActionSupport{
private User user;
private UserService userService=new UserService();
private String error;
public User getUser() {
return user;
}
public void setUser(User user) {
this.user = user;
}
public String getError() {
return error;
}
public void setError(String error) {
this.error = error;
}
private static final long serialVersionUID = 1L;
@Override
public String execute() throws Exception {
// TODO Auto-generated method stub
if(userService.login(user)){
ActionContext actionContext=ActionContext.getContext();
Map<String, Object>session=actionContext.getSession();
session.put("currentUser", user);
return SUCCESS;
}else{
this.error="用户名或者密码错误";
return "error";
}
}
}

配置struts.xml文件:

 <struts>
<constant name="struts.enable.DynamicMethodInvocation" value="true"></constant>
<package name="manage" namespace="/" extends="struts-default">
<interceptors>
<interceptor name="loginInterceptor" class="com.java1234.Interceptor.Logininterceptor">
</interceptor>
<interceptor-stack name="mystack">
<interceptor-ref name="loginInterceptor"></interceptor-ref>
<interceptor-ref name="defaultStack"></interceptor-ref>
</interceptor-stack>
</interceptors> <default-interceptor-ref name="mystack"></default-interceptor-ref>   方法2 直接引用拦截器栈 可以省去<interceptor-ref name="loginInterceptor"></interceptor-ref> <interceptor-ref name="defaultStack"></interceptor-ref>这部分代码。
 <global-results>
<result name="error">error.jsp</result>
</global-results>
<action name="user" class="com.java1234.Action.UserAction">
<result name="success">success.jsp</result>
<interceptor-ref name="defaultStack"></interceptor-ref>
</action>
<action name="gril" class="com.java1234.Action.GrilAction">
<result name="success">success.jsp</result>
<interceptor-ref name="loginInterceptor"></interceptor-ref>
<interceptor-ref name="defaultStack"></interceptor-ref>

        方法1 直接引用各个拦截器。直接明了

 </action>
</package>
</struts>

Success.jsp文件:

 <body>
当前登录的用户为:${currentUser.userName }
</body>

error.jsp文件

 <body>
错误信息:${error } <br/>
<a href="login.jsp">登录</a>
</body>

Login.jsp文件:

 <body>
<form action="user" method="post">
用户名:<input type="text" name="user.userName">&nbsp;&nbsp;
密 码:<input type="password" name="user.password"><br/>
<input type="submit" value="登录">
</form>
</body>

根据前端 http://localhost:8080/Struts2Chap04/login.jsp 显示页面:

输入应户名和密码。这个时候利用user请求,先经过默认拦截器的拦截验证,之后根据action=user,strut.xml文件中的配置action=user 由类UserAction处理 UserAction通过调用UserService来进行登录判断,进而确定是否登录成功?以下两种情况:

①用户名为java 密码为 123456 登录成功,跳转到success.jsp,显示登录结果!

②用户名或者密码错误,登录失败,跳转到error.jsp页面。

GrilAction代码:

 public class GrilAction extends ActionSupport{
private static final long serialVersionUID = 1L;
@Override
public String execute() throws Exception {
// TODO Auto-generated method stub
System.out.println("看美女!");
return SUCCESS;
}
}

如果在前端输入http://localhost:8080/Struts2Chap04/gril ,会先进行拦截器的判断,进入到Logininterceptor拦截器的拦截判断中,

第一步:进入intercept方法。获取到actionContext,之后利用actionContext获取session,之后利用session获取当前用户,根据当前用户是否为空做出以下两个选择:

①currentUser不为空,那么就是说明已经登录了,可以直接进行访问,所以这个时候进入到GrilAction中进行访问。

②currentUser为空,那么就是说明没有登录,就不能直接访问了,这个时候我们获取到request,利用request设置error,并且传递到前端,result设置为error。之后struts.xml根据result进行处理。

核心代码如下:

 ActionContext actionContext=invocation.getInvocationContext();
Map<String, Object> session=actionContext.getSession();
Object currentUser=session.get("currentUser");
String result=null;
if(currentUser!=null){
result=invocation.invoke();
}else{
HttpServletRequest request=(HttpServletRequest)invocation.getInvocationContext().get(ServletActionContext.HTTP_REQUEST);
request.setAttribute("error", "您未登录,请先登录!");
result="error";
}

拦截器先告一段落,我们还会回来的!

Struts2牛逼的拦截器,卧槽这才是最牛的核心!的更多相关文章

  1. Struts2基础学习(五)—拦截器

    一.概述 1.初识拦截器      Interceptor 拦截器类似前面学过的过滤器,是可以在action执行前后执行的代码,是我们做Web开发经常用到的技术.比如:权限控制.日志等.我们也可以将多 ...

  2. 【struts2】预定义拦截器

    1)预定义拦截器 Struts2有默认的拦截器配置,也就是说,虽然我们没有主动去配置任何关于拦截器的东西,但是Struts2会使用默认引用的拦截器.由于Struts2的默认拦截器声明和引用都在这个St ...

  3. Struts2 源码分析-----拦截器源码解析 --- ParametersInterceptor

    ParametersInterceptor拦截器其主要功能是把ActionContext中的请求参数设置到ValueStack中,如果栈顶是当前Action则把请求参数设置到了Action中,如果栈顶 ...

  4. 使用struts2中默认的拦截器以及自定义拦截器

    转自:http://blog.sina.com.cn/s/blog_82f01d350101echs.html 如何使用struts2拦截器,或者自定义拦截器.特别注意,在使用拦截器的时候,在Acti ...

  5. Struts2入门(二)——配置拦截器

    一.前言 之前便了解过,Struts 2的核心控制器是一个Filter过滤器,负责拦截所有的用户请求,当用户请求发送过来时,会去检测struts.xml是否存在这个action,如果存在,服务器便会自 ...

  6. 【Java EE 学习 69 上】【struts2】【paramsPrepareParamsStack拦截器栈解决model对象和属性赋值冲突问题】

    昨天有同学问我问题,他告诉我他的Action中的一个属性明明提供了get/set方法,但是在方法中却获取不到表单中传递过来的值.代码如下(简化后的代码) public class UserAction ...

  7. Struts2 源码分析——拦截器的机制

    本章简言 上一章讲到关于action代理类的工作.即是如何去找对应的action配置信息,并执行action类的实例.而这一章笔者将讲到在执行action需要用到的拦截器.为什么要讲拦截器呢?可以这样 ...

  8. Struts2学习笔记(拦截器配置添加)

    一.拦截器工作原理: 根据Struts2的工作原理图,拦截器在action执行前进行顺序调用,之后执行Action并返回结果字符串,再逆序调用拦截器.(结构类似递归方式...)大部分时候,拦截器方法都 ...

  9. Struts2之过滤器和拦截器的区别

    刚学习Struts2这个框架不久,心中依然有一个疑惑未解那就是过滤器和拦截器的区别,相信也有不少人跟我一样对于这个问题没有太多的深入了解 那么下面我们就一起来探讨探讨 过滤器,是在java web中, ...

随机推荐

  1. java第十次作业:oop的第6张图片到第11张图片

  2. 使用CSS来制作类似「黑幕」的效果

    网上几乎没有看到这类的代码,留个档 .heimu,.heimu a{ background-color: #252525; color:#252525; text-shadow: none; }::s ...

  3. Vue开发微信公众号默认背景为灰色

    最近公司有一个项目,使用Vue开发微信公众号,开发过程遇到一个问题,即设计图的整体背景是白色的,但是公众号里默认的背景是浅灰色,如果某个页面高度没能占满一屏,就会露出浅灰色的默认背景,会显得很不协调. ...

  4. 2018 CCF NOIP提高组&&普及组答案

    答案: 这是今年的答案大家觉得能进到复赛吗? 下一篇文章将会为大家推荐我自己出的复赛题!!!

  5. mbist summary

    1. 关于mbist,网上也有介绍,觉得不错: 推荐的mbistt的博客:奋斗的猪 2.使用的工具是mbistarchitect,不是tessent. 3.工具使用的相关文档:从EETOP和工具自带的 ...

  6. perl学习之:编译、执行与内存关系(转)

    1.所谓在编译期间分配空间指的是静态分配空间(相对于用new动态申请空间),如全局变量或静态变量(包括一些复杂类型的 常量),它们所需要的空间大小可以明确计算出来,并且不会再改变,因此它们可以直接存放 ...

  7. redis 散列学习要点记录

    散列类型键值也是种字典结构,存储了字段和字段值的映射,字段值只能是字符串,不可以是其他类型(redis数据类型都不可嵌套使用其他类型),散列类型键可以有2的32次方减1个字段 散列的命令组  hset ...

  8. (转)浅谈测试驱动开发(TDD)

    测试驱动开发(TDD)是极限编程的重要特点,它以不断的测试推动代码的开发,既简化了代码,又保证了软件质量.本文从开发人员使用的角度,介绍了 TDD 优势.原理.过程.原则.测试技术.Tips 等方面. ...

  9. Lex与Yacc学习(五)之正则表达式篇

    正则表达式语法 lex模式是由编辑程序和实用程序使用的正则表达式的扩展版本.正则表达式由常规字符(代表它们本身)和元字符(在一种模式中具有特殊含义)组成. 元字符 . . 匹配除了换行符 \n 之外的 ...

  10. lombok安装、配置、使用

    eclipse安装Lombok 运行安装: java -jar ${path}\lombok.jar 选择IDE所在路径点击Install/Update即可使用. 手动安装1. 将lombok.jar ...