joche.ojeda@bitframeworks.com
Joche Ojeda
  • Home
  • About
  • Contact
  • Login
  • Register
  • en
    • ar
    • zh-CN
    • nl
    • en
    • fr
    • de
    • it
    • pt
    • ru
    • es
Select Page
Understanding Keycloak: An Identity Management Solution for .NET Developers

Understanding Keycloak: An Identity Management Solution for .NET Developers

by Joche Ojeda | Aug 5, 2025 | Auth, Linux, Ubuntu, WSL

In modern application development, managing user authentication and authorization across multiple systems has become a significant challenge. Keycloak emerges as a compelling solution to address these identity management complexities, offering particular value for .NET developers seeking flexible authentication options.

What is Keycloak?

Keycloak is an open-source Identity and Access Management (IAM) solution developed by Red Hat. It functions as a centralized authentication and authorization server that manages user identities and controls access across multiple applications and services within an organization.

Rather than each application handling its own user authentication independently, Keycloak provides a unified identity provider that enables Single Sign-On (SSO) capabilities. Users authenticate once with Keycloak and gain seamless access to all authorized applications without repeated login prompts.

Core Functionality

Keycloak serves as a comprehensive identity management platform that handles several critical functions. It manages user authentication through various methods including traditional username/password combinations, multi-factor authentication, and social login integration with providers like Google, Facebook, and GitHub.

Beyond authentication, Keycloak provides robust authorization capabilities, controlling what authenticated users can access within applications through role-based access control and fine-grained permissions. The platform supports industry-standard protocols including OpenID Connect, OAuth 2.0, and SAML 2.0, ensuring compatibility with a wide range of applications and services.

User federation capabilities allow Keycloak to integrate with existing user directories such as LDAP and Active Directory, enabling organizations to leverage their current user stores rather than requiring complete migration to new systems.

The Problem Keycloak Addresses

Modern users often experience “authentication fatigue” – the exhaustion that comes from repeatedly logging into multiple systems throughout their workday. A typical enterprise user might need to authenticate with email systems, project management tools, CRM platforms, cloud storage, HR portals, and various internal applications, each potentially requiring different credentials and authentication flows.

This fragmentation leads to several problems: users struggle with password management across multiple systems, productivity decreases due to time spent on authentication processes, security risks increase as users resort to password reuse or weak passwords, and IT support costs rise due to frequent password reset requests.

Keycloak eliminates these friction points by providing seamless SSO while simultaneously improving security through centralized identity management and consistent security policies.

Keycloak and .NET Integration

For .NET developers, Keycloak offers excellent compatibility through its support of standard authentication protocols. The platform’s adherence to OpenID Connect and OAuth 2.0 standards means it integrates naturally with .NET applications using Microsoft’s built-in authentication middleware.

.NET Core and .NET 5+ applications can integrate with Keycloak using the Microsoft.AspNetCore.Authentication.OpenIdConnect package, while older .NET Framework applications can utilize OWIN middleware. Blazor applications, both Server and WebAssembly variants, support the same integration patterns, and Web APIs can be secured using JWT tokens issued by Keycloak.

The integration process typically involves configuring authentication middleware in the .NET application to communicate with Keycloak’s endpoints, establishing client credentials, and defining appropriate scopes and redirect URIs. This standards-based approach ensures that .NET developers can leverage their existing knowledge of authentication patterns while benefiting from Keycloak’s advanced identity management features.

Benefits for .NET Development

Keycloak offers several advantages for .NET developers and organizations. As an open-source solution, it provides cost-effectiveness compared to proprietary alternatives while offering extensive customization capabilities that proprietary solutions often restrict.

The platform reduces development time by handling complex authentication scenarios out-of-the-box, allowing developers to focus on business logic rather than identity management infrastructure. Security benefits include centralized policy management, regular security updates, and implementation of industry best practices.

Keycloak’s vendor-neutral approach provides flexibility for organizations using multiple cloud providers or seeking to avoid vendor lock-in. The solution scales effectively through clustered deployments and supports high-availability configurations suitable for enterprise environments.

Comparison with Microsoft Solutions

When compared to Microsoft’s identity offerings like Entra ID (formerly Azure AD), Keycloak presents different trade-offs. Microsoft’s solutions provide seamless integration within the Microsoft ecosystem and offer managed services with minimal maintenance requirements, but come with subscription costs and potential vendor lock-in considerations.

