Using Security Packages
The Security Support Provider Interface (SSPI) can be used with the following security packages:
The Kerberos and NTLM protocols are implemented as security packages from the Secur32.dll security support provider (SSP) supplied with the operating system. By default, support for both Kerberos and NTLM authentication are loaded by the local security authority (LSA) on a computer when the system starts. In Windows Server or Windows domains, either package can be used to authenticate network logons and client/server connections. Which one is used depends on the capabilities of the computer on the other side of the connection. The Kerberos protocol is always preferred, if available.
After a security context for an interactive user has been established, another instance of the Kerberos or NTLM package can be loaded by a process running in the security context of the user to support the exchanging, signing, verifying, encrypting, and decrypting of messages. However, no process other than the LSA is ever permitted access to session keys or tickets in the credentials cache.
System services and transport-level applications access an SSP through SSPI, which provides functions for enumerating the security packages available on a system, selecting a package, and using that package to obtain an authenticated connection.
The methods in SSPI are generic routines that developers can use without knowing the details of a particular security protocol. For example, when a client/server connection is authenticated:
- The application on the client side of the connection sends credentials to the server using the SSPI function InitializeSecurityContext (General).
- The application on the server side of the connection responds with the SSPI function AcceptSecurityContext (General).
- After the connection has been authenticated, the LSA on the server uses information from the client to build an access token.
- The server can then call the SSPI function ImpersonateSecurityContext to attach the access token to an impersonation thread for the service.
Kerberos Security Package
The Kerberos security package is based on the Kerberos authentication protocol.
If the Kerberos protocol is being used to authenticate a client/server connection, InitializeSecurityContext (Kerberos) generates a GSSAPI message that includes a KRB_AP_REQ message from the client. AcceptSecurityContext (Kerberos) then generates a GSSAPI message that includes a KRB_AP_REP message from the server.
For background information on the steps that take place behind the scenes in the implementation of a Kerberos protocol, see Microsoft Kerberos.
All distributed services use SSPI to access the Kerberos protocol. A partial list of the ways in which the Kerberos protocol is used for authentication includes:
- Print spooler services
- CIFS/SMB remote file access
- LDAP queries to the Active Directory
- Distributed file system management and referrals
- IPsec host-to-host security authority authentication
- Reservation requests for network Quality of Service
- Intranet authentication to Internet Information Services
- Remote server or workstation management using authenticated RPC
- Certificate requests to Certificate Services for domain users and computers
NTLM Security Package
The NTLM security package is based on the NTLM authentication protocol.