安全实例 : Spring面向方面 « Spring « Java

En
Java
1. 图形用户界面
2. 三维图形动画
3. 高级图形
4. 蚂蚁编译
5. Apache类库
6. 统计图
7. 
8. 集合数据结构
9. 数据类型
10. 数据库JDBC
11. 设计模式
12. 开发相关类
13. EJB3
14. 电子邮件
15. 事件
16. 文件输入输出
17. 游戏
18. 泛型
19. GWT
20. Hibernate
21. 本地化
22. J2EE平台
23. 基于J2ME
24. JDK-6
25. JNDI的LDAP
26. JPA
27. JSP技术
28. JSTL
29. 语言基础知识
30. 网络协议
31. PDF格式RTF格式
32. 映射
33. 常规表达式
34. 脚本
35. 安全
36. Servlets
37. Spring
38. Swing组件
39. 图形用户界面
40. SWT-JFace-Eclipse
41. 线程
42. 应用程序
43. Velocity
44. Web服务SOA
45. 可扩展标记语言
Java 教程
Java » Spring » Spring面向方面屏幕截图 
安全实例


/*
Pro Spring
By Rob Harrop
Jan Machacek
ISBN: 1-59059-461-4
Publisher: Apress
*/



///////////////////////////////////////////////////////////////////////////////////////
class UserInfo {
    private String userName;

    private String password;

    public UserInfo(String userName, String password) {
        this.userName = userName;
        this.password = password;
    }
    
    public String getPassword() {
        return password;
    }
    public String getUserName() {
        return userName;
    }
}

///////////////////////////////////////////////////////////////////////////////////////
public class SecureBean {

    public void writeSecureMessage() {
        System.out.println("Every time I learn something new, "
                "it pushes some old stuff out my brain");
    }
}

///////////////////////////////////////////////////////////////////////////////////////

import java.lang.reflect.Method;

import org.springframework.aop.MethodBeforeAdvice;

public class SecurityAdvice implements MethodBeforeAdvice {

    private SecurityManager securityManager;

    public SecurityAdvice() {
        this.securityManager = new SecurityManager();
    }

    public void before(Method method, Object[] args, Object target)
            throws Throwable {
        UserInfo user = securityManager.getLoggedOnUser();

        if (user == null) {
            System.out.println("No user authenticated");
            throw new SecurityException(
                    "You must login before attempting to invoke the method: "
                            + method.getName());
        else if ("robh".equals(user.getUserName())) {
            System.out.println("Logged in user is robh - OKAY!");
        else {
            System.out.println("Logged in user is " + user.getUserName()
                    " NOT GOOD :(");
            throw new SecurityException("User " + user.getUserName()
                    " is not allowed access to method " + method.getName());
        }

    }
}

///////////////////////////////////////////////////////////////////////////////////////
public class SecurityManager {

    private static ThreadLocal threadLocal = new ThreadLocal();

    public void login(String userName, String password) {
        // assumes that all credentials
        // are valid for a login
        threadLocal.set(new UserInfo(userName, password));
    }

    public void logout() {
        threadLocal.set(null);
        int x = 0;
    }

    public UserInfo getLoggedOnUser() {
        return (UserInfothreadLocal.get();
    }
}

///////////////////////////////////////////////////////////////////////////////////////


import org.springframework.aop.framework.ProxyFactory;

public class SecurityExample {

    public static void main(String[] args) {
        // get the security manager
        SecurityManager mgr = new SecurityManager();
        
        // get the bean
        SecureBean bean = getSecureBean();

        // try as robh
        mgr.login("robh""pwd");
        bean.writeSecureMessage();
        mgr.logout();
        
        // try as janm
        try {
            mgr.login("janm""pwd");
            bean.writeSecureMessage();
        catch(SecurityException ex) {
            System.out.println("Exception Caught: " + ex.getMessage());
        finally {
            mgr.logout();
        }
        
        // try with no credentials
        try {
            bean.writeSecureMessage();
        catch(SecurityException ex) {
            System.out.println("Exception Caught: " + ex.getMessage());
        }

    }
    
    private static SecureBean getSecureBean() {
        // create the target
        SecureBean target = new SecureBean();

        // create the advice
        SecurityAdvice advice = new SecurityAdvice();
        
        // get the proxy
        ProxyFactory factory = new ProxyFactory();
        factory.setTarget(target);
        factory.addAdvice(advice);
        SecureBean proxy = (SecureBean)factory.getProxy();
        
        return proxy;
        
    }
}

           
       
SecurityExample.zip( 1,481 k)
Related examples in the same category
1. 剖面实例
2. 导言配置实例
3. Simple After Returning Advice
4. Simple Before Advice
5. Simple Throws Advice
6. 组合切入点实例
7. 控制流实例
8. Dynamic Pointcut Example
9. 您好世界切入点
10. Spring宽介绍范例
11. 静态切入点范例
12. 姓名切入点范例
13. 姓名切入点使用顾问
14. 代理长组件范例
15. 代理服务器性能测试
16. Regexp切入点范例
17. 经过咨询范例
18. AspectJ Example from Pro Spring
19. 纵横世界您好实例
www.java2java.com | Contact Us
Copyright 2010 - 2030 Java Source and Support. All rights reserved.
All other trademarks are property of their respective owners.