The present invention relates to client-server technology in general, and in particular to integrating non-SSO-compliant applications into an SSO system.
Network-based applications often make use of many different technologies, object models, and programming languages, from simple Perl scripts and standalone applications implemented in C++ or Java™, to sophisticated applications running on J2EE application servers. In the past, access security was the responsibility of each application, requiring users to employ different user names and passwords for different applications. As users required access to increasing numbers of applications of all types, single sign-on (SSO) mechanisms were developed to standardize access security protocols and form application domains whereby users are given access to applications within the domain without having to separately sign on to each application. To accomplish this, all security algorithms are typically found in a single SSO server which acts as the only authentication point for a defined domain. Thus, a user signs on and is authenticated only once, and thereafter may securely interact with many different elements within a given domain. This is typically done by generating an SSO token for the user after the user is first authenticated, providing the token to the user, and thereafter having the user pass the token to other SSO applications which validate the token with the SSO server.
Unfortunately, not all applications are SSO-compliant. To remedy this, non-SSO-compliant applications may be modified internally to implement SSO mechanisms. However, such applications would need to be modified each time there is a change to the SSO protocol at the SSO server level. Enabling non-SSO-compliant applications to work within an SSO framework without requiring that the applications be modified internally to implement SSO mechanisms would therefore be advantageous.
The present invention discloses a system and method for integrating non-SSO-compliant applications into an SSO system.
In one aspect of the present invention a method is provided for providing SSO authentication when accessing non-SSO-compliant applications, the method including forwarding a user name and a password received from a non-SSO-compliant application to an SSO proxy, encapsulating the user name and password in a request to access a protected application, authenticating the user name and password responsive to the request using SSO authentication, and generating an SSO token if the authentication step is successful.
In another aspect of the present invention the method further includes providing the SSO token, the user name, and a notification of the successful authentication to a server.
In another aspect of the present invention the method further includes providing the SSO token and the user name to the protected application.
In another aspect of the present invention the method further includes providing the token and a notification of the successful authentication to the SSO proxy.
In another aspect of the present invention the method further includes configuring the SSO proxy as an HTTP client.
In another aspect of the present invention the method further includes configuring the encapsulated request as an HTTP request.
In another aspect of the present invention the method further includes sending the request to a J2EE server.
In another aspect of the present invention the method further includes configuring the protected application as a protected HTTP servlet residing on a J2EE server.
In another aspect of the present invention a system is provided for SSO authentication for use with non-SSO-compliant applications, the system including an SSO proxy operative to receive a user name and password from a non-SSO-compliant application and encapsulate the user name and password in a request to access a protected application, and an authenticator operative to authenticate the user name and password responsive to the request using SSO authentication and generate an SSO token if the authentication is successful.
In another aspect of the present invention the authenticator is operative to provide the SSO token, the user name, and a notification of the successful authentication to a server.
In another aspect of the present invention the server is operative to provide the SSO token and the user name to the protected application.
In another aspect of the present invention the protected application is operative to provide the token and a notification of the successful authentication to the SSO proxy.
In another aspect of the present invention the SSO proxy is an HTTP client.
In another aspect of the present invention the encapsulated request is an HTTP request.
In another aspect of the present invention the server is a J2EE server.
In another aspect of the present invention the protected application is a protected HTTP servlet residing on a J2EE server.
In another aspect of the present invention a method is provided for providing SSO authentication when accessing non-SSO-compliant applications, the method including forwarding a user name and token received from a non-SSO-compliant application to an SSO proxy, encapsulating the user name and token in a request to access a protected application, authenticating the token responsive to the request using SSO authentication, and generating a security context for the request if the authentication step is successful.
In another aspect of the present invention the generating step includes generating the security context to include the authenticated token and the user name.
In another aspect of the present invention the method further includes passing the request, the user name, and a notification of the successful authentication to a server.
In another aspect of the present invention the method further includes passing the request, the user name, and a notification of the successful authentication to the protected application.
In another aspect of the present invention the method further includes comparing the user name received with the request with the user name received with the security context of the request, and providing an affirmative response to the request if the user names match.
In another aspect of the present invention the providing step includes providing the affirmative response to the SSO proxy.
In another aspect of the present invention the method further includes configuring the SSO proxy as an HTTP client.
In another aspect of the present invention the method further includes configuring the encapsulated request as an HTTP request.
In another aspect of the present invention the method further includes sending the request to a J2EE server.
In another aspect of the present invention the method further includes configuring the protected application as a protected HTTP servlet residing on a J2EE server.
In another aspect of the present invention a system is provided for SSO authentication for use with non-SSO-compliant applications, the system including an SSO proxy operative to receive a user name and token from a non-SSO-compliant application and encapsulate the user name and token in a request to access a protected application, and an authenticator operative to authenticate the user name and token responsive to the request using SSO authentication and generate a security context for the request if the authentication step is successful.
In another aspect of the present invention the security context includes the authenticated token and the user name.
In another aspect of the present invention the authenticator is operative to pass the request, the user name, and a notification of the successful authentication to a server.
In another aspect of the present invention the server is operative to pass the request, the user name, and a notification of the successful authentication to the protected application.
In another aspect of the present invention the protected application is operative to compare the user name received with the request with the user name received with the security context of the request, and provide an affirmative response to the request if the user names match.
In another aspect of the present invention the protected application is operative to provide the affirmative response to the SSO proxy.
In another aspect of the present invention the SSO proxy is an HTTP client.
In another aspect of the present invention the encapsulated request is an HTTP request.
In another aspect of the present invention the server is a J2EE server.
In another aspect of the present invention the protected application is a protected HTTP servlet residing on a J2EE server.
In another aspect of the present invention a method is provided for implementing SSO authentication in support of non-SSO-compliant application access, the method including providing a SSO proxy operative to receive a user name and a password from a non-SSO-compliant application, and configuring the SSO proxy to a) encapsulate the user name and password in a request to access a protected application, and b) send the request to a computer operative to c) authenticate the user name and password responsive to the request using SSO authentication, and d) generate an SSO token if the authentication is successful.
In another aspect of the present invention a computer program is provided embodied on a computer-readable medium, the computer program including a first code segment operative to forward a user name and a password received from a non-SSO-compliant application to an SSO proxy, a second code segment operative to encapsulate the user name and password in a request to access a protected application, a third code segment operative to authenticate the user name and password responsive to the request using SSO authentication, and a fourth code segment operative to generate an SSO token if the authentication is successful.
The present invention will be understood and appreciated more fully from the following detailed description taken in conjunction with the appended drawings in which:
Reference is now made to
Reference is now made to
It is appreciated that one or more of the steps of any of the methods described herein may be omitted or carried out in a different order than that shown, without departing from the true spirit and scope of the invention.
While the methods and apparatus disclosed herein may or may not have been described with reference to specific computer hardware or software, it is appreciated that the methods and apparatus described herein may be readily implemented in computer hardware or software using conventional techniques. Thus, for example, client-side components described hereinabove may be implemented using the Extensible Markup Language (XML), Hypertext Markup Language (HTML), JavaScript™, Java Applets, ActiveX™, or any combination thereof.
While the present invention has been described with reference to one or more specific embodiments, the description is intended to be illustrative of the invention as a whole and is not to be construed as limiting the invention to the embodiments shown. It is appreciated that various modifications may occur to those skilled in the art that, while not specifically shown herein, are nevertheless within the true spirit and scope of the invention.
Number | Name | Date | Kind |
---|---|---|---|
5944824 | He | Aug 1999 | A |
6178511 | Cohen et al. | Jan 2001 | B1 |
6327659 | Boroditsky et al. | Dec 2001 | B2 |
6332192 | Boroditsky et al. | Dec 2001 | B1 |
6691232 | Wood et al. | Feb 2004 | B1 |
6732105 | Watson et al. | May 2004 | B1 |
6826692 | White | Nov 2004 | B1 |
6938158 | Azuma | Aug 2005 | B2 |
6973617 | Parasu | Dec 2005 | B1 |
7069440 | Aull | Jun 2006 | B2 |
7085840 | de Jong et al. | Aug 2006 | B2 |
7164685 | Atamaniouk | Jan 2007 | B2 |
7221935 | Barriga-Caceres et al. | May 2007 | B2 |
7237256 | Cheng et al. | Jun 2007 | B2 |
7246230 | Stanko | Jul 2007 | B2 |
7249375 | Bhatia et al. | Jul 2007 | B2 |
7275259 | Jamieson et al. | Sep 2007 | B2 |
7275260 | de Jong et al. | Sep 2007 | B2 |
7296290 | Barriga et al. | Nov 2007 | B2 |
7475146 | Bazot et al. | Jan 2009 | B2 |
20020176582 | Aull | Nov 2002 | A1 |
20030012382 | Ferchichi et al. | Jan 2003 | A1 |
20030126136 | Omoigui | Jul 2003 | A1 |
20030177356 | Abela | Sep 2003 | A1 |
20030229783 | Hardt | Dec 2003 | A1 |
20040025056 | Katsube | Feb 2004 | A1 |
20040078312 | Bush et al. | Apr 2004 | A1 |
20040117493 | Bazot et al. | Jun 2004 | A1 |
20040123144 | Chan et al. | Jun 2004 | A1 |
20040153908 | Schiavone et al. | Aug 2004 | A1 |
20040181469 | Saeki | Sep 2004 | A1 |
20040249961 | Katsube et al. | Dec 2004 | A1 |
20040250118 | Andreev et al. | Dec 2004 | A1 |
20050015490 | Saare et al. | Jan 2005 | A1 |
20050039008 | Bhatia et al. | Feb 2005 | A1 |
20050039054 | Satoh et al. | Feb 2005 | A1 |
20050108575 | Yung | May 2005 | A1 |
20050188212 | Laferriere et al. | Aug 2005 | A1 |
20050283443 | Hardt | Dec 2005 | A1 |
20050283614 | Hardt | Dec 2005 | A1 |
20060013393 | Ferchichi et al. | Jan 2006 | A1 |
20060020791 | Laitinen | Jan 2006 | A1 |
20060195893 | Caceres et al. | Aug 2006 | A1 |
20060200671 | Ishigaki et al. | Sep 2006 | A1 |
20070208936 | Ramos Robles | Sep 2007 | A1 |
Number | Date | Country | |
---|---|---|---|
20060041933 A1 | Feb 2006 | US |