G9BlazorComponent.Captcha.Common
1.0.0.6
See the version list below for details.
dotnet add package G9BlazorComponent.Captcha.Common --version 1.0.0.6
NuGet\Install-Package G9BlazorComponent.Captcha.Common -Version 1.0.0.6
<PackageReference Include="G9BlazorComponent.Captcha.Common" Version="1.0.0.6" />
paket add G9BlazorComponent.Captcha.Common --version 1.0.0.6
#r "nuget: G9BlazorComponent.Captcha.Common, 1.0.0.6"
// Install G9BlazorComponent.Captcha.Common as a Cake Addin #addin nuget:?package=G9BlazorComponent.Captcha.Common&version=1.0.0.6 // Install G9BlazorComponent.Captcha.Common as a Cake Tool #tool nuget:?package=G9BlazorComponent.Captcha.Common&version=1.0.0.6
G9BlazorComponent.Captcha
The G9BlazorComponent.Captcha library provides a flexible and robust CAPTCHA system for .NET applications, designed to integrate seamlessly with Blazor components and ASP.NET Core web services. It consists of three main NuGet packages:
- G9BlazorComponent.Captcha.Common: Shared client-side and server-side logic.
- G9BlazorComponent.Captcha.Core: Server-side CAPTCHA generation and validation logic.
- G9BlazorComponent.Captcha.Component: Blazor components for integrating CAPTCHA into your UI.
Key Features
- Support for multiple CAPTCHA types (Text-based, Click-based, and Selection-based).
- Customizable difficulty levels and themes (light/dark).
- Localization support for multiple languages.
- Easy integration with .NET applications and Blazor components.
- Configurable server-side logic for eligibility and validation.
Table of Contents
Getting Started
To use the G9BlazorComponent.Captcha
library, include the required NuGet packages in your project:
- G9BlazorComponent.Captcha.Core: For server-side logic.
- G9BlazorComponent.Captcha.Component: For Blazor UI components.
When adding G9BlazorComponent.Captcha.Core
or G9BlazorComponent.Captcha.Component
, the G9BlazorComponent.Captcha.Common
package is included automatically.
Usage Scenarios
Blazor Web Server Project
In a Blazor Web Server project, add both G9BlazorComponent.Captcha.Core
and G9BlazorComponent.Captcha.Component
to:
- Configure server-side CAPTCHA generation and validation.
- Integrate Blazor components for CAPTCHA input.
MAUI Application
For a .NET MAUI project:
- Add
G9BlazorComponent.Captcha.Component
to the MAUI client application. - Use
G9BlazorComponent.Captcha.Core
on the server-side to handle CAPTCHA generation and validation requests.
Installation
Use the .NET CLI or NuGet Package Manager to install the required packages:
# Install server-side package
dotnet add package G9BlazorComponent.Captcha.Core
# Install client-side package
dotnet add package G9BlazorComponent.Captcha.Component
Configuration
Server-side
In your server project, configure the CAPTCHA generator using G9CaptchaGeneratorSingleton
. Example:
builder.Services.AddSingleton(service =>
{
var logger = service.GetService<ILogger<G9CaptchaGeneratorSingleton>>();
var selectionBase = G9DtSelectionBaseCaptchaConfiguration.Init(new G9DtCaptchaSelectionConfig
{
Difficulty = G9ECaptchaDifficulty.Hard,
Template = G9ECaptchaTheme.Dark,
SelectionBaseCaptchaType = G9ESelectionBaseCaptchaValidationRules.AcceptOutOfOrder
});
var textBase = G9DtTextBaseCaptchaConfiguration.Init(new G9DtCaptchaTextBaseConfig
{
Difficulty = G9ECaptchaDifficulty.Hard,
Template = G9ECaptchaTheme.Dark,
CallbackMode = G9ECaptchaResultCallbackMode.CallbackWithConfirmButton
});
textBase.IsCaseSensitive = true;
var config = new G9DtCaptchaConfiguration
{
CaptchaClickBaseConfig = new G9DtCaptchaClickBaseConfig
{
CheckEligibilityUsingClickBaseCaptcha = () => (true, null),
UsedEligibilityOnClickBaseCaptcha = _ => true
},
SelectionBaseCaptchaConfiguration = selectionBase,
TextBaseCaptchaConfiguration = textBase
};
return G9CaptchaGeneratorSingleton.InitOrGet(config, 180, 3600, 0, logger, false, false);
});
Map CAPTCHA API endpoints:
app.AddCaptchaApiEndpoints();
Client-side
In your Blazor component, use G9BlazorComponentCaptchaManual
, G9BlazorComponentCaptchaAutomatic
, or G9BlazorComponentCaptchaClient
for CAPTCHA integration:
<G9BlazorComponentCaptchaClient @ref="_captcha"
ServerAddress="https://localhost:7255/"
OnApprovementCallback="OnApprovement"
Language="G9ECultures.en" />
Examples
Blazor Integration
A complete example of integrating CAPTCHA in a Blazor Web Server project:
Razor Component
<G9BlazorComponentCaptchaManual CaptchaMetadata="@_clientCaptchaMetadata"
OnRefreshRequestCallback="RefreshRequest"
OnResultCallback="OnCaptchaCallback"
Theme="G9ECaptchaTheme.Dark"
Language="G9ECultures.en" />
Code-behind
private G9DtCaptchaMetadata? _clientCaptchaMetadata;
protected override async Task OnInitializedAsync()
{
_clientCaptchaMetadata = await CaptchaGeneratorSingleton.GenerateCaptcha();
}
private async Task OnCaptchaCallback(G9DtCaptchaResult result)
{
var isValid = await CaptchaGeneratorSingleton.ValidateCaptcha(result);
Console.WriteLine(isValid ? "CAPTCHA Valid" : "CAPTCHA Invalid");
}
MAUI Integration
Client Application
Use G9BlazorComponentCaptchaClient
in your MAUI Blazor project to connect to the server-side API.
License
This library is licensed under the MIT License. See the LICENSE.md
file for details.
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net9.0 is compatible. net9.0-android was computed. net9.0-browser was computed. net9.0-ios was computed. net9.0-maccatalyst was computed. net9.0-macos was computed. net9.0-tvos was computed. net9.0-windows was computed. |
-
net9.0
- No dependencies.
NuGet packages (2)
Showing the top 2 NuGet packages that depend on G9BlazorComponent.Captcha.Common:
Package | Downloads |
---|---|
G9BlazorComponent.Captcha.Component
Package Description |
|
G9BlazorComponent.Captcha.Core
Package Description |
GitHub repositories
This package is not used by any popular GitHub repositories.