Keycloak, conversely, offers complete control over deployment and data, extensive customization options, and freedom from licensing fees. However, it requires organizations to manage their own infrastructure and maintain the necessary technical expertise.

When Keycloak Makes Sense

Keycloak represents an ideal choice for .NET developers and organizations that prioritize flexibility, cost control, and customization capabilities. It’s particularly suitable for scenarios involving multiple cloud providers, integration with diverse systems, or requirements for extensive branding and workflow customization.

Organizations with the technical expertise to manage infrastructure and those seeking vendor independence will find Keycloak’s open-source model advantageous. The solution also appeals to teams building applications that need to work across different technology stacks and cloud environments.

Conclusion

Keycloak stands as a robust, flexible identity management solution that integrates seamlessly with .NET applications through standard authentication protocols. Its open-source nature, comprehensive feature set, and standards-based approach make it a compelling alternative to proprietary identity management solutions.

For .NET developers seeking powerful identity management capabilities without vendor lock-in, Keycloak provides the tools necessary to implement secure, scalable authentication solutions while maintaining the flexibility to adapt to changing requirements and diverse technology environments.

MailHog: The Essential Email Testing Tool for .NET Developers

MailHog: The Essential Email Testing Tool for .NET Developers

by Joche Ojeda | Aug 4, 2025 | Linux, Ubuntu, WSL

Email functionality is a critical component of most modern applications, from user authentication and password resets to notifications and marketing campaigns. However, testing email features during development can be challenging—you don’t want to accidentally send test emails to real users, and setting up a complete email server for testing is often overkill. This is where MailHog comes to the rescue.

What is MailHog?

MailHog is an open-source email testing tool designed specifically for development and testing environments. Think of it as a “fake” SMTP server that captures emails sent by your application instead of delivering them to real recipients. It provides a clean web interface where you can view, inspect, and manage all captured emails in real-time.

Built with Go and completely free, MailHog has become an indispensable tool for developers who need to test email functionality without the complexity and risks associated with real email delivery.

Why MailHog is Perfect for .NET Development

As a .NET developer, you’ve likely encountered scenarios where you need to test:

  • User registration and email verification
  • Password reset workflows
  • Account activation processes
  • Notification systems
  • Email templates and formatting

MailHog seamlessly integrates with .NET applications using the standard SMTP libraries you’re already familiar with. Whether you’re using System.Net.Mail.SmtpClient or other SMTP libraries, MailHog works transparently as a drop-in replacement for your production SMTP server.

Key Features That Make MailHog Stand Out

SMTP Server Compliance

  • Full RFC5321 ESMTP server implementation
  • Support for SMTP AUTH (RFC4954) and PIPELINING (RFC2920)
  • Works with any SMTP client library

Developer-Friendly Interface

  • Clean web UI to view messages in plain text, HTML, or raw source
  • Real-time updates using EventSource technology
  • Support for RFC2047 encoded headers
  • Multipart MIME support with downloadable individual parts

Testing and Development Features

  • Chaos Monkey: Built-in failure testing to simulate email delivery issues
  • Message Release: Forward captured emails to real SMTP servers when needed
  • HTTP API: Programmatically list, retrieve, and delete messages (APIv1 and APIv2)
  • Authentication: HTTP basic authentication for UI and API security

Storage Options

  • In-memory storage: Lightweight and fast for development
  • MongoDB persistence: For scenarios requiring message persistence
  • File-based storage: Simple file system storage option

Deployment Benefits

  • Lightweight and portable: Single binary with no dependencies
  • No installation required: Download and run
  • Cross-platform: Works on Windows, macOS, and Linux

Installing MailHog on WSL2

Setting up MailHog on Windows Subsystem for Linux (WSL2) is straightforward and provides excellent performance for .NET development workflows.

Option 1: Automated Installation with Script

If you don’t want to manually install MailHog, you can use my automated installation script for WSL:

# Download and run the installation script
curl -sSL https://raw.githubusercontent.com/egarim/MyWslScripts/master/install_mailhog.sh | bash

This script will automatically download MailHog, set it up, and configure it as a service. You can find the script at: https://github.com/egarim/MyWslScripts/blob/master/install_mailhog.sh

