spring aop action中验证用户登录状态的实例代码
作者:后台菜狗子 发布时间:2021-12-04 19:47:01
标签:spring,aop,登录验证
最近在学习ssh框架时,照着网上做了一个商城系统,之前在一些需要用户存在的操作中,都是在每一个action中写重复的代码,这样做现在想起来并不好,想起了spring的aop,于是想通过aop来给每个需要用户操作的Action验证用户登录状态。
想法是这样的:
1. 用户登录时把userId放入session中
2. 通过spring 写一个advice来获取session中的userId,判断用户登录状态,如果userId不符合,则抛出自定义异常
3. 通过struts中配置来捕获异常,跳转界面
以下是代码:
advice代码:
public class IsUserLoginAdvice{
public void isUserLogin() throws UserNotFoundException{
// TODO Auto-generated method stub
int id=0;
Map sessionMap=ActionContext.getContext().getSession();
System.out.println(sessionMap);
try {
//这里在一开始时userId是不存在的可能会抛出NullPointException,catch起来
id=(int) sessionMap.get("userId");
//在用户注销时我把session中的userId设为0
if(id==0){
throw new UserNotFoundException();
}
} catch (Exception e) {
// TODO Auto-generated catch block
e.printStackTrace();
throw new UserNotFoundException();
}
}
}
struts.xml:
这里通过全局异常映射来处理这个异常:
<package name="struts-global" namespace="/" extends="struts-default">
<global-results>
<result name="userNotFound">/web_resource/error_jsp/user_not_found.jsp
</result>
</global-results>
<global-exception-mappings>
<exception-mapping result="userNotFound" exception="com.lsj.market.exception.UserNotFoundException"></exception-mapping>
</global-exception-mappings>
</package>
全局异常有个name属性,给那些想要共享该异常捕获的package继承,这样就可以共享该异常捕获行为:
<package name="com.lsj.market.action.user" extends="struts-global">
applicationContext.xml:
<!-- aop设置 -->
<aop:config proxy-target-class="true">
<aop:aspect ref="isUserLoginAdvice">
<aop:pointcut id="isUserLoginPointcut"
expression="execution (* com.lsj.market.action..GetUser*.*(..))
or execution (* com.lsj.market.action..*Update*Action*.*(..))
or execution (* com.lsj.market.action..*Delete*Action*.*(..))
or execution (* com.lsj.market.action..GetMarketCar*.*(..))
or execution (* com.lsj.market.action..MarketCar*.*(..))
or execution (* com.lsj.market.action..ToFlower*.*(..))
or execution (* com.lsj.market.action..Flower*Add*.*(..))"/>
<aop:before method="isUserLogin" pointcut-ref="isUserLoginPointcut"/>
</aop:aspect>
</aop:config>
<!-- 声明advice Bean -->
<bean id="isUserLoginAdvice" class="com.lsj.market.aop.IsUserLoginAdvice"></bean>
其中pointcut可以通过or 来连接多个切入点,这里有这么多切入点是因为第一次做,没想到用aop,各个Action的命名没有考虑太多,导致现在必须配置这么多个切入点表达式- -!!!
还有一个,如果struts交由spring管理时,即struts.xml中配置了这一句:
<constant name="struts.objectFactory" value="spring" />
在生成代理类时会发生错误,无法捕捉到抛出的异常,在网上查了后发现需要在struts.xml加入这一句,struts就可以捕捉到该异常了:
<!-- 总是确保使用spring的自动装备策略 -->
<constant name="struts.objectFactory.spring.autoWire.alwaysRespect" value="true" />
刚刚还想删除这一句配置后把异常发上来,但是发现删除后居然还可以运行?!
算了还是写上来,以后遇到这个问题,还可以看一下博客。
来源:http://blog.csdn.net/caser_hdmi/article/details/75205783
0
投稿
猜你喜欢
- 一、前言最近在回顾数据结构与算法,有部分的算法题用到了栈的思想,说起栈又不得不说链表了。数组和链表都是线性存储结构的基础,栈和队列都是线性存
- 前言Docker旨在提供一种应用程序的自动化部署解决方案,在 Linux 系统上迅速创建一个容器(轻量级虚拟机)并部署和运行应用程序,并通过
- 在页面显示的时候,有时候文字无法显示完全,就只能显示部分文字,但是直接截取就只能截取等长字符串,英文和中文很难处理所以就写了下面方法,截取等
- 一、解决方案1声明:jdk1.8已经经过线上环境使用1. 调研JDK8的加密策略存在限制版本和无限制版本,随着越来越多的第三方工具只支持 J
- 何为原子性原子性:一条线程在执行一系列程序指令操作时,该线程不可中断。一旦出现中断,那么就可能会导致程序执行前后的结果不一致。与数据库中的原
- 前言先放一个官网吧,其实本案例就是根据官网案例来的,只是进行了修改配置。Mybatis-plus官网一、搭建一个springboot项目&n
- ✨字符, 字节与字符串🎈字符与字符串字符串内部包含一个字符数组,String 可以和 char[] 相互转换.NO方法名称类型描述1publ
- 1.map遍历快速实现边距,文字自适应改变大小Container( // padding: EdgeI
- 目录创建线程管理线程销毁线程创建线程线程是通过扩展 Thread 类创建的。扩展的 Thread 类调用 Start() 方法来开
- 本文实例讲述了C#滚动字幕的实现方法,分享给大家供大家参考。具体方法如下:在c#中其实滚动屏幕的实现其实很简单,只需要用到Graphics.
- 第一部分:Java数据结构要理解Java数据结构,必须能清楚何为数据结构?数据结构:Data_Structure,它是储存数据的一种结构体,
- 本文实例讲述了Android判断网络类型的方法。分享给大家供大家参考,具体如下:判断网络类型是wifi,还是3G,还是2G网络,对不同的网络
- 在本篇中我要介绍两个概念,我觉得这两个东西必须一起来介绍,这样才能连贯。C# 2.0里我们已经匿名方法了,现在类型也玩起匿名来了,怪不得大家
- 一、加密方案介绍对接口的加密解密操作主要有下面两种方式:自定义消息转换器优势:仅需实现接口,配置简单。劣势:仅能对同一类型的MediaTyp
- 今天看《第一行代码》上面关于拍照和从相册选取图片那一部分,发现始终出不来效果,所以搜索其他资料学习一下相关知识,写一个简单的Demo。&nb
- 前言为什么Spring Boot 定时任务是单线程的?想要解释为什么,一定要从源码入手,直接从@EnableScheduling这个注解入手
- 在Web开发过程中离不开数据的交互,这就需要规定交互数据的相关格式,以便数据在客户端与服务器之间进行传递。数据的格式通常有2种:1、xml;
- 本文实例实现一个如下图所示的Android自定义控件,可以直观地展示某个球队在某个赛季的积分数和胜场、负场、平局数首先对画布进行区域划分,整
- 开发环境 android studio 3.0.1 已支持 kotlin1、定义接口interface CallBack{ fun call
- JAVA源码编译由三个过程组成:1、源码编译机制。2、类加载机制3、类执行机制我们这里主要介绍编译和类加载这两种机制。一、源码编译代码编译由