data:image/s3,"s3://crabby-images/b7429/b7429a8133a3c6bcd800c1082c189f124eb31a8b" alt=""
Certificate-based authentication is the use of a Digital Certificate to identify a user, machine, or device before granting access to a resource, network, application, etc.
Let’s see example
Create a certificate
using windows PowerShell, I am generating a simple self-signed certificate for test.
It will generate a certificate in current directory.
dotnet dev-certs https -ep dev_cert.pfx -p 1234
Create web API
Create a webapi app with following command.
dotnet new webapi -o CerificateAuth
add the required nuget package
dotnet add package Microsoft.AspNetCore.Authentication.Certificate
Program.cs
Open Program.cs and make the following changes.
data:image/s3,"s3://crabby-images/979fd/979fd28911703307caa4342661cc41b53c8f034e" alt=""
Program.cs changes
It tells Kestrel that it needs a certificate to allow any further communication.
Certificate Validation
Add a class which does the certificate validation and add following method.
data:image/s3,"s3://crabby-images/cf18d/cf18df2f19d2d5c20992ba20fd9ab4345dd5b38d" alt=""
certificate validation
Note: In production, reading certificate should be done via any secure vault.
Authentication Extension
Add a extension class to configure authentication.
public static class AuthenticationExtension
{
public static void ConfigureAuthetication(this
IServiceCollection services)
{
services.AddAuthentication
(CertificateAuthenticationDefaults.
AuthenticationScheme)
.AddCertificate(options=>
{
options.RevocationMode = X509RevocationMode.NoCheck;
options.AllowedCertificateTypes=CertificateTypes.All;
options.Events = new CertificateAuthenticationEvents
{
OnCertificateValidated=context=>
{
var validationService =
context.HttpContext.RequestServices.
GetService<CertificateValidationService>();
if (validationService != null &&
validationService.ValidateCertificate
(context.ClientCertificate))
{
Console.WriteLine("Success");
context.Success();
}
else
{
Console.WriteLine("invalid cert");
context.Fail("invalid cert");
}
return Task.CompletedTask;
}
};
});
services.AddAuthorization();
}
}
In this example, we are simply validating the certificate and returning success, we can extract claims after successful validation.
Startup.cs
Finally we add required code in startup.cs
data:image/s3,"s3://crabby-images/fe6ba/fe6baa5ca01eab364cf1715505de98de5c177ecb" alt=""
Startup.cs changes
Controller
we also have to specify the authorize attribute to required controllers.
data:image/s3,"s3://crabby-images/96430/96430fcc1a275bf047258450e7f31a7cbcc1e71e" alt=""
controller changes
we are done with changes in API
Let’s build and run to make sure no build errors.
Create client
Create a console app with following command.
dotnet new console -o CerificateAuthClient
and add the following code
data:image/s3,"s3://crabby-images/74da3/74da39d0e4d82e881dca4903248febdbf0014349" alt=""
It is simple client with httpclient, calling API with attaching the certificate.
when we run the client. we get following result.
data:image/s3,"s3://crabby-images/9f0e7/9f0e71ed467fc6f09c8446e67fc051097709294c" alt=""
We have got the response back.
Test With Postman
Make sure your API is running.
First add the certificate to postman. go to Settings -> Certificates and select add certificate. and add the required info like below.
data:image/s3,"s3://crabby-images/51c43/51c432882de375c17715373a16ca1632034d47bf" alt=""
Once the certificate is added, we can call our API.
data:image/s3,"s3://crabby-images/f814b/f814bfb1ad6dcb3e16cef57d74840aedcb30e194" alt=""
we can see the result as we successfully get the response back.
You can find full source code at Github
Summary
This is just a simple example. of course we can achieve more with certificate based authentication.
Source: Medium - Nitesh Singhal
The Tech Platform
Comments