JAAS 基本概念 (1/3)

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)

 




  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值