使用Acegi 1.0获取用户信息

使用Acegi 1.0获取用户信息

java 代码
  1. import org.acegisecurity.Authentication;   
  2. import org.acegisecurity.context.SecurityContext;   
  3. import org.acegisecurity.context.SecurityContextHolder;   
  4. import org.acegisecurity.ui.WebAuthenticationDetails;   
  5. import org.acegisecurity.userdetails.UserDetails;   
  6.   
  7. public class ThreadLocaTest {   
  8.   
  9.     /** */  
  10.     /**  
  11.      * 取得当前用户名  
  12.      *   
  13.      */  
  14.     public static String getUsername() {   
  15.         SecurityContext ctx = SecurityContextHolder.getContext();   
  16.         if (ctx != null) {   
  17.             Authentication auth = ctx.getAuthentication();   
  18.             if (auth != null) {   
  19.                 Object principal = auth.getPrincipal();   
  20.                 if (principal instanceof UserDetails) {   
  21.                     return ((UserDetails) principal).getUsername();   
  22.                 } else {   
  23.                     return principal.toString();   
  24.                 }   
  25.             }   
  26.         }   
  27.         return null;   
  28.     }   
  29.   
  30.     /** */  
  31.     /**  
  32.      * 取得当前用户密码  
  33.      *   
  34.      */  
  35.     public static String getPassword() {   
  36.         SecurityContext ctx = SecurityContextHolder.getContext();   
  37.         if (ctx != null) {   
  38.             Authentication auth = ctx.getAuthentication();   
  39.             if (auth != null) {   
  40.                 Object principal = auth.getPrincipal();   
  41.                 if (principal instanceof UserDetails) {   
  42.                     return ((UserDetails) principal).getPassword();   
  43.                 } else {   
  44.                     return null;   
  45.                 }   
  46.             }   
  47.   
  48.         }   
  49.         return null;   
  50.     }   
  51.   
  52.     /** */  
  53.     /**  
  54.      * 取得当前用户SessionId  
  55.      *   
  56.      */  
  57.     public static String getSessionID() {   
  58.         SecurityContext ctx = SecurityContextHolder.getContext();   
  59.         if (ctx != null) {   
  60.             if (ctx instanceof SecurityContext) {   
  61.                 SecurityContext sc = (SecurityContext) ctx;   
  62.                 Authentication auth = sc.getAuthentication();   
  63.                 if (auth != null) {   
  64.                     Object details = auth.getDetails();   
  65.                     if (details instanceof WebAuthenticationDetails) {   
  66.                         return ((WebAuthenticationDetails) details)   
  67.                                 .getSessionId();   
  68.                     } else {   
  69.                         return null;   
  70.                     }   
  71.                 }   
  72.             }   
  73.         }   
  74.         return null;   
  75.     }   
  76. }  
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值