第01步:配置web.xml,启动struts框架

<?xml version="1.0" encoding="UTF-8"?>
<web-app version="2.4"
xmlns="http://java.sun.com/xml/ns/j2ee"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://java.sun.com/xml/ns/j2ee
http://java.sun.com/xml/ns/j2ee/web-app_2_4.xsd"> <filter>
<filter-name>struts2</filter-name>
<filter-class>org.apache.struts2.dispatcher.ng.filter.StrutsPrepareAndExecuteFilter</filter-class>
</filter> <filter-mapping>
<filter-name>struts2</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping> <welcome-file-list>
<welcome-file>index.jsp</welcome-file>
</welcome-file-list>
</web-app>

第02步:编写action类

package com.self.action;

public class InterceptorAction {
private String message ; public String login(){
this.message="登录成功!";
return "success";
} public String addUser(){
this.message="添加用户";
return "success";
} public String getMessage() {
return message;
} public void setMessage(String message) {
this.message = message;
}
}

第03步:编写拦截器类

package com.self.action;

import com.opensymphony.xwork2.ActionContext;
import com.opensymphony.xwork2.ActionInvocation;
import com.opensymphony.xwork2.interceptor.Interceptor;//导入包,包里含有Interceptor类 /**第01 步:编写拦截器**/
public class Permission implements Interceptor { public void destroy() { } public void init() { } public String intercept(ActionInvocation invocation) throws Exception {//属于aop编程的环绕通知
String reString="";
//01:判断用户是否登录,登录就有权限执行action方法,没登陆就没权限
Object user=ActionContext.getContext().getSession().get("user");
if(user!=null){
reString=invocation.invoke();//执行被拦截的action方法,被拦截的action方法有返回的字符串,原样返回
ActionContext.getContext().put("message", "允许执行该操作");
System.out.println("执行拦截的方法,并返回字符串:"+reString);
//return invocation.invoke();可以直接这样
}else{
reString="error";
ActionContext.getContext().put("message", "不允许执行该操作!");
System.out.println("执行拦截的方法,并返回字符串:"+reString);
}
return reString;//原样返回action方法的字符串
} }

第04步:配置struts.xml

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE struts PUBLIC
"-//Apache Software Foundation//DTD Struts Configuration 2.0//EN"
"http://struts.apache.org/dtds/struts-2.0.dtd"> <struts>
<constant name="struts.action.extension" value="do,action"/>
<!-- 第02步:配置action -->
<package name="intercept" namespace="/" extends="struts-default"> <!-- 第03步:注册拦截器 -->
<interceptors>
<!-- 03.1:自定义拦截器配置 -->
<interceptor name="permission" class="com.self.action.Permission" />
<!-- 03.2 :定义拦截器栈,不定义会失去很多struts自身的拦截器-->
<interceptor-stack name="permissionStackss">
<!-- 03.4:引入系统拦截器栈:defaultStack,系统拦截器栈放前面,先执行 -->
<interceptor-ref name="defaultStack"/>
<!-- 03.5:引入自定义拦截器 -->
<interceptor-ref name="permission" />
</interceptor-stack>
</interceptors> <global-results>
<result name="error">
/error.jsp
</result>
</global-results>
<action name="list_*" class="com.self.action.InterceptorAction" method="{1}">
<!-- 03.6:自定义拦截器先执行:"permissionStackss"还是"permissionStacks" -->
<interceptor-ref name="permissionStackss" />
<result name="success">
/show.jsp
</result>
</action>
</package>
</struts>

第05步:编写界面,session有数据,拦截器通过

<%@ page language="java" import="java.util.*" pageEncoding="utf-8"%>
<html>
<head>
</head>
<body>
<%
request.getSession().setAttribute("user", "zouli");
%>
<center>
<a href="list_login.action">用户登录action!</a><BR>
<a href="list_addUser.action">添加用户action!</a><BR>
</center>
<br>
</body>
</html>

第06步:编写界面,session没数据,拦截器不通过

<%@ page language="java" import="java.util.*" pageEncoding="utf-8"%>
<html>
<head>
</head>
<body>
<%
request.getSession().removeAttribute("user");
%>
<center>
没有用户<BR>
<a href="list_login.action">用户登录action!</a><BR>
<a href="list_addUser.action">添加用户action!</a><BR>
</center>
<br>
</body>
</html>

第07步:编写通过显示界面

<%@ page language="java" import="java.util.*" pageEncoding="utf-8"%>
<html>
<head>
</head>
<body>
<center>
登录信息:message:${message }
</center>
<br>
</body>
</html>

第08步:编写不通过错误界面