Option 2: Manual Installation

Step 1: Download MailHog

# Create a directory for MailHog
mkdir ~/mailhog
cd ~/mailhog

# Download the latest Linux binary
wget https://github.com/mailhog/MailHog/releases/download/v1.0.1/MailHog_linux_amd64

# Make it executable
chmod +x MailHog_linux_amd64

# Optional: Create a symlink for easier access
sudo ln -s ~/mailhog/MailHog_linux_amd64 /usr/local/bin/mailhog

Step 2: Start MailHog

# Start MailHog (runs on ports 1025 for SMTP and 8025 for web UI)
./MailHog_linux_amd64

# Or if you created the symlink:
mailhog

Step 3: Verify Installation

Open your browser and navigate to http://localhost:8025. You should see the MailHog web interface ready to capture emails.

Step 4: Configure as a Service (Optional)

For persistent use, create a systemd service:

# Create service file
sudo nano /etc/systemd/system/mailhog.service

Add the following content:

[Unit]
Description=MailHog Email Web Service
After=network.target

[Service]
Type=simple
User=your-username
ExecStart=/home/your-username/mailhog/MailHog_linux_amd64
Restart=always

[Install]
WantedBy=multi-user.target

Enable and start the service:

sudo systemctl enable mailhog
sudo systemctl start mailhog

Integrating MailHog with .NET Applications

Configuration in appsettings.json

{
  "EmailSettings": {
    "SmtpServer": "localhost",
    "SmtpPort": 1025,
    "FromEmail": "noreply@yourapp.com",
    "FromName": "Your Application"
  }
}

Using with System.Net.Mail

public class EmailService
{
    private readonly IConfiguration _configuration;

    public EmailService(IConfiguration configuration)
    {
        _configuration = configuration;
    }

    public async Task SendEmailAsync(string to, string subject, string body)
    {
        var smtpClient = new SmtpClient(_configuration["EmailSettings:SmtpServer"])
        {
            Port = int.Parse(_configuration["EmailSettings:SmtpPort"]),
            EnableSsl = false, // MailHog doesn't require SSL
            UseDefaultCredentials = true
        };

        var mailMessage = new MailMessage
        {
            From = new MailAddress(_configuration["EmailSettings:FromEmail"], 
                                 _configuration["EmailSettings:FromName"]),
            Subject = subject,
            Body = body,
            IsBodyHtml = true
        };
        
        mailMessage.To.Add(to);

        await smtpClient.SendMailAsync(mailMessage);
    }
}

Real-World Testing Scenarios

Password Reset Testing

[Fact]
public async Task PasswordReset_ShouldSendEmail()
{
    // Arrange
    var userEmail = "test@example.com";
    var resetToken = Guid.NewGuid().ToString();

    // Act
    await _authService.SendPasswordResetEmailAsync(userEmail, resetToken);

    // Assert - Check MailHog API for sent email
    var httpClient = new HttpClient();
    var response = await httpClient.GetAsync("http://localhost:8025/api/v2/messages");
    var messages = JsonSerializer.Deserialize<MailHogResponse>(await response.Content.ReadAsStringAsync());
    
    Assert.Single(messages.Items);
    Assert.Contains(resetToken, messages.Items[0].Content.Body);
}

Email Template Verification

With MailHog’s web interface, you can:

  • Preview HTML email templates exactly as recipients would see them
  • Test responsive design across different screen sizes
  • Verify that images and styling render correctly
  • Check for broken links or formatting issues

Advanced MailHog Usage

Environment-Specific Configuration

Use different MailHog instances for different environments:

# Development environment
mailhog -smtp-bind-addr 127.0.0.1:1025 -ui-bind-addr 127.0.0.1:8025

# Testing environment  
mailhog -smtp-bind-addr 127.0.0.1:1026 -ui-bind-addr 127.0.0.1:8026

API Integration for Automated Tests

public class MailHogClient
{
    private readonly HttpClient _httpClient;

    public MailHogClient()
    {
        _httpClient = new HttpClient { BaseAddress = new Uri("http://localhost:8025/") };
    }

