• siteminder sso agent 初探


    公司一直用weblogic开发,CA有现成的sso agent for weblogic,只需要简单封装即可,主要是通过filter+serevlet来实现的。

    后来又有了sso agent from jboss,自己也设想一下tomcat/jetty 替换weblogic 来作为web server,所以考虑custom sso agent for web container的开发.


     大致的设计架构:

    • 组件1:authenticator/filter:可以支持cross domain,cookie,form
    • 组件2:loginModule/Provider:包括Identity 和Form 个独立组件
    • tomcat 使用 jaas(sso realm + form realm) + authenticator来实现
    • jetty 使用 jass(sso realm _+ realm )+ authenticator来实现
    • sso realm 和 form realm 都是标准的jaas实现,tomcat 和jetty 分别继承自身的FormAuthenticator来扩展.

     认证流程处理:

    a.SSO跨域
      需要配置siteminder 的cookie provider,用于生成cookie和SESSION,以便于不同域cookie生成的桥梁;
      .判断请求是否已经认证过,如何认证过直接通过。
      .如果是登陆请求j_security_check,使用SMSSION来登陆,如果通过,realm 认证(获取权限role);认证成功,跳转到cookieprovider(生成cookieprovider domain的cookie或smsession);如何认证成功,结束。
      .使用SSO Cookie登陆,如果通过,realm认证;认证成功,跳转到cookieprovider(生成cookieprovider domain的cookie或smsession);如果认证成功,结束
      .跳转到登陆页面.
      
    b.SSO同域
      .判断请求是否已经认证过,如何认证过直接通过。
      .如果是登陆请求j_security_check,使用SSO Cookie登陆,如果通过,realm认证(获取权限role).如何认证成功,结束
      .跳转到登陆页面.
      
    c.非SSO
      .realm认证。如果成功,跳转到welcome页面。否则跳转到登陆错误页面.
       
    smagent sdk 4.x 是需要在policy server上配置静态密钥,5.x 就可以先注册生成Smhost.conf,smagent加载即可


    参考

    JAAS:http://docs.oracle.com/javase/6/docs/technotes/guides/security/jaas/tutorials/index.html
    SiteMinder:https://support.ca.com/cadocs/0/CA%20SiteMinder%20r6%200%20SP6-ENU/Bookshelf_Files/HTML/index.htm?toc.htm?937146.html

  • 相关阅读:
    LG3626 [APIO2009]会议中心(倍增+树状数组)
    LG3624 [APIO2008]DNA(DP+前缀和)
    CF1516C
    PKUSC2021 口胡题解
    THUSC2021 Day1口胡题解
    2021.4
    2021.3
    2021 暑假 sxyz 集训做题记录
    【做题记录】CF746F Music in Car
    KMP
  • 原文地址:https://www.cnblogs.com/yangjun1120/p/2332154.html
Copyright © 2020-2023  润新知