Required dependencies: io.ktor:%artifact_name%
The Digest authentication scheme is a part of HTTP framework used for access control and authentication. In this scheme, a hash function is applied to a username and password before sending them over the network.
Ktor allows you to use digest authentication for logging in users and protecting specific routes. You can get general information about authentication in Ktor in the section.
To enable digest
authentication, you need to include the %artifact_name%
artifact in the build script:
The digest authentication flow looks as follows:
-
A client makes a request without the
Authorization
header to a specific route in a server application. -
A server responds to a client with a
401
(Unauthorized) response status and uses aWWW-Authenticate
response header to provide information that the digest authentication scheme is used to protect a route. A typicalWWW-Authenticate
header looks like this:WWW-Authenticate: Digest realm="Access to the '/' path", nonce="e4549c0548886bc2", algorithm="MD5"
{style="block"}
In Ktor, you can specify the realm and the way of generating a nonce value when configuring the
digest
authentication provider. -
Usually a client displays a login dialog where a user can enter credentials. Then, a client makes a request with the following
Authorization
header:Authorization: Digest username="jetbrains", realm="Access to the '/' path", nonce="e4549c0548886bc2", uri="/", algorithm=MD5, response="6299988bb4f05c0d8ad44295873858cf"
{style="block"}
The
response
value is generated in the following way:a.
HA1 = MD5(username:realm:password)
This part is stored on a server and can be used by Ktor to validate user credentials.
b.
HA2 = MD5(method:digestURI)
c.
response = MD5(HA1:nonce:HA2)
-
A server validates credentials sent by a client and responds with the requested content.
To install the digest
authentication provider, call the digest function inside the install
block:
install(Authentication) {
digest {
// Configure digest authentication
}
}
You can optionally specify a provider name that can be used to authenticate a specified route.
To get a general idea on how to configure different authentication providers in Ktor, see . In this section, we'll see on configuration specifics of the digest
authentication provider.
The digest
authentication provider validates user credentials using the HA1
part of a digest message. So, you can provide a user table that contains usernames and corresponding HA1
hashes. In the example below, the getMd5Digest
function is used to generate HA1
hashes:
{src="snippets/auth-digest/src/main/kotlin/com/example/Application.kt" lines="10-16"}
The digest
authentication provider exposes its settings via the DigestAuthenticationProvider.Config class. In the example below, the following settings are specified:
- The
realm
property sets the realm to be passed inWWW-Authenticate
header. - The
digestProvider
function fetches theHA1
part of digest for a specified username.
{src="snippets/auth-digest/src/main/kotlin/com/example/Application.kt" lines="18-26,34"}
You can also use the nonceManager property to specify how to generate nonce values.
After configuring the digest
provider, you can define the authorization for the different resources in our application using the authenticate
function. In a case of successful authentication, you can retrieve an authenticated UserIdPrincipal inside a route handler using the call.principal
function and get a name of an authenticated user.
{src="snippets/auth-digest/src/main/kotlin/com/example/Application.kt" lines="27-33"}