    public async Task<IEnumerable<Email>> GetEmailsAsync()
    {
        var response = await _httpClient.GetAsync("api/v2/messages");
        var content = await response.Content.ReadAsStringAsync();
        var mailHogResponse = JsonSerializer.Deserialize<MailHogResponse>(content);
        return mailHogResponse.Items;
    }

    public async Task DeleteAllEmailsAsync()
    {
        await _httpClient.DeleteAsync("api/v1/messages");
    }
}

Why I Use MailHog Daily

As someone who works extensively with .NET applications requiring email functionality, MailHog has become an essential part of my development toolkit. Here’s why:

Reliability: No more worrying about test emails reaching real users or bouncing back from invalid addresses.

Speed: Instant email capture and viewing without network delays or external dependencies.

Debugging: The ability to inspect raw email headers and content makes troubleshooting email issues much easier.

Team Collaboration: Developers can share MailHog URLs to demonstrate email functionality during code reviews or testing sessions.

CI/CD Integration: MailHog works perfectly in Docker containers and automated testing pipelines.

Conclusion

MailHog represents the perfect balance of simplicity and functionality for email testing in .NET development. Its open-source nature, zero-configuration setup, and comprehensive feature set make it an invaluable tool for any developer working with email functionality.

Whether you’re building a simple contact form or a complex multi-tenant application with sophisticated email workflows, MailHog provides the testing infrastructure you need without the complexity of traditional email servers.

Give MailHog a try in your next .NET project—you’ll wonder how you ever developed email features without it.


Resources:

  • MailHog GitHub Repository
  • API Documentation
  • MailHog Client Libraries
  • WSL Installation Script

 

Search

Recent Posts

  • Understanding Keycloak: An Identity Management Solution for .NET Developers
  • MailHog: The Essential Email Testing Tool for .NET Developers
  • Understanding the N+1 Database Problem using Entity Framework Core
  • Day 4 (the missing day): Building Data Import/Export Services for Your ERP System
  • Building a Comprehensive Accounting System Integration Test – Day 5

Categories

  • A.I
  • ADO
  • ADO.NET
  • AlchemyDotNet
  • Apache
  • Application Framework
  • Auth
  • Bitcoin
  • Blazor
  • Blockchain
  • Boring systems
  • Brevitas
  • Brevitas Application Framework
  • C#
  • Carbon Credits
  • Code Rush
  • CPU
  • Custom Controllers
  • Custom Templates
  • Data Synchronization
  • Database
  • DevExpress
  • DevExpress XPO from step 1 to N
  • dotnet
  • EfCore
  • EfCore
  • El Salvador
  • Emit
  • Entity Framework Core
  • ERP
  • Forms
  • GraphQL
  • http
  • IPFS
  • Linux
  • MAUI
  • MetaProgramming
  • netcore
  • netframework
  • network
  • Nuget
  • Object-Oriented Programming
  • Oqtane
  • ORM
  • Postgres
  • PowerShell
  • Programming Situations
  • PropertyEditors
  • Reflection
  • Search
  • Semantic Kernel
  • SivarErp
  • Smart contracts
  • Sqlite
  • Stratis
  • SyncFrameworkV2
  • System Theory
  • Testing
  • UAP/UWP
  • Ubuntu
  • Uncategorized
  • Uno Platform
  • Visual Studio
  • VPN
  • Web
  • WebAssembly
  • Webinars
  • WebServers
  • Windows Os
  • WSL
  • XAF
  • Xamarin
  • Xamarin Forms
  • XPO
  • XPO Database Replication
  • XtraReports

Archives

  • August 2025
  • June 2025
  • May 2025
  • April 2025
  • March 2025
  • February 2025
  • January 2025
  • December 2024
  • November 2024
  • October 2024
  • September 2024
  • August 2024
  • July 2024
  • June 2024
  • May 2024
  • April 2024
  • March 2024
  • February 2024
  • January 2024
  • December 2023
  • October 2023
  • September 2023
  • July 2023
  • May 2023
  • March 2023
  • January 2023
  • December 2022
  • November 2022
  • October 2021
  • October 2020
  • September 2020
  • May 2020
  • April 2020
  • February 2020
  • September 2019
  • July 2019
  • June 2019
  • April 2019
  • March 2019
  • February 2019
  • January 2019
  • December 2018
  • October 2018
  • September 2018
  • Facebook
  • X

Designed by Elegant Themes | Powered by WordPress