SSO with CAS or OAuth?

后端 未结 5 1117
一个人的身影
一个人的身影 2020-12-02 03:16

I wonder if I should use the CAS protocol or OAuth + some authentication provider for single sign-on.

Example Scenario:

  1. A User tries to access a protec
相关标签:
5条回答
  • 2020-12-02 03:48

    Old post, but this might be useful:

    CAS 3.5 will support oAuth as Client and Server. See: https://wiki.jasig.org/display/CASUM/OAuth

    0 讨论(0)
  • 2020-12-02 03:51

    To me, the real difference between SSO and OAuth is grant, not authentication because a server that implements OAuth obviously has authentication (you have to be logged in to your google, openId or facebook for OAuth to happen with the client app)

    In SSO, a power user/sysadmin grants the final user access to an application beforehand on the "SSO app" In OAuth, final user grants application access to his "data" on the "OAuth app"

    I don't see why OAuth protocol couldn't be used as part of an SSO server. Just take out the grant screen from the flow and let the OAuth server lookup the grant from the backing db.

    0 讨论(0)
  • 2020-12-02 03:54

    OpenID is an authentication protocol, OAuth and OAuth WRAP are authorization protocols. They can be combined with the hybrid OpenID extension.

    I'd strongly prefer to see people building on top of standards that have a lot of momentum (more available support, easier to get third parties involved), even if they aren't an exact fit for the application at hand. In this case, OAuth has the momentum, not CAS. You ought to be able to do all or at least nearly all of what you need to do with OAuth. At some later point in the future, OAuth WRAP should simplify things further (it makes some worthwhile trade-offs by using a bearer token and pushing encryption down to the protocol layer), but it's still in its infancy, and in the meantime, OAuth will probably do the job just fine.

    Ultimately, if you choose to use OpenID and OAuth, there are more libraries for more languages available to you and to anyone else who needs to integrate with the system. You also have a lot more eyeballs looking at the protocols, making sure they really are as secure as they're supposed to be.

    0 讨论(0)
  • 2020-12-02 03:56

    I tend to think of it this way:

    Use CAS if you control/own the user authentication system and need to support a heterogenous set of servers and apps that need centralized authentication.

    Use OAuth if you want to support user authentication from systems that you don't own/support (ie Google, Facebook, etc).

    0 讨论(0)
  • 2020-12-02 04:14

    OpenID is not a 'successor' or 'substitute' for CAS, they're different, in intent and in implementation.

    CAS centralizes authentication. Use it if you want all your (probably internal) applications to ask users to login to a single server (all applications are configured to point to a single CAS server).

    OpenID decentralizes authentication. Use it if you want your application to accept users login to whatever authentication service they want (the user provides the OpenID server address - in fact, the 'username' is the server's URL).

    None of the above handle authorization (without extensions and/or customization).

    OAuth handles authorization, but it is not a substitute for the traditional 'USER_ROLES table' (user access). It handles authorization for third-parties.

    For example, you want your application to integrate with Twitter: a user could allow it to tweet automatically when they update their data or post new content. You want to access some third-party service or resource on behalf of a user, without getting his password (which is obviously unsecure for the user). The application asks Twitter for access, the user authorizes it (through Twitter), and then the app may have access.

    So, OAuth is not about Single Sign-On (nor a substitute for the CAS protocol). It is not about you controlling what the user can access. It is about letting the user to control how their resources may be accessed by third-parties. Two very different use-cases.

    To the context you described, CAS is probably the right choice.

    [updated]

    That said, you can implement SSO with OAuth, if you consider the identity of the user as a secured resource. This is what 'Sign up with GitHub' and the likes do, basically. Probably not the original intent of the protocol, but it can be done. If you control the OAuth server, and restrict the apps to only authenticate with it, that's SSO.

    No standard way to force logout, though (CAS has this feature).

    0 讨论(0)
提交回复
热议问题