<%@ page language="java" import="java.util.*" pageEncoding="utf-8"%>
<html>
<head>
</head>
<body>
<center>
拦截信息:message:${message }<BR>
拦截器不能使用错误!
</center>
</body>
</html>

注意:需要导入包

struts自定义拦截器的更多相关文章

  1. Struts自定义拦截器&拦截器工作原理

    0.拦截器的调用原理: 拦截器是一个继承了序列化接口的普通接口.其工作原理是讲需要被拦截的对象作为参数传到intercept()方法内,在方法内部对此对象进行处理之后再执行原方法.intercept( ...

  2. JavaWeb -- Struts 自定义拦截器, 登录权限拦截

    1. 自定义拦截器, 登录权限拦截 login.jsp 登录JSP <%@ page language="java" contentType="text/html; ...

  3. struts自定义拦截器实现

    示例 添加新功能:只有是登录的状态访问hello_loginSuccess才会显示登录成功. index.jsp登录成功页面 test.jsp登录页面 一.修改原代码实现 1.登录后将登录信息添加到S ...

  4. struts自定义拦截器配置

    配置自己的拦截器可以先参照下系统的拦截器是怎么配置的,首先打开struts-default.xml搜索下interceptor:系统里的拦截器有很多,拦截器都是放在堆栈里的,系统引用的是默认堆栈, & ...

  5. [原创]java WEB学习笔记74:Struts2 学习之路--自定义拦截器,struts内建的拦截器

    本博客的目的:①总结自己的学习过程,相当于学习笔记 ②将自己的经验分享给大家,相互学习,互相交流,不可商用 内容难免出现问题,欢迎指正,交流,探讨,可以留言,也可以通过以下方式联系. 本人互联网技术爱 ...

  6. Struts学习之自定义拦截器

    * 所有的拦截器都需要实现Interceptor接口或者继承Interceptor接口的扩展实现类    * 要重写init().intercept().destroy()方法        * in ...

  7. 2018.12.17 struts.xml 配置自定义拦截器配置

    自定义拦截器有三个步骤哦 <?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE struts PU ...

  8. java:struts框架3(自定义拦截器,token令牌,文件上传和下载(单/多))

    1.自定义拦截器: struts.xml: <?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE ...

  9. Struts的拦截器

    Struts的拦截器 1.什么是拦截器 Struts的拦截器和Servlet过滤器类似,在执行Action的execute方法之前,Struts会首先执行Struts.xml中引用的拦截器,在执行完所 ...

随机推荐

  1. 使用Reveal

    添加Reveal.framework,设置Other link flags 添加Debug为 -ObjC,添加 libz 库 这里介绍 Reveal UI 分析工具的简单使用,至于使用他分析手机 Ap ...

  2. Python 汉字简体和繁体的相互转换

    其实利用python实现汉字的简体和繁体相互转早有人做过,并发布到github上了,地址:https://github.com/skydark/nstools/tree/master/zhtools ...

  3. RelativeLayout不能调用measure去直接测量子元素

    RelativeLayout在实现onMeasure方法时并没有像LinearLayout一样去重写如下代码: @Override protected void onMeasure(int width ...

  4. ubuntu下hadoop环境配置

    软件环境: 虚拟机:VMware Workstation 10 操作系统:ubuntu-12.04-desktop-amd64 JAVA版本:jdk-7u55-linux-x64 Hadoop版本:h ...

  5. 单个未知大小图片在div里面垂直居中的方法。。。添加辅助元素挤一下位置达到居中

    单个未知大小图片在div里面垂直居中的方法...添加辅助元素挤一下位置达到居中   <div class="ServicesLiTopPic"> <i>&l ...

  6. Asp.net MVC中Route的理解

    在Asp.net MVC中,对于一个请求,是通过路由找到对应的Controller类中的对应Action,并与model进行交互,最后返回到view. 就是说Asp.net MVC是用Route来定义 ...

  7. Java Binary Tree DFS

    DFS Recursion: public void DFS(TreeNode root){ if(root == null){ return; } System.out.println(root.v ...

  8. 神奇的计算器dc和bc

    神奇的计算器dc和bc Linux就这个范儿 P244http://baike.baidu.com/link?url=YlTtivBfc1tfzreeUQoe8D0C6yqwbZGqnmlObq1hj ...

  9. 第一篇 SQL Server安全概述

    本篇文章是SQL Server安全系列的第一篇,详细内容请参考原文. Relational databases are used in an amazing variety of applicatio ...

  10. RouterOS软路由常用命令

    修改用户密码 [admin@MikroTik]>/user                               #进入操作路径 [admin@MikroTik]/user>prin ...