JAAS 基本概念 (1/3)

news/2025/2/26 6:52:45

JAAS ( Java Authentication and Authorization Services )
簡單來說就是專門處理 身份驗證 ( authentication ) 及 權限管控 ( authorization ) 的標準服務
目前已經納入 j2sdk 1.4 正式成為標準的安全性模組

主要的幾個元件有分為 通用性 ( common ), 身份驗證 ( authentication ) 及 權限管控 ( authorziation ).

  • 通用性
    • Subject
    • Principal
    • Credential
  • 身份驗證
    • LoginContext
    • LoginModule
    • CallbackHandler
    • Callback
  • 權限管控
    • Policy
    • AuthPermission
    • PrivateCredentialPermission

而 Subject 是整個 JAAS Framework 的核心

他的宣告方式是

---------------------------------

    public Subject();

    public Subject(boolean readOnly, Set principals,
                   Set pubCredentials, Set privCredentials);
---------------------------------

可以看到 Subject 之中包含了數個 principals, pubCredentials, 及 privCredentials.

在身份驗證通過的同時, LoginContext 就會存在著 Subject

 LoginContext lc = new LoginContext("SL", new SLCallbackHandler());
  lc.login();
  PrivilegedExceptionAction action = new PrivilegedExceptionAction() {
   public Object run() throws Exception{
       // do something
   }
  };
  Subject.doAs(lc.getSubject(), action);

 

我們可以使用 lc.getSubject() 取得目前的 subject

及透過 Subject.doAs 或 Subject.doAsPrivileged 處理是否執行該 action.

這兩個 method 差異是是否為同一個 thread 需要參考同一份 AccessControlContext .

而 Principal 是需要實作 java.security.Principal 及 java.io.Seriallizable.

簡單的範例如下

public class SamplePrincipal implements java.security.Principal,java.io.Serializable {

    private String name;
    public SamplePrincipal(String name) {
     if (name == null)
         throw new NullPointerException("illegal null input");
     this.name = name;
    }
    public String getName() {
       return name;
    }
    public String toString() {
       return("SamplePrincipal:  " + name);
    }
    public boolean equals(Object o) {
        if (o == null)
          return false;
        if (this == o)
            return true;
 
        if (!(o instanceof SamplePrincipal))
            return false;
       
        SamplePrincipal that = (SamplePrincipal)o;
        if (this.getName().equals(that.getName()))
            return true;
       

        return false;
    }
 
    public int hashCode() {
        return name.hashCode();
    }
}

> next one : JAAS 身份驗證 (2/3)

 





http://www.niftyadmin.cn/n/3653796.html

相关文章

web.xml 中的 security-role 的運作剖析

如果在 tomcat 之上執行程式你撰寫的 security-role 到底有沒有用呢 ?當呼叫 isUserInRole 其實是去呼叫 RealmBase 中的 hasRole 透過 GenericPrincipal 去檢查GenericPrincipal gp (GenericPrincipal) principal;boolean result gp.hasRole(role);return result;而 Princi…

MySQL 行列转换变化各种方法实现总结(行变列报表统计 列变行数据记录统计等)

前言:mysql行列变化,最难的就是将多个列变成多行,使用的比较多的是统计学中行变列,列变行,没有找到现成的函数或者语句,所以自己写了存储过程,使用动态sql来实现,应用业务场景&#…

JavaTWO 2004 in taiwan 紀事

舊金山有 JavaONE, 台灣有 JavaTWO雖然沒有 JavaONE 來自各地先驅名流聚集, 但是台灣的 Java 界同好也都有到場互動第一天的早上, 是由台灣昇陽主持, 相關的一些未來發展與介紹, 包括 Motorala, Mac, Nokia 等等的國際大廠一起為 Java 大力推廣與前幾屆不同的地方, 這次加入了 …

Servlet Security 的缺憾 -- request.getUserSubject()

此篇詳細討論在 http://www.javaworld.com.tw/jute/post/view?bid5&id63394&tpg1&ppg1&sty1&age1#63394smallufo 對於我在 javatwo 演講的 j2ee security 很不滿意因為我只有簡略地帶過 JAAS.所以提出了相關的問題與討論在 JavaWorld Taiwan 之中很高興和…

zabbix3 0 监控mysql服务免用户名密码登录的问题故障处理详细过程

1,My.cnf中用户名密码无效在azure云上面,使用Zabbix监控mysql中,发现在/usr/local/mysql/my.cnf里面设置的默认用户名密码无效,出不来数据,而且在zabbix服务器上,使用zabbix_get也报错failed,如…

Git学习 -- 个人常用命令add commit以及push

Git命令行配置1 安装Github2 安装msysgit3 要配置用户名和油箱git config --global user.name <用户名>我的命令就是&#xff1a;git config --global user.name mchdbaghgit config --global user.email <油箱>我的命令就是&#xff1a;git config --global mchdb…

4th Asia Opensource Symposium in Taipei Howard

活動的首頁是 http://www.nii.org.tw/cnt/ecnews/activity/aoss/ 9/1 晚上 ..我到場的時候 已經是晚上 6:30 了因為整天都在客戶那兒處理一些有的沒的資料進入了福華之後, 在中庭的地方,就是 4th AOSS 的晚宴的所在進場的時候 和 中研院的專案經理 寒喧了一下帶我到 資訊研究所…

commons-beanutils 1.7 新增的 LazyDynaBean

commons-beanutils 除了增加一些 Exception 處理外, 還包含了一個新的東西, 那就是 LazyDynaBean.. 所謂 Lazy, 就是懶人寫 DynaBean 的方法, 簡化了 DynaBean 要先寫 DynaProperty 的設定值, 我們可以完全不用去宣告他原本的預設值, 只要直接把值放進去就可以了. 在 commons-b…