Struts拦截器实现拦截未登陆用户实例解析
时间:2019-04-13
本文章向大家介绍Struts拦截器实现拦截未登陆用户实例解析,主要包括Struts拦截器实现拦截未登陆用户实例解析使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
本文研究的主要是Struts拦截器实现拦截未登陆用户,具体实现如下。
首先建立一个工具类:
checkPrivilegeInterceptor:这个类继承interceptor,这是一个接口,要实现三个方法,要是觉得比较多的话,可以继承他的实现类AbstractInterceptor,继承这个类以后只需要重写一个方法,就是在这个方法里面控制,是否登录,登录以后有哪些权限,等等,代码如下;
package com.cjdx.utils; import javax.annotation.Resource; import org.hibernate.Session; import org.hibernate.SessionFactory; import com.cjdx.domain.User; import com.opensymphony.xwork2.ActionContext; import com.opensymphony.xwork2.ActionInvocation; import com.opensymphony.xwork2.interceptor.AbstractInterceptor; //检查是否有权限,这里只检查知否登录 public class CheckPrivilegeInterceptor extends AbstractInterceptor { @Override public String intercept(ActionInvocation invocation) throws Exception { User user = (User) ActionContext.getContext().getSession().get("user"); String nameSpace = invocation.getProxy().getNamespace(); String actionName = invocation.getProxy().getActionName(); String privilegeUrl = nameSpace + actionName; if (user == null) { // 如果用户没有登录 if (privilegeUrl.startsWith("/user_login")) { //如果用户准备去登录,则放行 return invocation.invoke(); } { return "loginUI"; //如果用户不是去登录,又没有登录,则转到登录页面 } } else { return invocation.invoke(); //如果用户已经登录,则执行相应的方法 } } }
然后再配置struts2.xml里:
<!-- 登录拦截器的声明 --> <interceptors> <!-- 声明你已经写好的拦截器 --> <interceptor name="checkPrivilege" class="com.cjdx.utils.CheckPrivilegeInterceptor"></interceptor> <!-- 将已经声明的拦截器加到默认的拦截器里面去 --> <!-- 这个拦截器的名字就叫做defaultStack,这样就直接覆盖了原来的defaultStack --> <!-- 如果不这样写,还可以在像注释这样添加 --> <interceptor-stack name="defaultStack"> <interceptor-ref name="checkPrivilege"></interceptor-ref> <interceptor-ref name="defaultStack"></interceptor-ref> </interceptor-stack> <!-- <interceptor-stack name="myStack"> <interceptor-ref name="checkPrivilege"></interceptor-ref> <interceptor-ref name="defaultStack"></interceptor-ref> </interceptor-stack> <interceptor-stack name="defaultStack"> <interceptor-ref name="myStack"></interceptor-ref> </interceptor-stack> --> </interceptors>
总结
以上就是本文关于Struts拦截器实现拦截未登陆用户实例解析的全部内容,希望对大家有所帮助。感兴趣的朋友可以继续参阅本站其他相关专题,如有不足之处,欢迎留言指出。感谢朋友们对本站的支持!
- 一个简单的案例带你入门Dubbo分布式框架
- Ajax上传图片以及上传之前先预览
- Spring Cloud中Hystrix的服务降级与异常处理
- Open vSwitch源码解析之基于VxLAN实现NSH解析功能
- Spring Cloud自定义Hystrix请求命令
- JavaScript面试问题:事件委托和this
- Spring Cloud中的断路器Hystrix
- js的隐含参数(arguments,callee,caller)使用方法
- Spring Cloud中的负载均衡策略
- Spring Cloud中负载均衡器概览
- 没有event loop的PHP
- RestTemplate的逆袭之路,从发送请求到负载均衡
- limit_area_cirle
- Spring RestTemplate中几种常见的请求方式
- java教程
- Java快速入门
- Java 开发环境配置
- Java基本语法
- Java 对象和类
- Java 基本数据类型
- Java 变量类型
- Java 修饰符
- Java 运算符
- Java 循环结构
- Java 分支结构
- Java Number类
- Java Character类
- Java String类
- Java StringBuffer和StringBuilder类
- Java 数组
- Java 日期时间
- Java 正则表达式
- Java 方法
- Java 流(Stream)、文件(File)和IO
- Java 异常处理
- Java 继承
- Java 重写(Override)与重载(Overload)
- Java 多态
- Java 抽象类
- Java 封装
- Java 接口
- Java 包(package)
- Java 数据结构
- Java 集合框架
- Java 泛型
- Java 序列化
- Java 网络编程
- Java 发送邮件
- Java 多线程编程
- Java Applet基础
- Java 文档注释
- IntelliJ IDEA 2020.2重磅发布!全面支持Github PR。真香版本?
- 腾讯云智能语音小程序插件实现实时语音识别
- 我还在生产玩 JDK7,JDK 15 却要来了!|新特性尝鲜
- 36个助你成为专家需要掌握的JavaScript概念
- Bulehero 蠕虫病毒安全分析报告
- 一句话加速grep近30倍
- 正道的光!这有个用TensorFlow做的小黄图过滤器
- Bytom侧链Vapor源码浅析-节点出块过程
- Logstash: 启动监控及集中管理
- 渗透测试中文件上传技巧
- PHP常见过WAF webshell及最简单检测方法
- 基于PhantomJS的动态爬虫引擎
- XSS Cheat Sheet
- 免费代理池的实现与优化
- 基于Django和clean-blog前端框架的博客系统