Làm cách nào để bản địa hóa thông báo lỗi Tên người dùng và Mật khẩu ASP.NET Identity UserName?


80

Có thể cung cấp các chuỗi được bản địa hóa cho các thông báo lỗi ASP.NET Identity v1 của "hệ thống", như " Tên XYZ đã được sử dụng " hoặc " Tên người dùng XYZ không hợp lệ, chỉ có thể chứa chữ cái hoặc chữ số " không?

Câu trả lời:


18

Chưa hết, chúng tôi có một lỗi theo dõi hạng mục công việc này để cho phép xác định nguồn tài nguyên đến từ đâu.


3
Cảm ơn. Bạn có bất kỳ ý tưởng nào về việc khi nào chức năng này sẽ có sẵn nói chung không?
rootless

Khi nào sẽ có gói NuGet cho tiếng Thụy Điển? Tôi đã thử một mình và không thành công stackoverflow.com/questions/22835981/…
Niels Bosma

1
Công việc này đang được theo dõi ở đây: github.com/aspnet/Identity/issues/86 cho 3.0, chúng tôi có một số ý tưởng thô và nguyên mẫu, nhưng nó không hoàn toàn sẵn sàng nào cho check in
Hảo Kung

@HaoKung phù thủy phương pháp xử lý này ?? Tôi có thể tìm thấy nó ở đâu ?? Tôi muốn Tìm nó bằng cách sử dụng VS "Đi tới Thực hiện"!
AminM

119

Đối với ASP.NET Core: (Microsoft.AspNetCore.Identity 1.0.0)

Tạo một lớp kế thừa IdentityErrorDescriber và ghi đè các thông báo lỗi mong muốn.

public class CustomIdentityErrorDescriber : IdentityErrorDescriber
{
    public override IdentityError DefaultError() { return new IdentityError { Code = nameof(DefaultError), Description = $"An unknown failure has occurred." }; }
    public override IdentityError ConcurrencyFailure() { return new IdentityError { Code = nameof(ConcurrencyFailure), Description = "Optimistic concurrency failure, object has been modified." }; }
    public override IdentityError PasswordMismatch() { return new IdentityError { Code = nameof(PasswordMismatch), Description = "Incorrect password." }; }
    public override IdentityError InvalidToken() { return new IdentityError { Code = nameof(InvalidToken), Description = "Invalid token." }; }
    public override IdentityError LoginAlreadyAssociated() { return new IdentityError { Code = nameof(LoginAlreadyAssociated), Description = "A user with this login already exists." }; }
    public override IdentityError InvalidUserName(string userName) { return new IdentityError { Code = nameof(InvalidUserName), Description = $"User name '{userName}' is invalid, can only contain letters or digits." }; }
    public override IdentityError InvalidEmail(string email) { return new IdentityError { Code = nameof(InvalidEmail), Description = $"Email '{email}' is invalid."  }; }
    public override IdentityError DuplicateUserName(string userName) { return new IdentityError { Code = nameof(DuplicateUserName), Description = $"User Name '{userName}' is already taken."  }; }
    public override IdentityError DuplicateEmail(string email) { return new IdentityError { Code = nameof(DuplicateEmail), Description = $"Email '{email}' is already taken."  }; }
    public override IdentityError InvalidRoleName(string role) { return new IdentityError { Code = nameof(InvalidRoleName), Description = $"Role name '{role}' is invalid."  }; }
    public override IdentityError DuplicateRoleName(string role) { return new IdentityError { Code = nameof(DuplicateRoleName), Description = $"Role name '{role}' is already taken."  }; }
    public override IdentityError UserAlreadyHasPassword() { return new IdentityError { Code = nameof(UserAlreadyHasPassword), Description = "User already has a password set." }; }
    public override IdentityError UserLockoutNotEnabled() { return new IdentityError { Code = nameof(UserLockoutNotEnabled), Description = "Lockout is not enabled for this user." }; }
    public override IdentityError UserAlreadyInRole(string role) { return new IdentityError { Code = nameof(UserAlreadyInRole), Description = $"User already in role '{role}'."  }; }
    public override IdentityError UserNotInRole(string role) { return new IdentityError { Code = nameof(UserNotInRole), Description = $"User is not in role '{role}'."  }; }
    public override IdentityError PasswordTooShort(int length) { return new IdentityError { Code = nameof(PasswordTooShort), Description = $"Passwords must be at least {length} characters."  }; }
    public override IdentityError PasswordRequiresNonAlphanumeric() { return new IdentityError { Code = nameof(PasswordRequiresNonAlphanumeric), Description = "Passwords must have at least one non alphanumeric character." }; }
    public override IdentityError PasswordRequiresDigit() { return new IdentityError { Code = nameof(PasswordRequiresDigit), Description = "Passwords must have at least one digit ('0'-'9')." }; }
    public override IdentityError PasswordRequiresLower() { return new IdentityError { Code = nameof(PasswordRequiresLower), Description = "Passwords must have at least one lowercase ('a'-'z')." }; }
    public override IdentityError PasswordRequiresUpper() { return new IdentityError { Code = nameof(PasswordRequiresUpper), Description = "Passwords must have at least one uppercase ('A'-'Z')." }; }
}

Trên lớp Khởi động của bạn, đăng ký ErrorDescriber tùy chỉnh bên trong ConfigureServices:

services.AddIdentity<ApplicationUser, IdentityRole>()
                .AddErrorDescriber<CustomIdentityErrorDescriber>(); // Add this line

CẬP NHẬT: Dưới đây, bạn có thể tìm thấy các phiên bản đã được dịch cho tiếng Tây Ban Nha và tiếng Bồ Đào Nha. Kiểm tra kỹ chúng!

public class SpanishIdentityErrorDescriber : IdentityErrorDescriber
{
    public override IdentityError DefaultError() { return new IdentityError { Code = nameof(DefaultError), Description = $"Ha ocurrido un error." }; }
    public override IdentityError ConcurrencyFailure() { return new IdentityError { Code = nameof(ConcurrencyFailure), Description = "Ha ocurrido un error, el objeto ya ha sido modificado (Optimistic concurrency failure)." }; }
    public override IdentityError PasswordMismatch() { return new IdentityError { Code = nameof(PasswordMismatch), Description = "Password Incorrecta." }; }
    public override IdentityError InvalidToken() { return new IdentityError { Code = nameof(InvalidToken), Description = "Ha ingresado un código Inválido." }; }
    public override IdentityError LoginAlreadyAssociated() { return new IdentityError { Code = nameof(LoginAlreadyAssociated), Description = "Un usuario con ese nombre ya existe." }; }
    public override IdentityError InvalidUserName(string userName) { return new IdentityError { Code = nameof(InvalidUserName), Description = $"El nombre de usuario '{userName}' es inválido. Solo puede contener letras y números." }; }
    public override IdentityError InvalidEmail(string email) { return new IdentityError { Code = nameof(InvalidEmail), Description = $"La dirección de email '{email}' es incorrecta."  }; }
    public override IdentityError DuplicateUserName(string userName) { return new IdentityError { Code = nameof(DuplicateUserName), Description = $"El usuario '{userName}' ya existe, por favor ingrese un nombre diferente."  }; }
    public override IdentityError DuplicateEmail(string email) { return new IdentityError { Code = nameof(DuplicateEmail), Description = $"La direccion de email '{email}' ya se encuentra registrada. Puede recupar su contraseña para ingresar nuevamente al sistema."  }; }
    public override IdentityError InvalidRoleName(string role) { return new IdentityError { Code = nameof(InvalidRoleName), Description = $"El nombre de rol '{role}' es inválido."  }; }
    public override IdentityError DuplicateRoleName(string role) { return new IdentityError { Code = nameof(DuplicateRoleName), Description = $"El nombre de rol '{role}' ya existe."  }; }
    public override IdentityError UserAlreadyHasPassword() { return new IdentityError { Code = nameof(UserAlreadyHasPassword), Description = "El usuario ya tiene contraseña." }; }
    public override IdentityError UserLockoutNotEnabled() { return new IdentityError { Code = nameof(UserLockoutNotEnabled), Description = "El bloqueo no esta habilitado para este usuario." }; }
    public override IdentityError UserAlreadyInRole(string role) { return new IdentityError { Code = nameof(UserAlreadyInRole), Description = $"El usuario ya es parte del rol '{role}'."  }; }
    public override IdentityError UserNotInRole(string role) { return new IdentityError { Code = nameof(UserNotInRole), Description = $"El usuario no es parte del rol '{role}'."  }; }
    public override IdentityError PasswordTooShort(int length) { return new IdentityError { Code = nameof(PasswordTooShort), Description = $"La contraseña deben tener un largo mínimo de {length} caracteres."  }; }
    public override IdentityError PasswordRequiresNonAlphanumeric() { return new IdentityError { Code = nameof(PasswordRequiresNonAlphanumeric), Description = "La contraseña debe contener al menos un caracter alfanumérico." }; }
    public override IdentityError PasswordRequiresDigit() { return new IdentityError { Code = nameof(PasswordRequiresDigit), Description = "La contraseña debe incluir al menos un dígito ('0'-'9')." }; }
    public override IdentityError PasswordRequiresLower() { return new IdentityError { Code = nameof(PasswordRequiresLower), Description = "La contraseña debe incluir al menos una letra minúscula ('a'-'z')." }; }
    public override IdentityError PasswordRequiresUpper() { return new IdentityError { Code = nameof(PasswordRequiresUpper), Description = "La contraseña debe incluir al menos una letra MAYÚSCULA ('A'-'Z')." }; }
}

Tiếng Bồ Đào Nha: (cảm ơn rất nhiều vì furlanrapha )

public class PortugueseIdentityErrorDescriber : IdentityErrorDescriber
{
    public override IdentityError DefaultError() { return new IdentityError { Code = nameof(DefaultError), Description = $"Um erro desconhecido ocorreu." }; }
    public override IdentityError ConcurrencyFailure() { return new IdentityError { Code = nameof(ConcurrencyFailure), Description = "Falha de concorrência otimista, o objeto foi modificado." }; }
    public override IdentityError PasswordMismatch() { return new IdentityError { Code = nameof(PasswordMismatch), Description = "Senha incorreta." }; }
    public override IdentityError InvalidToken() { return new IdentityError { Code = nameof(InvalidToken), Description = "Token inválido." }; }
    public override IdentityError LoginAlreadyAssociated() { return new IdentityError { Code = nameof(LoginAlreadyAssociated), Description = "Já existe um usuário com este login." }; }
    public override IdentityError InvalidUserName(string userName) { return new IdentityError { Code = nameof(InvalidUserName), Description = $"Login '{userName}' é inválido, pode conter apenas letras ou dígitos." }; }
    public override IdentityError InvalidEmail(string email) { return new IdentityError { Code = nameof(InvalidEmail), Description = $"Email '{email}' é inválido." }; }
    public override IdentityError DuplicateUserName(string userName) { return new IdentityError { Code = nameof(DuplicateUserName), Description = $"Login '{userName}' já está sendo utilizado." }; }
    public override IdentityError DuplicateEmail(string email) { return new IdentityError { Code = nameof(DuplicateEmail), Description = $"Email '{email}' já está sendo utilizado." }; }
    public override IdentityError InvalidRoleName(string role) { return new IdentityError { Code = nameof(InvalidRoleName), Description = $"A permissão '{role}' é inválida." }; }
    public override IdentityError DuplicateRoleName(string role) { return new IdentityError { Code = nameof(DuplicateRoleName), Description = $"A permissão '{role}' já está sendo utilizada." }; }
    public override IdentityError UserAlreadyHasPassword() { return new IdentityError { Code = nameof(UserAlreadyHasPassword), Description = "Usuário já possui uma senha definida." }; }
    public override IdentityError UserLockoutNotEnabled() { return new IdentityError { Code = nameof(UserLockoutNotEnabled), Description = "Lockout não está habilitado para este usuário." }; }
    public override IdentityError UserAlreadyInRole(string role) { return new IdentityError { Code = nameof(UserAlreadyInRole), Description = $"Usuário já possui a permissão '{role}'." }; }
    public override IdentityError UserNotInRole(string role) { return new IdentityError { Code = nameof(UserNotInRole), Description = $"Usuário não tem a permissão '{role}'." }; }
    public override IdentityError PasswordTooShort(int length) { return new IdentityError { Code = nameof(PasswordTooShort), Description = $"Senhas devem conter ao menos {length} caracteres." }; }
    public override IdentityError PasswordRequiresNonAlphanumeric() { return new IdentityError { Code = nameof(PasswordRequiresNonAlphanumeric), Description = "Senhas devem conter ao menos um caracter não alfanumérico." }; }
    public override IdentityError PasswordRequiresDigit() { return new IdentityError { Code = nameof(PasswordRequiresDigit), Description = "Senhas devem conter ao menos um digito ('0'-'9')." }; }
    public override IdentityError PasswordRequiresLower() { return new IdentityError { Code = nameof(PasswordRequiresLower), Description = "Senhas devem conter ao menos um caracter em caixa baixa ('a'-'z')." }; }
    public override IdentityError PasswordRequiresUpper() { return new IdentityError { Code = nameof(PasswordRequiresUpper), Description = "Senhas devem conter ao menos um caracter em caixa alta ('A'-'Z')." }; }
}

2
Đây là một cách tiếp cận hay khi sử dụng MVC Core.
MeanGreen,

2
Điều gì xảy ra nếu tôi cần hỗ trợ nhiều ngôn ngữ? có cách nào được xây dựng để phân biệt giữa những Người đăng ký Lỗi khác nhau không hay tôi có cần tự mình thực hiện một số bản vá kỳ lạ không?
gilmishal

@gilmishal Câu hỏi tuyệt vời. Tôi không có yêu cầu đó, vì vậy tôi không chắc chắn. Tôi đoán là kiểm tra CurrentCultureIdentityErrorDescriber và trả về các thông báo lỗi đã bản địa hóa, nhưng đó là một công thức cho mã lộn xộn. Các tệp tài nguyên phải là cách thích hợp. Có vẻ như triển khai ban đầu không thể mở rộng (vui lòng sửa cho tôi nếu tôi sai) nhưng sử dụng tệp res. Có thể kết hợp ErrorDescr gốc ban đầu + tệp tài nguyên của nó và thêm tài nguyên mới cho ngôn ngữ của bạn?
Gerardo Grignoli

@gilmishal Chưa có giải pháp chính thức nào, hãy kiểm tra vấn đề này để biết các bản cập nhật từ MS: github.com/aspnet/Identity/issues/991#issuecomment-256516328
Gerardo Grignoli

6
@gilmishal Bạn có thể chèn hàm tạo của nó IdentityErrorDescriberbằng một IStringLocalizer. Để bản địa hóa, hãy xem: docs.microsoft.com/en-us/aspnet/core/fundamentals/localization
jasdefer

57

Kể từ phiên bản 2 của danh tính được phát hành vào ngày 20 tháng 3 năm 2014, giờ đây bạn có thể có các thông báo lỗi đã bản địa hóa.

Đầu tiên hãy cài đặt gói bản địa hóa danh tính.

Install-Package Microsoft.AspNet.Identity.Core.fr

Sau đó, văn hóa thích hợp phải được thiết lập để nhận được các thông điệp được bản địa hóa, ví dụ một cách để thiết lập văn hóa là trong web.config

<system.web>
      <globalization culture="fr-FR" uiCulture="fr"/>
</system.web>

3
Thật không may, dường như không có phiên bản dành cho người Thụy Điển? Có bạn nào biết có thể tự mình lấy nguồn và dịch cho người Thụy Điển được không?
Niels Bosma

1
nó có thể làm cho một dịch ngược dll và biên dịch lại để tiếp cận được với các file tài nguyên sử dụng các công cụ như .netReflector
Amir Jalali

@ 1AmirJaliali Tôi đã thử điều này nhưng không thành công :( stackoverflow.com/questions/22835981/… Bạn có bất kỳ gợi ý nào không?
Niels Bosma

Không làm việc cho tôi. Đã cài đặt tài nguyên tiếng Séc và tiếng Đức, đặt văn hóa Chủ đề thành cs-CZ trong BeginExecuteCore. Các tài nguyên của riêng tôi được tải tốt, nhưng các tài nguyên từ Identity.Core không hiển thị, tôi vẫn thấy các chuỗi tiếng Anh. Cần gì nữa không?
Tomas Voracek

11
Bất kỳ cập nhật nào về hỗ trợ đa ngôn ngữ cho Identity 2.0? Thật nực cười khi không có hỗ trợ đa ngôn ngữ trên thư viện như vậy !!! Cách giải quyết để tải xuống thư viện bằng ngôn ngữ bạn muốn sử dụng không phù hợp với mọi nhu cầu của các nhà phát triển vì có thể tôi cũng muốn thay đổi thông báo dựa trên mục tiêu người dùng của ứng dụng của mình. Cố lên MS!
Giox

23

Giải pháp ASP NET Core (25.11.2016)

Bạn có thể đưa IStringLocalizer vào IdentityErrorDescriber tùy chỉnh

1) Tạo IdentityErrorDescriber tùy chỉnh (xem câu trả lời của Gerardo Grignoli)

public class MultilanguageIdentityErrorDescriber : IdentityErrorDescriber
{
    private readonly IStringLocalizer<SharedResource> _localizer;

    public MultilanguageIdentityErrorDescriber(IStringLocalizer<SharedResource> localizer)
    {
        _localizer = localizer;
    }

    public override IdentityError DuplicateEmail(string email)
    {
        return new IdentityError()
        {
            Code = nameof(DuplicateEmail),
            Description = string.Format(_localizer["Email {0} is already taken."], email)
        };
    }

    // DuplicateUserName, InvalidEmail, DuplicateUserName etc
}

2) Đăng ký MultilanguageIdentityErrorDescriber trong Startup.cs

services.AddIdentity<IdentityUser, IdentityRole>()
            .AddErrorDescriber<MultilanguageIdentityErrorDescriber>()
            .AddDefaultTokenProviders();

3) Thêm thông báo lỗi vào SharedResource.language.resx.


Andril xuất sắc! Luôn luôn là tốt nhất để đặt các tài nguyên trong các tệp tài nguyên. Có lẽ chúng ta có thể sắp xếp để đặt mã này và một vài tài nguyên cho các ngôn ngữ phổ biến trên github hoặc thậm chí trên NuGet.
Gerardo Grignoli

@GerardoGrignoli Tôi hài lòng với cách tiếp cận này và tôi sử dụng nó trong sản xuất. Thật không may, tôi không có thời gian rảnh để làm việc này, nhưng tôi đã gửi ý tưởng này trên github. github.com/aspnet/Identity/issues/991 , có thể nó sẽ giúp ai đó hoặc nhóm nhà phát triển .NET Core sẽ tiếp thu ý tưởng này.
Andrew Basarab

Câu trả lời xuất sắc. Có lẽ tôi sẽ thêm rằng localizer không cần chuỗi. Định dạng, bạn có thể thêm các tham số trong []
harveyt

14

Tôi gặp phải vấn đề tương tự và tìm ra một giải pháp nhanh chóng và hiệu quả. Tôi đã xem xét bên trong Microsoft.AspNet.Identity.Coreassembly bằng DotPeek (tôi cho rằng bất kỳ trình dịch ngược C # nào cũng vậy) và tìm thấy hai lớp chịu trách nhiệm cho các thông báo như vậy:

  • Microsoft.AspNet.Identity.UserValidator<TUser> (Liên quan đến UserName)
  • Microsoft.AspNet.Identity.MinimumLengthValidator (Liên quan đến mật khẩu)

Các lớp này không chứa bất kỳ tham chiếu bên ngoài nào (ngoài các tài nguyên chuỗi mà bạn muốn thay thế), vì vậy việc triển khai lại chúng trong mã của riêng bạn sẽ khá đơn giản.

Sau khi làm như vậy, đừng quên sử dụng chúng đúng cách trong UserManager:

UserManager.UserValidator = new MyCustomUserValidator<MyUserType>(UserManager);
UserManager.PasswordValidator = new MyCustomMinimumLengthValidator(6);

1
@NielsBosma Nó hơi hacky, nhưng nó hoạt động tốt. Hãy xem cách triển khai UserValidatorMinumumLengthValidator của tôi , cung cấp bản địa hóa tiếng Romania.
Cristian Lupascu

13

cái này dành cho những người nói tiếng Farsi (Ba Tư) thân yêu

using Microsoft.AspNetCore.Identity;

namespace WebApplication.Admin.Helpers
{
    public class CustomIdentityErrorDescriber : IdentityErrorDescriber
    {
        public override IdentityError DefaultError() { return new IdentityError { Code = nameof(DefaultError), Description = $"یک خطای ناشناخته رخ داده است." }; }
        public override IdentityError ConcurrencyFailure() { return new IdentityError { Code = nameof(ConcurrencyFailure), Description = "رکورد جاری پیشتر ویرایش شده‌است و تغییرات شما آن‌را بازنویسی خواهد کرد." }; }
        public override IdentityError PasswordMismatch() { return new IdentityError { Code = nameof(PasswordMismatch), Description = "کلمه عبور نادرست است." }; }
        public override IdentityError InvalidToken() { return new IdentityError { Code = nameof(InvalidToken), Description = "کلمه عبور نامعتبر است." }; }
        public override IdentityError LoginAlreadyAssociated() { return new IdentityError { Code = nameof(LoginAlreadyAssociated), Description = "این کاربر قبلأ اضافه شده‌است." }; }
        public override IdentityError InvalidUserName(string userName) { return new IdentityError { Code = nameof(InvalidUserName), Description = $"نام کاربری '{userName}' نامعتبر است، فقط می تواند حاوی حروف ویا اعداد باشد." }; }
        public override IdentityError InvalidEmail(string email) { return new IdentityError { Code = nameof(InvalidEmail), Description = $"ایمیل '{email}' نامعتبر است." }; }
        public override IdentityError DuplicateUserName(string userName) { return new IdentityError { Code = nameof(DuplicateUserName), Description = $"این نام کاربری '{userName}' به کاربر دیگری اختصاص یافته است." }; }
        public override IdentityError DuplicateEmail(string email) { return new IdentityError { Code = nameof(DuplicateEmail), Description = $"ایمیل '{email}' به کاربر دیگری اختصاص یافته است." }; }
        public override IdentityError InvalidRoleName(string role) { return new IdentityError { Code = nameof(InvalidRoleName), Description = $"نام نقش '{role}' نامعتبر است." }; }
        public override IdentityError DuplicateRoleName(string role) { return new IdentityError { Code = nameof(DuplicateRoleName), Description = $"این نام نقش '{role}' به کاربر دیگری اختصاص یافته است." }; }
        public override IdentityError UserAlreadyHasPassword() { return new IdentityError { Code = nameof(UserAlreadyHasPassword), Description = "کلمه‌ی عبور کاربر قبلأ تنظیم شده‌است." }; }
        public override IdentityError UserLockoutNotEnabled() { return new IdentityError { Code = nameof(UserLockoutNotEnabled), Description = "این کاربر فعال است." }; }
        public override IdentityError UserAlreadyInRole(string role) { return new IdentityError { Code = nameof(UserAlreadyInRole), Description = $"این نقش '{role}' قبلأ به این کاربر اختصاص یافته است." }; }
        public override IdentityError UserNotInRole(string role) { return new IdentityError { Code = nameof(UserNotInRole), Description = $"این نقش '{role}' قبلأ به این کاربر اختصاص نیافته است." }; }
        public override IdentityError PasswordTooShort(int length) { return new IdentityError { Code = nameof(PasswordTooShort), Description = $"کلمه عبور باید حداقل {length} کاراکتر باشد." }; }
        public override IdentityError PasswordRequiresNonAlphanumeric() { return new IdentityError { Code = nameof(PasswordRequiresNonAlphanumeric), Description = "کلمه عبور باید حداقل یک کاراکتر غیر از حروف الفبا داشته باشد." }; }
        public override IdentityError PasswordRequiresDigit() { return new IdentityError { Code = nameof(PasswordRequiresDigit), Description = "کلمه عبور باید حداقل یک عدد داشته باشد." }; }
        public override IdentityError PasswordRequiresLower() { return new IdentityError { Code = nameof(PasswordRequiresLower), Description = "کلمه عبور باید حداقل یک حرف کوچک داشته باشد." }; }
        public override IdentityError PasswordRequiresUpper() { return new IdentityError { Code = nameof(PasswordRequiresUpper), Description = "کلمه عبور باید حداقل یک حرف بزرگ داشته باشد." }; }
        public override IdentityError RecoveryCodeRedemptionFailed() { return new IdentityError { Code = nameof(RecoveryCodeRedemptionFailed), Description = "بازیابی ناموفق بود." }; }
        public override IdentityError PasswordRequiresUniqueChars(int uniqueChars) { return new IdentityError { Code = nameof(PasswordRequiresUniqueChars), Description = $"کلمه عبور باید حداقل داراى {uniqueChars} حرف متفاوت باشد." }; }
    }
}

6

Phiên bản tiếng Đức cho Giải pháp của @GerardoGrignoli

public class CustomIdentityErrorDescriber : IdentityErrorDescriber
{
    public override IdentityError DefaultError() { return new IdentityError { Code = nameof(DefaultError), Description = $"Ein unbekannter Fehler ist aufgetreten." }; }
    public override IdentityError ConcurrencyFailure() { return new IdentityError { Code = nameof(ConcurrencyFailure), Description = "Fehler bzgl. der Optimistischen Nebenläufigkeit, das Objekt wurde verändert." }; }
    public override IdentityError PasswordMismatch() { return new IdentityError { Code = nameof(PasswordMismatch), Description = "Ungültiges Passwort." }; }
    public override IdentityError InvalidToken() { return new IdentityError { Code = nameof(InvalidToken), Description = "Ungültiger Token." }; }
    public override IdentityError LoginAlreadyAssociated() { return new IdentityError { Code = nameof(LoginAlreadyAssociated), Description = "Es ist bereits ein Nutzer mit diesem Login vorhanden." }; }
    public override IdentityError InvalidUserName(string userName) { return new IdentityError { Code = nameof(InvalidUserName), Description = $"Nutzername '{userName}' ist ungültig. Erlaubt sind nur Buchstaben und Zahlen." }; }
    public override IdentityError InvalidEmail(string email) { return new IdentityError { Code = nameof(InvalidEmail), Description = $"E-Mail '{email}' ist ungültig." }; }
    public override IdentityError DuplicateUserName(string userName) { return new IdentityError { Code = nameof(DuplicateUserName), Description = $"Nutzername '{userName}' ist bereits vergeben." }; }
    public override IdentityError DuplicateEmail(string email) { return new IdentityError { Code = nameof(DuplicateEmail), Description = $"E-Mail '{email}' ist bereits vergeben." }; }
    public override IdentityError InvalidRoleName(string role) { return new IdentityError { Code = nameof(InvalidRoleName), Description = $"Rollen-Name '{role}' ist ungültig." }; }
    public override IdentityError DuplicateRoleName(string role) { return new IdentityError { Code = nameof(DuplicateRoleName), Description = $"Rollen-Name '{role}' ist bereits vergeben." }; }
    public override IdentityError UserAlreadyHasPassword() { return new IdentityError { Code = nameof(UserAlreadyHasPassword), Description = "Nutzer hat bereits ein Passwort gesetzt." }; }
    public override IdentityError UserLockoutNotEnabled() { return new IdentityError { Code = nameof(UserLockoutNotEnabled), Description = "Aussperrung ist für diesen Nutzer nicht aktiviert." }; }
    public override IdentityError UserAlreadyInRole(string role) { return new IdentityError { Code = nameof(UserAlreadyInRole), Description = $"Nutzer ist bereits in Rolle '{role}'." }; }
    public override IdentityError UserNotInRole(string role) { return new IdentityError { Code = nameof(UserNotInRole), Description = $"Nutzer ist nicht in Rolle '{role}'." }; }
    public override IdentityError PasswordTooShort(int length) { return new IdentityError { Code = nameof(PasswordTooShort), Description = $"Passwörter müssen mindestens {length} Zeichen lang sein." }; }
    public override IdentityError PasswordRequiresNonAlphanumeric() { return new IdentityError { Code = nameof(PasswordRequiresNonAlphanumeric), Description = "Passwörter müssen mindestens ein Sonderzeichen enthalten." }; }
    public override IdentityError PasswordRequiresDigit() { return new IdentityError { Code = nameof(PasswordRequiresDigit), Description = "Passwörter müssen mindestens eine Ziffer enthalten ('0'-'9')." }; }
    public override IdentityError PasswordRequiresLower() { return new IdentityError { Code = nameof(PasswordRequiresLower), Description = "Passwörter müssen mindestens einen Kleinbuchstaben enthalten ('a'-'z')." }; }
    public override IdentityError PasswordRequiresUpper() { return new IdentityError { Code = nameof(PasswordRequiresUpper), Description = "Passwörter müssen mindestens einen Großbuchstaben enthalten ('A'-'Z')." }; }
}

Vielen Dank !! ;)
Tom el Safadi

3

Phương pháp của 1AmirJalali hoạt động hoàn hảo. Trong khi thiết lập văn hóa trong web.config hoạt động, nó cũng có thể được đặt động nếu được yêu cầu, đây là cách có thể đạt được điều này:

Thread.CurrentThread.CurrentCulture = new System.Globalization.CultureInfo(cultureName);
Thread.CurrentThread.CurrentUICulture = Thread.CurrentThread.CurrentCulture;

Trong ví dụ mã ở trên, cultureName, là tên của văn hóa sẽ được đặt. Bạn có thể tìm thấy danh sách các nền văn hóa trong tiêu đề "Nhận xét" tại đây: http://msdn.microsoft.com/en-us/library/system.globalization.cultureinfo%28v=vs.80%29.aspx

Hi vọng điêu nay co ich.


3

Tôi không muốn ghi đè logic (tức là phát minh lại bánh xe), cũng như không muốn chuyển sang ASP NET Core. Tất cả những gì tôi muốn làm là ghi đè các thông báo lỗi và sử dụng nhiều tệp tài nguyên (mỗi ngôn ngữ) để điều chỉnh trải nghiệm người dùng theo ngôn ngữ đã chọn của họ.

Đây là giải pháp của tôi:

  1. Tôi đã tạo tệp tài nguyên 'IdentityErrors.resx' như sau:

    <data name="DefaultError" xml:space="preserve">
        <value>An unknown failure has occured.</value>
    </data>
    <data name="DuplicateEmail" xml:space="preserve">
        <value>Email '{0}' is already taken.</value>
    </data>
    <data name="DuplicateName" xml:space="preserve">
        <value>Name {0} is already taken.</value>
    </data>
    <data name="ExternalLoginExists" xml:space="preserve">
        <value>A user with that external login already exists.</value>
    </data>
    <data name="InvalidEmail" xml:space="preserve">
        <value>Email '{0}' is invalid.</value>
    </data>
    <data name="InvalidToken" xml:space="preserve">
        <value>Invalid token.</value>
    </data>
    <data name="InvalidUserName" xml:space="preserve">
        <value>User name {0} is invalid, can only contain letters or digits.</value>
    </data>
    <data name="LockoutNotEnabled" xml:space="preserve">
        <value>Lockout is not enabled for this user.</value>
    </data>
    <data name="NoTokenProvider" xml:space="preserve">
        <value>No IUserTokenProvider is registered.</value>
    </data>
    <data name="NoTwoFactorProvider" xml:space="preserve">
        <value>No IUserTwoFactorProvider for '{0}' is registered.</value>
    </data>
    <data name="PasswordMismatch" xml:space="preserve">
        <value>Incorrect password.</value>
    </data>
    <data name="PasswordRequireDigit" xml:space="preserve">
        <value>Passwords must have at least one digit ('0'-'9').</value>
    </data>
    <data name="PasswordRequireLower" xml:space="preserve">
        <value>Passwords must have at least one lowercase ('a'-'z').</value>
    </data>
    <data name="PasswordRequireNonLetterOrDigit" xml:space="preserve">
        <value>Passwords must have at least one non letter or digit character.</value>
    </data>
    <data name="PasswordRequireUpper" xml:space="preserve">
        <value>Passwords must have at least one uppercase ('A'-'Z').</value>
    </data>
    <data name="PasswordTooShort" xml:space="preserve">
        <value>Passwords must be at least {0} characters.</value>
    </data>
    <data name="PropertyTooShort" xml:space="preserve">
        <value>{0} cannot be null or empty.</value>
    </data>
    <data name="RoleNotFound" xml:space="preserve">
        <value>Role {0} does not exist.</value>
    </data>
    <data name="StoreNotIQueryableRoleStore" xml:space="preserve">
        <value>Store does not implement IQueryableRoleStore&amp;lt;TRole&amp;gt;.</value>
    </data>
    <data name="StoreNotIQueryableUserStore" xml:space="preserve">
        <value>Store does not implement IQueryableUserStore&amp;lt;TUser&amp;gt;.</value>
    </data>
    <data name="StoreNotIUserClaimStore" xml:space="preserve">
        <value>Store does not implement IUserClaimStore&amp;lt;TUser&amp;gt;.</value>
    </data>
    <data name="StoreNotIUserConfirmationStore" xml:space="preserve">
        <value>Store does not implement IUserConfirmationStore&amp;lt;TUser&amp;gt;.</value>
    </data>
    <data name="StoreNotIUserEmailStore" xml:space="preserve">
        <value>Store does not implement IUserEmailStore&amp;lt;TUser&amp;gt;.</value>
    </data>
    <data name="StoreNotIUserLockoutStore" xml:space="preserve">
        <value>Store does not implement IUserLockoutStore&amp;lt;TUser&amp;gt;.</value>
    </data>
    <data name="StoreNotIUserLoginStore" xml:space="preserve">
        <value>Store does not implement IUserLoginStore&amp;lt;TUser&amp;gt;.</value>
    </data>
    <data name="StoreNotIUserPasswordStore" xml:space="preserve">
        <value>Store does not implement IUserPasswordStore&amp;lt;TUser&amp;gt;.</value>
    </data>
    <data name="StoreNotIUserPhoneNumberStore" xml:space="preserve">
        <value>Store does not implement IUserPhoneNumberStore&amp;lt;TUser&amp;gt;.</value>
    </data>
    <data name="StoreNotIUserRoleStore" xml:space="preserve">
        <value>Store does not implement IUserRoleStore&amp;lt;TUser&amp;gt;.</value>
    </data>
    <data name="StoreNotIUserSecurityStampStore" xml:space="preserve">
        <value>Store does not implement IUserSecurityStampStore&amp;lt;TUser&amp;gt;.</value>
    </data>
    <data name="StoreNotIUserTwoFactorStore" xml:space="preserve">
        <value>Store does not implement IUserTwoFactorStore&amp;lt;TUser&amp;gt;.</value>
    </data>
    <data name="UserAlreadyHasPassword" xml:space="preserve">
        <value>User already has a password set.</value>
    </data>
    <data name="UserAlreadyInRole" xml:space="preserve">
        <value>User already in role.</value>
    </data>
    <data name="UserIdNotFound" xml:space="preserve">
        <value>UserId not found.</value>
    </data>
    <data name="UserNameNotFound" xml:space="preserve">
        <value>User {0} does not exist.</value>
    </data>
    <data name="UserNotInRole" xml:space="preserve">
        <value>User is not in role.</value>
    </data>
    
  2. Tôi đã tạo một lớp 'IdentityResultErrorMessages.cs':

    public class IdentityResultErrorMessages
    {
      public static List<String> GetResourceEquivalent(IEnumerable<string> errors)
      {
        List<String> errorList = new List<String>();
        if (errors != null)
        {
          foreach (String error in errors)
          {
            if (error.StartsWith("An unknown failure has occured."))
            {
              errorList.Add(IdentityErrors.DefaultError);
            }
            else if (error.StartsWith("Email '") && error.EndsWith("' is already taken."))
            {
              errorList.Add(String.Format(IdentityErrors.DuplicateEmail, error.Replace("Email '", "").Replace("' is already taken.", "")));
            }
            else if (error.StartsWith("Name ") && error.EndsWith(" is already taken."))
            {
              errorList.Add(String.Format(IdentityErrors.DuplicateName, error.Replace("Name ", "").Replace(" is already taken.", "")));
            }
            else if (error.StartsWith("A user with that external login already exists."))
            {
              errorList.Add(IdentityErrors.ExternalLoginExists);
            }
            else if (error.StartsWith("Email '") && error.EndsWith("' is invalid."))
            {
              errorList.Add(String.Format(IdentityErrors.InvalidEmail, error.Replace("Email '", "").Replace("' is invalid.", "")));
            }
            else if (error.StartsWith("Invalid token."))
            {
              errorList.Add(IdentityErrors.InvalidToken);
            }
            else if (error.StartsWith("User name ") && error.EndsWith(" is invalid, can only contain letters or digits."))
            {
              errorList.Add(String.Format(IdentityErrors.InvalidUserName, error.Replace("User name ", "").Replace(" is invalid, can only contain letters or digits.", "")));
            }
            else if (error.StartsWith("Lockout is not enabled for this user."))
            {
              errorList.Add(IdentityErrors.LockoutNotEnabled);
            }
            else if (error.StartsWith("No IUserTokenProvider is registered."))
            {
              errorList.Add(IdentityErrors.NoTokenProvider);
            }
            else if (error.StartsWith("No IUserTwoFactorProvider for '") && error.EndsWith("' is registered."))
            {
              errorList.Add(String.Format(IdentityErrors.NoTwoFactorProvider, error.Replace("No IUserTwoFactorProvider for '", "").Replace("' is registered.", "")));
            }
            else if (error.StartsWith("Incorrect password."))
            {
              errorList.Add(IdentityErrors.PasswordMismatch);
            }
            else if (error.StartsWith("Passwords must have at least one digit ('0'-'9')."))
            {
              errorList.Add(IdentityErrors.PasswordRequireDigit);
            }
            else if (error.StartsWith("Passwords must have at least one lowercase ('a'-'z')."))
            {
              errorList.Add(IdentityErrors.PasswordRequireLower);
            }
            else if (error.StartsWith("Passwords must have at least one non letter or digit character."))
            {
              errorList.Add(IdentityErrors.PasswordRequireNonLetterOrDigit);
            }
            else if (error.StartsWith("Passwords must have at least one uppercase ('A'-'Z')."))
            {
              errorList.Add(IdentityErrors.PasswordRequireUpper);
            }
            else if (error.StartsWith("Passwords must be at least ") && error.EndsWith(" characters."))
            {
              errorList.Add(String.Format(IdentityErrors.PasswordTooShort, error.Replace("Passwords must be at least ", "").Replace(" characters.", "")));
            }
            else if (error.EndsWith(" cannot be null or empty."))
            {
              errorList.Add(String.Format(IdentityErrors.PropertyTooShort, error.Replace(" cannot be null or empty.", "")));
            }
            else if (error.StartsWith("Role ") && error.EndsWith(" does not exist."))
            {
              errorList.Add(String.Format(IdentityErrors.RoleNotFound, error.Replace("Role ", "").Replace(" does not exist.", "")));
            }
            else if (error.StartsWith("Store does not implement IQueryableRoleStore"))
            {
              errorList.Add(IdentityErrors.StoreNotIQueryableRoleStore);
            }
            else if (error.StartsWith("Store does not implement IQueryableUserStore"))
            {
              errorList.Add(IdentityErrors.StoreNotIQueryableUserStore);
            }
            else if (error.StartsWith("Store does not implement IUserClaimStore"))
            {
              errorList.Add(IdentityErrors.StoreNotIUserClaimStore);
            }
            else if (error.StartsWith("Store does not implement IUserConfirmationStore"))
            {
              errorList.Add(IdentityErrors.StoreNotIUserConfirmationStore);
            }
            else if (error.StartsWith("Store does not implement IUserEmailStore"))
            {
              errorList.Add(IdentityErrors.StoreNotIUserEmailStore);
            }
            else if (error.StartsWith("Store does not implement IUserLockoutStore"))
            {
              errorList.Add(IdentityErrors.StoreNotIUserLockoutStore);
            }
            else if (error.StartsWith("Store does not implement IUserLoginStore"))
            {
              errorList.Add(IdentityErrors.StoreNotIUserLoginStore);
            }
            else if (error.StartsWith("Store does not implement IUserPasswordStore"))
            {
              errorList.Add(IdentityErrors.StoreNotIUserPasswordStore);
            }
            else if (error.StartsWith("Store does not implement IUserPhoneNumberStore"))
            {
              errorList.Add(IdentityErrors.StoreNotIUserPhoneNumberStore);
            }
            else if (error.StartsWith("Store does not implement IUserRoleStore"))
            {
              errorList.Add(IdentityErrors.StoreNotIUserRoleStore);
            }
            else if (error.StartsWith("Store does not implement IUserSecurityStampStore"))
            {
              errorList.Add(IdentityErrors.StoreNotIUserSecurityStampStore);
            }
            else if (error.StartsWith("Store does not implement IUserTwoFactorStore"))
            {
              errorList.Add(IdentityErrors.StoreNotIUserTwoFactorStore);
            }
            else if (error.StartsWith("User already has a password set."))
            {
              errorList.Add(IdentityErrors.UserAlreadyHasPassword);
            }
            else if (error.StartsWith("User already in role."))
            {
              errorList.Add(IdentityErrors.UserAlreadyInRole);
            }
            else if (error.StartsWith("UserId not found."))
            {
              errorList.Add(IdentityErrors.UserIdNotFound);
            }
            else if (error.StartsWith("User ") && error.EndsWith(" does not exist."))
            {
              errorList.Add(String.Format(IdentityErrors.UserNameNotFound, error.Replace("User ", "").Replace(" does not exist.", "")));
            }
            else if (error.StartsWith("User is not in role."))
            {
              errorList.Add(IdentityErrors.UserNotInRole);
            }
          }
        }
        return errorList;
      }
    }
    
  3. Tôi đã thay đổi phương thức AddErrors của Bộ điều khiển thành như sau:

    private void AddErrors(IdentityResult result)
    {
      foreach (var error in IdentityResultErrorMessages.GetResourceEquivalent(result.Errors))
      {
        ModelState.AddModelError("", error);
      }
    }
    

Bây giờ, tôi có thể tạo các tệp tài nguyên cho nội dung ngôn ngữ khác mà tôi muốn cung cấp trên trang web của mình.


3
Giải pháp này không thành công ngay sau khi ai đó thay đổi thông báo lỗi tiếng Anh ban đầu. Tôi sẽ không khuyên bạn nên nó để làm nó như vậy ..
thomasgalliker

3

Dựa trên các câu trả lời ở đây, tôi đã thực hiện triển khai của riêng mình cho trang web đa ngôn ngữ của chúng tôi được xây dựng trên MVC Core 2.2, nơi các chuỗi không thể được mã hóa cứng.

Tôi đang sử dụng tệp tài nguyên cơ bản với trình thiết kế được tạo tự động để lấy các chuỗi và mã để làm điều đó trông giống như sau:

public class LocalizedIdentityErrorDescriber : IdentityErrorDescriber
{
    private ResourceManager ResourceManager { get; set; }

    public LocalizedIdentityErrorDescriber()
    {
        ResourceManager = Translations.ResourceManager;
    }

    public override IdentityError DefaultError() { return new IdentityError { Code = nameof(DefaultError), Description = Translations.Validation_DefaultError }; }
    public override IdentityError ConcurrencyFailure() { return new IdentityError { Code = nameof(ConcurrencyFailure), Description = Translations.Validation_ConcurrencyFailure }; }
    public override IdentityError PasswordMismatch() { return new IdentityError { Code = nameof(PasswordMismatch), Description = Translations.Validation_PasswordMismatch }; }
    public override IdentityError InvalidToken() { return new IdentityError { Code = nameof(InvalidToken), Description = Translations.Validation_InvalidToken }; }
    public override IdentityError LoginAlreadyAssociated() { return new IdentityError { Code = nameof(LoginAlreadyAssociated), Description = Translations.Validation_LoginAlreadyAssociated }; }
    public override IdentityError InvalidUserName(string userName) { return new IdentityError { Code = nameof(InvalidUserName), Description = string.Format(Translations.Validation_InvalidUserName, userName) }; }
    public override IdentityError InvalidEmail(string email) { return new IdentityError { Code = nameof(InvalidEmail), Description = string.Format(Translations.Validation_InvalidEmail, email) }; }
    public override IdentityError DuplicateUserName(string userName) { return new IdentityError { Code = nameof(DuplicateUserName), Description = string.Format(Translations.Validation_DuplicateUserName, userName) }; }
    public override IdentityError DuplicateEmail(string email) { return new IdentityError { Code = nameof(DuplicateEmail), Description = string.Format(Translations.Validation_DuplicateEmail, email) }; }
    public override IdentityError InvalidRoleName(string role) { return new IdentityError { Code = nameof(InvalidRoleName), Description = string.Format(Translations.Validation_InvalidRoleName, role) }; }
    public override IdentityError DuplicateRoleName(string role) { return new IdentityError { Code = nameof(DuplicateRoleName), Description = string.Format(Translations.Validation_DuplicateRoleName, role) }; }
    public override IdentityError UserAlreadyHasPassword() { return new IdentityError { Code = nameof(UserAlreadyHasPassword), Description = Translations.Validation_UserAlreadyHasPassword }; }
    public override IdentityError UserLockoutNotEnabled() { return new IdentityError { Code = nameof(UserLockoutNotEnabled), Description = Translations.Validation_UserLockoutNotEnabled }; }
    public override IdentityError UserAlreadyInRole(string role) { return new IdentityError { Code = nameof(UserAlreadyInRole), Description = string.Format(Translations.Validation_UserAlreadyInRole, role) }; }
    public override IdentityError UserNotInRole(string role) { return new IdentityError { Code = nameof(UserNotInRole), Description = string.Format(Translations.Validation_UserNotInRole, role) }; }
    public override IdentityError PasswordTooShort(int length) { return new IdentityError { Code = nameof(PasswordTooShort), Description = string.Format(Translations.Validation_PasswordTooShort, length) }; }
    public override IdentityError PasswordRequiresNonAlphanumeric() { return new IdentityError { Code = nameof(PasswordRequiresNonAlphanumeric), Description = Translations.Validation_PasswordRequiresNonAlphanumeric }; }
    public override IdentityError PasswordRequiresDigit() { return new IdentityError { Code = nameof(PasswordRequiresDigit), Description = Translations.Validation_PasswordRequiresDigit }; }
    public override IdentityError PasswordRequiresLower() { return new IdentityError { Code = nameof(PasswordRequiresLower), Description = Translations.Validation_PasswordRequiresLower }; }
    public override IdentityError PasswordRequiresUpper() { return new IdentityError { Code = nameof(PasswordRequiresUpper), Description = Translations.Validation_PasswordRequiresUpper }; }
}

Sau đó, nó được tích hợp trong đường dẫn Danh tính trong Startup.cs

services.AddDefaultIdentity<User>()
    .AddErrorDescriber<LocalizedIdentityErrorDescriber>()
    .AddDefaultTokenProviders();

Cuối cùng, tôi đã xác định các chuỗi trong tệp Translations.resx và tài nguyên phụ của mình, trong đó các khóa được đặt tên là Validation_DefaultError, Validation_PasswordMismatch, v.v.


2

Vấn đề này đã làm phiền tôi một thời gian rồi vì vậy tôi đã cố gắng tìm ra một cái gì đó chung chung, vì giải pháp cài đặt Identity.Core cho văn hóa cụ thể chỉ hoạt động nếu gói có sẵn :)

Dưới đây là các bước để tôi đạt được bản địa hóa thích hợp:

  1. Đã xem xét việc triển khai Microsoft.AspNet.Identity.PasswordValidatorsử dụng dotPeak được sử dụng theo mặc định trongApplicationUserManager ,
  2. Sau đó, tôi nghĩ ra cách triển khai của riêng mình class CustomPasswordValidator : PasswordValidatorvà ghi đè ValidateAsyncphương thức để không trả vềIdentityResult thông báo lỗi, mà thay vào đó là "mã" của những thông báo lỗi này, tất cả chúng đều có tiền tố là chuỗi "CustomValidator".
  3. Sau đó, AccountControllertôi đã thay đổi AddErrorsđược gọi từ Registerbài đăng để cung cấp thông báo lỗi được bản địa hóa từ các tệp tài nguyên của riêng tôi dựa trên mã lỗi.

Đây là lớp CustomPasswordValidatorvà tiện ích PasswordValidatorCodescó chứa mã lỗi và phương pháp để truy xuất thông báo lỗi được bản địa hóa dựa trên các mã này (Chuỗi tài khoản là một tệp tài nguyên):

public static class PasswordValidatorCodes
{
    public const string ErrorCodePrefix = "CustomPassword";
    public const string PasswordTooShort = ErrorCodePrefix + "TooShort";
    public const string PasswordRequireNonLetterOrDigit = ErrorCodePrefix + "RequireNonLetterOrDigit";
    public const string PasswordRequireDigit = ErrorCodePrefix + "RequireDigit";
    public const string PasswordRequireLower = ErrorCodePrefix + "RequireLower";
    public const string PasswordRequireUpper = ErrorCodePrefix + "RequireUpper";

    public static string GetLocalizedMessageForCode(string code)
    {
        switch (code)
        {
            case PasswordTooShort:
                return string.Format(AccountStrings.ValidationPasswordTooShort, CustomPasswordValidator.RequiredPasswordLength);
            case PasswordRequireNonLetterOrDigit:
                return AccountStrings.ValidationPasswordRequireNonLetterOrDigit;
            case PasswordRequireDigit:
                return AccountStrings.ValidationPasswordRequireDigit;
            case PasswordRequireLower:
                return AccountStrings.ValidationPasswordRequireLower;
            case PasswordRequireUpper:
                return AccountStrings.ValidationPasswordRequireUpper;
            default:
                throw new ArgumentException("code");
        }
    }
}

public class CustomPasswordValidator : PasswordValidator
{
    public const int RequiredPasswordLength = 6;

    public CustomPasswordValidator()
    {
        RequiredLength = RequiredPasswordLength;
        RequireNonLetterOrDigit = false;
        RequireDigit = true;
        RequireLowercase = true;
        RequireUppercase = false;
    }

    public override Task<IdentityResult> ValidateAsync(string item)
    {
        if (item == null) throw new ArgumentNullException("item");
        var list = new List<string>();

        if (string.IsNullOrWhiteSpace(item) || item.Length < RequiredLength)
        {
            list.Add(PasswordValidatorCodes.PasswordTooShort);
        }

        if (RequireNonLetterOrDigit && item.All(IsLetterOrDigit))
        {
            list.Add(PasswordValidatorCodes.PasswordRequireNonLetterOrDigit);
        }

        if (RequireDigit && item.All(c => !IsDigit(c)))
        {
            list.Add(PasswordValidatorCodes.PasswordRequireDigit);
        }

        if (RequireLowercase && item.All(c => !IsLower(c)))
        {
            list.Add(PasswordValidatorCodes.PasswordRequireLower);
        }

        if (RequireUppercase && item.All(c => !IsUpper(c)))
        {
            list.Add(PasswordValidatorCodes.PasswordRequireUpper);
        }

        return Task.FromResult(list.Count == 0
            ? IdentityResult.Success
            : new IdentityResult(list));
    }
}

Và đây là AccountController.AddErrorsphương pháp đã sửa đổi . Như bạn có thể thấy, tôi đang thêm lỗi vào mô hình cho thuộc tính Passwordbởi vì nếu thuộc tính Passwordkhông vượt qua xác thực thì tôi muốn trường này hiển thị thông báo lỗi Passwordvà không có trong tóm tắt xác thực. Đây là lý do duy nhất khiến tôi CustomPasswordValidatortạo ra mã lỗi chứ không phải thông báo lỗi trực tiếp:

private void AddErrors(IdentityResult result)
{
    foreach (var error in result.Errors)
    {
        if (error.StartsWith(PasswordValidatorCodes.ErrorCodePrefix))
        {
            ModelState.AddModelError("Password", PasswordValidatorCodes.GetLocalizedMessageForCode(error));
            continue;
        }
        ModelState.AddModelError(string.Empty, error);
    }
}

Cuối cùng nhưng không kém phần quan trọng, đừng quên sửa đổi IdentityConfigtệp, tức là:

manager.PasswordValidator = new CustomPasswordValidator();

CẬP NHẬT:

Chỉ bây giờ tôi mới nhận thấy rằng Marselus Chia (xem các câu trả lời khác) đã đưa ra giải pháp tương tự nhưng cho VB.


2

Đây là câu trả lời của Gerardo Grignoli với bản dịch tiếng Pháp

/// <inheritdoc />
/// <summary>
/// Service to enable localization (french) for application facing identity errors.
/// </summary>
public class FrenchIdentityErrorDescriber : IdentityErrorDescriber
{
    /// <inheritdoc />
    public override IdentityError DefaultError() => new IdentityError { Code = nameof(DefaultError), Description = "Une erreur inconnue est survenue." };

    /// <inheritdoc />
    public override IdentityError ConcurrencyFailure() => new IdentityError { Code = nameof(ConcurrencyFailure), Description = "Erreur de concurrence simultanée optimiste, l'objet a été modifié." };

    /// <inheritdoc />
    public override IdentityError PasswordMismatch() => new IdentityError { Code = nameof(PasswordMismatch), Description = "Mot de passe incorrect." };

    /// <inheritdoc />
    public override IdentityError InvalidToken() => new IdentityError { Code = nameof(InvalidToken), Description = "Jeton invalide." };

    /// <inheritdoc />
    public override IdentityError LoginAlreadyAssociated() => new IdentityError { Code = nameof(LoginAlreadyAssociated), Description = "Un utilisateur avec ce nom de compte existe déjà." };

    /// <inheritdoc />
    public override IdentityError InvalidUserName(string userName) => new IdentityError { Code = nameof(InvalidUserName), Description = $"Le nom de compte '{userName}' est invalide. Seuls les lettres et chiffres sont autorisés." };

    /// <inheritdoc />
    public override IdentityError InvalidEmail(string email) => new IdentityError { Code = nameof(InvalidEmail), Description = $"L'email '{email}' est invalide." };

    /// <inheritdoc />
    public override IdentityError DuplicateUserName(string userName) => new IdentityError { Code = nameof(DuplicateUserName), Description = $"Le nom de compte '{userName}' est déjà utilisé." };

    /// <inheritdoc />
    public override IdentityError DuplicateEmail(string email) => new IdentityError { Code = nameof(DuplicateEmail), Description = $"L'email '{email} est déjà utilisée." };

    /// <inheritdoc />
    public override IdentityError InvalidRoleName(string role) => new IdentityError { Code = nameof(InvalidRoleName), Description = $"Le nom du rôle '{role}' est invalide." };

    /// <inheritdoc />
    public override IdentityError DuplicateRoleName(string role) => new IdentityError { Code = nameof(DuplicateRoleName), Description = $"Le nom du rôle '{role}' est déjà utilisé." };

    /// <inheritdoc />
    public override IdentityError UserAlreadyHasPassword() => new IdentityError { Code = nameof(UserAlreadyHasPassword), Description = "L'utilisateur a déjà un mot de passe." };

    /// <inheritdoc />
    public override IdentityError UserLockoutNotEnabled() => new IdentityError { Code = nameof(UserLockoutNotEnabled), Description = "Le verouillage n'est pas activé pour cet utilisateur." };

    /// <inheritdoc />
    public override IdentityError UserAlreadyInRole(string role) => new IdentityError { Code = nameof(UserAlreadyInRole), Description = $"L'utilisateur a déjà le rôle '{role}'." };

    /// <inheritdoc />
    public override IdentityError UserNotInRole(string role) => new IdentityError { Code = nameof(UserNotInRole), Description = $"L'utilisateur n'a pas le rôle '{role}'." };

    /// <inheritdoc />
    public override IdentityError PasswordTooShort(int length) => new IdentityError { Code = nameof(PasswordTooShort), Description = $"Le mot de passe doit contenir au moins {length} caractères." };

    /// <inheritdoc />
    public override IdentityError PasswordRequiresNonAlphanumeric() => new IdentityError { Code = nameof(PasswordRequiresNonAlphanumeric), Description = "Le mot de passe doit contenir au moins un caractère non alpha-numérique." };

    /// <inheritdoc />
    public override IdentityError PasswordRequiresDigit() => new IdentityError { Code = nameof(PasswordRequiresDigit), Description = "Le mot de passe doit contenir au moins un chiffre ('0'-'9')." };

    /// <inheritdoc />
    public override IdentityError PasswordRequiresLower() => new IdentityError { Code = nameof(PasswordRequiresLower), Description = "Le mot de passe doit contenir au moins un charactère minuscule ('a'-'z')." };

    /// <inheritdoc />
    public override IdentityError PasswordRequiresUpper() => new IdentityError { Code = nameof(PasswordRequiresUpper), Description = "Le mot de passe doit contenir au moins un charactère majuscule ('A'-'Z')." };
}

2

Xin chào Đây là Giải pháp của tôi để dịch các lỗi nhận dạng:

 public string TranslateIdentityResult(string massage)
    {

        var list = new List<KeyValuePair<string, string>>() {
            new KeyValuePair<string, string>("An unknown failure has occured.", "حدث خطأ غير معروف"),
            new KeyValuePair<string, string>("Email '{0}' is already taken.", "هذا البريد '{0}' موجود بالفعل"),
            new KeyValuePair<string, string>("Name {0} is already taken.", "الاسم {0} مأخوذ بالفعل."),
            new KeyValuePair<string, string>("A user with that external login already exists.", "يوجد بالفعل مستخدم له معلومات تسجيل الدخول الخارجية."),
            new KeyValuePair<string, string>("Email '{0}' is invalid.", "البريد الإلكتروني '{0}' غير صحيح."),
            new KeyValuePair<string, string>("Invalid token.", "المفتاح غير صالح"),
            new KeyValuePair<string, string>("User name {0} is invalid, can only contain letters or digits.", "اسم المستخدم {0} غير صالح ، يمكن أن يحتوي فقط على أحرف أو أرقام."),
            new KeyValuePair<string, string>("Lockout is not enabled for this user.", "تأمين المستخدم غير متاح لهذا المستخدم"),
            new KeyValuePair<string, string>("Incorrect password.", "الرقم السري غير صحيح"),
            new KeyValuePair<string, string>("Passwords must have at least one digit ('0'-'9').", "الرقم السري يجب أ،ن يحتوي على الأقل رقم واحد (0-9)"),
            new KeyValuePair<string, string>("Passwords must have at least one lowercase ('a'-'z').", "يجب أن تحتوي كلمات المرور على حرف صغير واحد على الأقل ('a' - 'z')."),
            new KeyValuePair<string, string>("Passwords must have at least one non letter or digit character.", "يجب أن يكون لكلمة مرور حرف واحد على الأقل غير الحرف أو الرقم."),
            new KeyValuePair<string, string>("Passwords must have at least one uppercase ('A'-'Z').", "يجب أن تحتوي كلمات المرور على حرف كبير واحد على الأقل ('A' - 'Z')."),
            new KeyValuePair<string, string>("Passwords must be at least {0} characters.", "يجب أن تكون كلمات المرور على الأقل {0} حرفًا."),
            new KeyValuePair<string, string>("{0} cannot be null or empty.", "لا يمكن أن يكون {0} خاليًا أو فارغًا."),
            new KeyValuePair<string, string>("Role {0} does not exist.", "صلاحية {0} غير موجود."),
            new KeyValuePair<string, string>("User already has a password set.", "المستخدم لديه بالفعل كلمة مرور محددة."),
            new KeyValuePair<string, string>("User already in role.", "المستخدم بالفعل لديه هذي الصلاحية."),
            new KeyValuePair<string, string>("UserId not found.", "لم يتم العثور على هوية المستخدم."),
            new KeyValuePair<string, string>("User {0} does not exist.", "المستخدم {0} غير موجود."),
            new KeyValuePair<string, string>("User is not in role.", "المستخدم ليس لديه صلاحية.")
        };

        return list.Find(x => x.Key.Equals(massage)).Value;
    }

 private void AddErrors(IdentityResult result)
    {
        foreach (var error in result.Errors)
        {
            //if my function is not found error it will print it as it's
            foreach(var msg in error.Split('.'))
            {
                ModelState.AddModelError("", accBClass.TranslateIdentityResult(msg.TrimStart(' ')) ?? msg);
            }
        }
    }

Thí dụ


2

Ngoài @Gerardo Grinolli trả lời phiên bản dịch này cho tiếng Nga:

public class CustomIdentityErrorDescriber : IdentityErrorDescriber
{
    public override IdentityError DefaultError() { return new IdentityError { Code = nameof(DefaultError), Description = $"Произошла неизвестная ошибка" }; }
    public override IdentityError ConcurrencyFailure() { return new IdentityError { Code = nameof(ConcurrencyFailure), Description = "Ошибка оптимистичного контроля параллелизма, объект был изменён" }; }
    public override IdentityError PasswordMismatch() { return new IdentityError { Code = nameof(PasswordMismatch), Description = "Некорретный пароль" }; }
    public override IdentityError InvalidToken() { return new IdentityError { Code = nameof(InvalidToken), Description = "Недействительный токен" }; }
    public override IdentityError LoginAlreadyAssociated() { return new IdentityError { Code = nameof(LoginAlreadyAssociated), Description = "Пользователь с таким логином уже существует" }; }
    public override IdentityError InvalidUserName(string userName) { return new IdentityError { Code = nameof(InvalidUserName), Description = $"Имя пользователя '{userName}' некорректно, может содержать только буквы и цифры" }; }
    public override IdentityError InvalidEmail(string email) { return new IdentityError { Code = nameof(InvalidEmail), Description = $"Email '{email}' некорректен" }; }
    public override IdentityError DuplicateUserName(string userName) { return new IdentityError { Code = nameof(DuplicateUserName), Description = $"Пользователь с именем '{userName}' уже существует" }; }
    public override IdentityError DuplicateEmail(string email) { return new IdentityError { Code = nameof(DuplicateEmail), Description = $"Email '{email}' уже используется" }; }
    public override IdentityError InvalidRoleName(string role) { return new IdentityError { Code = nameof(InvalidRoleName), Description = $"Имя роли '{role}' некорректно" }; }
    public override IdentityError DuplicateRoleName(string role) { return new IdentityError { Code = nameof(DuplicateRoleName), Description = $"Имя роли '{role}' уже используется" }; }
    public override IdentityError UserAlreadyHasPassword() { return new IdentityError { Code = nameof(UserAlreadyHasPassword), Description = "Пользователь уже установил пароль" }; }
    public override IdentityError UserLockoutNotEnabled() { return new IdentityError { Code = nameof(UserLockoutNotEnabled), Description = "Блокировка недоступна для этого пользователя" }; }
    public override IdentityError UserAlreadyInRole(string role) { return new IdentityError { Code = nameof(UserAlreadyInRole), Description = $"Пользователю уже присвоена роль '{role}'." }; }
    public override IdentityError UserNotInRole(string role) { return new IdentityError { Code = nameof(UserNotInRole), Description = $"У пользователя нет роли '{role}'." }; }
    public override IdentityError PasswordTooShort(int length) { return new IdentityError { Code = nameof(PasswordTooShort), Description = $"Пароль должен быть длиной не менее {length} символов" }; }
    public override IdentityError PasswordRequiresNonAlphanumeric() { return new IdentityError { Code = nameof(PasswordRequiresNonAlphanumeric), Description = "Пароль должен быть содержать хотя бы один не буквенно-цифровой символ" }; }
    public override IdentityError PasswordRequiresDigit() { return new IdentityError { Code = nameof(PasswordRequiresDigit), Description = "Пароль должен содержать хотя бы одну цифру ('0'-'9')." }; }
    public override IdentityError PasswordRequiresLower() { return new IdentityError { Code = nameof(PasswordRequiresLower), Description = "Пароль должен содержать хотя бы один символ в нижнем регистре ('a'-'z')." }; }
    public override IdentityError PasswordRequiresUpper() { return new IdentityError { Code = nameof(PasswordRequiresUpper), Description = "Пароль должен содержать хотя бы один символ в верхнем регистре ('A'-'Z')" }; }
}

1

Phiên bản tiếng Ba Lan

public class CustomErrorDescriber : IdentityErrorDescriber
{
    public override IdentityError DefaultError() {      return new IdentityError { Code = nameof(DefaultError), Description = $"Wystąpił nieanany błąd." }; }
    public override IdentityError ConcurrencyFailure() { return new IdentityError { Code = nameof(ConcurrencyFailure), Description = "Błąd współbieżności, obiekt został zmodyfikowany." }; }
    public override IdentityError PasswordMismatch() { return new IdentityError { Code = nameof(PasswordMismatch), Description = "Nieprawidłowe hasło." }; }
    public override IdentityError InvalidToken() { return new IdentityError { Code = nameof(InvalidToken), Description = "Nieprawidłowy token." }; }
    public override IdentityError LoginAlreadyAssociated() { return new IdentityError { Code = nameof(LoginAlreadyAssociated), Description = "Użytkownik o takiej nazwie już istnieje." }; }
    public override IdentityError InvalidUserName(string userName) { return new IdentityError { Code = nameof(InvalidUserName), Description = $"Nazwa użytkownika \"'{userName}'\" jest nieprawidłowa, może posiadać tylko znaki i cyfry." }; }
    public override IdentityError InvalidEmail(string email) { return new IdentityError { Code = nameof(InvalidEmail), Description = $"Email \"'{email}'\" jest nieprawidłowy." }; }
    public override IdentityError DuplicateUserName(string userName) { return new IdentityError { Code = nameof(DuplicateUserName), Description = $"Nazwa użytkownika \"'{userName}'\" jest zajęta." }; }
    public override IdentityError DuplicateEmail(string email) { return new IdentityError { Code = nameof(DuplicateEmail), Description = $"Adres \"'{email}'\" jest zajęty." }; }
    public override IdentityError InvalidRoleName(string role) { return new IdentityError { Code = nameof(InvalidRoleName), Description = $"Grupa \"'{role}'\" jest nieprawidłowa." }; }
    public override IdentityError DuplicateRoleName(string role) { return new IdentityError { Code = nameof(DuplicateRoleName), Description = $"Nazwa grupy \"'{role}'\" jest zajęta." }; }
    public override IdentityError UserAlreadyHasPassword() { return new IdentityError { Code = nameof(UserAlreadyHasPassword), Description = "Hasło użytkownika jest już ustawione." }; }
    public override IdentityError UserLockoutNotEnabled() { return new IdentityError { Code = nameof(UserLockoutNotEnabled), Description = "Blokada nie jest ustawiona dla tego użytkownika." }; }
    public override IdentityError UserAlreadyInRole(string role) { return new IdentityError { Code = nameof(UserAlreadyInRole), Description = $"Użytkownik ma już przypisaną grupę \"'{role}'\"." }; }
    public override IdentityError UserNotInRole(string role) { return new IdentityError { Code = nameof(UserNotInRole), Description = $"Użytkownik nie należy do grupy \"'{role}'\"." }; }
    public override IdentityError PasswordTooShort(int length) { return new IdentityError { Code = nameof(PasswordTooShort), Description = $"Hasło musi posiadać conajmniej {length} znaków." }; }
    public override IdentityError PasswordRequiresNonAlphanumeric() { return new IdentityError { Code = nameof(PasswordRequiresNonAlphanumeric), Description = "Hasło musi posiadać przynajmniej jeden znak alfanumeryczny." }; }
    public override IdentityError PasswordRequiresDigit() { return new IdentityError { Code = nameof(PasswordRequiresDigit), Description = "Hasło musi posiadać przynajmniej jedną cyfrę ('0'-'9')." }; }
    public override IdentityError PasswordRequiresLower() { return new IdentityError { Code = nameof(PasswordRequiresLower), Description = "Hasło musi posiadać przynajmniej jedną małą literę ('a'-'z')." }; }
    public override IdentityError PasswordRequiresUpper() { return new IdentityError { Code = nameof(PasswordRequiresUpper), Description = "Hasło musi posiadać przynajmniej jedną wielką literę ('A'-'Z')." }; }
    public override IdentityError PasswordRequiresUniqueChars(int uniqueChars) { return new IdentityError { Code = nameof(PasswordRequiresNonAlphanumeric), Description = "Hasło musi posiadać przynajmniej jeden znak specjalny." }; }
}

1

Hãy để tôi chia sẻ với bạn những gì tôi đã làm để đạt được điều này bằng tiếng Tây Ban Nha. Ở đó bạn có thể tùy chỉnh các tin nhắn một cách dễ dàng!

string Errores = result.Errors.FirstOrDefault();
Errores = Errores.Replace("Name " + Email.Text + " is already taken.", "- El mail " + Email.Text + " ya fue registrado. Intente recuperar la clave.<br/>");
Errores = Errores.Replace("Passwords must be at least 6 characters.", "- La clave debe contener por lo menos 6 caracteres.<br/>");
Errores = Errores.Replace("Passwords must have at least one non letter or digit character.", "- La clave debe contener por lo menos un caracter que no sea letra ni dígito. Por ejemplo: un punto.<br/>");
Errores = Errores.Replace("Passwords must have at least one digit ('0'-'9').", "- La clave debe contener al menos un dígito (entre 0 y 9).<br/>");
Errores = Errores.Replace("Passwords must have at least one uppercase ('A'-'Z').", "- La clave debe contener al menos una letra (entre A y Z).<br/>");
ErrorMessage.Text = "Errores:<br/><br/>" + Errores;

0

Giải pháp của tôi là tạo lớp xác thực mật khẩu tùy chỉnh mới kế thừa từ Microsoft.AspNet.Identity.PasswordValidator, Ghi đè ValidateAsync là lớp gửi thông báo lỗi. Tùy chỉnh thông báo lỗi ở đây và nó hoạt động với tôi ...

Các lớp này giả sử bạn có một trình xác thực tên tệp tài nguyên chung. Tập lệnh từ các lớp này và mẫu tệp tài nguyên có thể được tìm thấy tại đây ASP.NET Identity - Codeplex Sample Code

Đây là mã làm việc mẫu của tôi trong vb.net


Imports System.Threading.Tasks 

Imports Microsoft.AspNet.Identity

Namespace MyNameSpace

Public Class MyPasswordValidator
    Inherits PasswordValidator
    Public Overrides Function ValidateAsync(item As String) As Task(Of IdentityResult)
        Dim errorMessage As String = String.Empty
        Dim bolminChar As Boolean = True
        Dim bolminDigit As Boolean = True
        Dim bolminLcase As Boolean = True
        Dim bolminUCase As Boolean = True
        Dim bolminNonAlfanum As Boolean = True

        If Not String.IsNullOrWhiteSpace(item) AndAlso item.Length >= Me.RequiredLength Then
            bolminChar = True
        Else
            bolminChar = False
            errorMessage = String.Format(CultureInfo.CurrentCulture, Resources.validator.PasswordTooShort & "<br/>", RequiredLength)
        End If

        If Me.RequireDigit Then
            Dim regex As New Regex("^(?=.*\d).+$")
            Dim match As Match = regex.Match(item)
            If match.Success Then
                bolminDigit = True
            Else
                bolminDigit = False
                errorMessage &= Resources.validator.PasswordRequireDigit & ".<br/>"
            End If
        End If

        If Me.RequireLowercase Then
            Dim LCrex As New Regex("^(?=.*[a-z]).+$")
            Dim LCMatch As Match = LCrex.Match(item)
            If LCMatch.Success Then
                bolminLcase = True
            Else
                bolminLcase = False
                errorMessage &= Resources.validator.PasswordRequireLower & "<br/>"
            End If
        End If

        If Me.RequireNonLetterOrDigit Then
            Dim NAFRex As New Regex("^(?=.*[-+_!@#$%=^\[\]\{\}()&*.,?]).+$")
            Dim NAFMatch As Match = NAFRex.Match(item)
            If NAFMatch.Success Then
                bolminNonAlfanum = True
            Else
                bolminNonAlfanum = False
                errorMessage &= Resources.validator.PasswordRequireNonLetterOrDigit & "<br/>"
            End If
        End If

        If Me.RequireUppercase Then
            Dim UCrex As New Regex("^(?=.*[A-Z]).+$")
            Dim UCMatch As Match = UCrex.Match(item)
            If UCMatch.Success Then
                bolminUCase = True
            Else
                bolminUCase = False
                errorMessage &= Resources.validator.PasswordRequireUpper & "<br/>"
            End If
        End If

        If bolminChar And bolminDigit And bolminLcase And bolminNonAlfanum And bolminUCase Then
            Return Task.FromResult(Of IdentityResult)(IdentityResult.Success)
        Else
            Return Task.FromResult(Of IdentityResult)(IdentityResult.Failed(New String() {errorMessage}))
        End If
        'Return MyBase.ValidateAsync(item)
    End Function
End Class

Public Class MyUserValidator
    Inherits UserValidator(Of applicationUser, int64)
    Private _manager As ApplicationUserManager

    Public Sub New(manager As ApplicationUserManager)
        MyBase.New(manager)
        _manager = manager
    End Sub

    Public Overrides Function ValidateAsync(item As applicationUser) As Task(Of IdentityResult)
        If item Is Nothing Then
            Throw New ArgumentNullException("item")
        End If

        Dim errors As New List(Of String)()
        Validateusername(item, errors)

        If Me.RequireUniqueEmail Then
            ValidateEmail(item, errors)
        End If

        If errors.Count > 0 Then
            Return Task.FromResult(Of IdentityResult)(IdentityResult.Failed(errors.ToArray()))
        End If
        Return Task.FromResult(Of IdentityResult)(IdentityResult.Success)
    End Function

    Private Sub Validateusername(User As applicationUser, errors As List(Of String))
        If String.IsNullOrWhiteSpace(User.UserName) Then
            errors.Add(String.Format(CultureInfo.CurrentCulture, Resources.validator.PropertyTooShort, "Email")) '
        ElseIf Me.AllowOnlyAlphanumericUserNames AndAlso Not Regex.IsMatch(User.UserName, "^[A-Za-z0-9@_\.]+$") Then
            ' If any characters are not letters or digits, its an illegal user name
            errors.Add(String.Format(CultureInfo.CurrentCulture, Resources.validator.InvalidUserName, User.UserName))
        Else
            Dim owner = _manager.FindByName(User.UserName)
            If owner IsNot Nothing AndAlso Not EqualityComparer(Of applicationUser).ReferenceEquals(owner.Id, User.Id) Then
                errors.Add(String.Format(CultureInfo.CurrentCulture, Resources.validator.DuplicateName, User.UserName))
            End If
        End If
    End Sub

    Private Sub ValidateEmail(User As ApplicationUser, errors As List(Of String))
        Dim email As String = String.Empty

        If User.Id > 0 Then
            email = _manager.GetEmail(User.Id)
        End If
        If String.IsNullOrWhiteSpace(email) Then
            errors.Add(String.Format(CultureInfo.CurrentCulture, Resources.validator.PropertyTooShort, "Email"))
            Return
        End If

        Try
            Dim m As New MailAddress(email)
        Catch ex As Exception
            errors.Add(String.Format(CultureInfo.CurrentCulture, Resources.validator.InvalidEmail, email))
            Return
        End Try
        Dim owner = _manager.FindByEmail(email)
        If owner IsNot Nothing AndAlso Not EqualityComparer(Of ApplicationUser).ReferenceEquals(owner.Id, User.Id) Then
            errors.Add(String.Format(CultureInfo.CurrentCulture, Resources.validator.DuplicateName, email))
        End If
    End Sub
End Class

Hãy nhớ cập nhật cài đặt trong tệp IdentityConfig.vb của bạn để sử dụng các lớp này.


0

Giải pháp của tôi hơi bẩn một chút nhưng nó hoạt động như mong đợi. Ý tưởng là gán tất cả các lỗi mà kết quả đối tượng IdentityResult mang lại khi chúng tôi đăng ký người dùng mới:

var result = await UserManager.CreateAsync(user, model.Password);

Đối với một cái mới mà chúng tôi sẽ tạo. Đầu tiên, chúng tôi cần tạo một Danh sách sẽ chứa các lỗi tùy chỉnh của chúng tôi:

var erroresEspanol = new List<string>();

Sau đó, chúng ta cần lặp lại các lỗi bên trong kết quả và thêm một lỗi tùy chỉnh mới cho mỗi lỗi tùy thuộc vào nguyên nhân gây ra lỗi đó (Người dùng trùng lặp, email, v.v.):

foreach (var error in result.Errors)
            {
                if (error == ("Name " + model.Usuario + " is already taken."))
                {
                    erroresEspanol.Add("El Usuario " + model.Usuario + " ya existe.");
                }
                if (error.Substring(0, error.IndexOf(" ")) == "Email")
                {
                    erroresEspanol.Add("El Email " + model.Email + " ya fue ingresado.");
                }
                if (error.Substring(0, error.IndexOf(" ")) == "Passwords")
                {
                    erroresEspanol.Add("La contraseña debe contener mayúscula, minúscula y al menos 6 caracteres de longitud.");
                }
            }

Vì vậy, sau đó chúng ta chỉ cần tạo một đối tượng IdentityResult mới:

var resultado = new IdentityResult(erroresEspanol);

Và chuyển nó vào phương thức AddErrors ở cuối hành động Đăng ký của chúng tôi:

AddErrors(resultado);

0

Gặp phải vấn đề tương tự, người ta có thể cung cấp các tệp tài nguyên của riêng bạn để đạt được điều này. Tất nhiên nó yêu cầu một chút hack phản xạ! Trước tiên, bạn sẽ cần chạy với bảo mật đầy đủ, tức là được đặt trong web.config của bạn:

<system.web>
  <securityPolicy>
     <trustLevel name="Full" policyFile="internal"/>
  </securityPolicy>
...

Tiếp theo trong mã khởi động ứng dụng của bạn:

var ass = Assembly.Load("Microsoft.AspNet.Identity.Core, Version=2.0.0.0, Culture=neutral, PublicKeyToken=31bf3856ad364e35");
Type hack = ass.GetType("Microsoft.AspNet.Identity.Resources");
var field = hack.GetField("resourceMan",
                        BindingFlags.Static |
                        BindingFlags.NonPublic);
// NOTE: this is where you set you own resource manager!
field.SetValue(null, new global::System.Resources.ResourceManager("WebApplication1.Resources", typeof(WebApplication1.Resources).Assembly));

Công việc hoàn thành!


0

Tôi đã cố gắng tìm ra giải pháp để tạo phiên bản bản địa hóa của AspNet.Identity cho các nền văn hóa mà không có gói sẵn sàng sử dụng nào. Các bước là:

  1. Tải xuống mã nguồn từ GitHub và mở dự án src / Microsoft.AspNet.Identity.Core trong studio trực quan.
  2. Thêm một mục mới (tệp tài nguyên) vào dự án. Đặt tên cho nó Resources.aa-BB.resxaa-BBlà văn hóa bạn cần để bản địa hoá lắp ráp cho. Eg .: Resources.fa-IR.resx.
  3. Mở tệp mới tạo và sao chép các mục tài nguyên từ Resources.resx tệp đó.
  4. Bản địa hóa các văn bản như bạn muốn.
  5. Xây dựng dự án.
  6. Đi tới binthư mục và dưới thư mục Debughoặc, Releasebạn sẽ thấy một thư mục có tên aa-BB(văn hóa bạn đã nhập trước đó). Sao chép thư mục vào thư mục bincủa dự án của bạn.
  7. Thực hiện các thay đổi mà @ 1AmirJalali đã nói ( bài đăng này ).
  8. Làm tốt! Bản địa hóa đã hoàn tất. Cố gắng chia sẻ gói bản địa hóa của bạn :)

0

Đây là bản dịch tiếng Thổ Nhĩ Kỳ của IdentityErrorDescriber

using Microsoft.AspNetCore.Identity;


public class TurkishIdentityErrorDescriber : IdentityErrorDescriber
{
    public override IdentityError DefaultError() { return new IdentityError { Code = nameof(DefaultError), Description = $"Bilinmeyen bir hata meydana geldi." }; }
    public override IdentityError ConcurrencyFailure() { return new IdentityError { Code = nameof(ConcurrencyFailure), Description = "Bir eşzamanlılık hatası meydana geldi lütfen tekrar deneyin." }; }
    public override IdentityError PasswordMismatch() { return new IdentityError { Code = nameof(PasswordMismatch), Description = "Şifreler eşleşmiyor." }; }
    public override IdentityError InvalidToken() { return new IdentityError { Code = nameof(InvalidToken), Description = "Üretilen eşleştirme kodu geçerli değil." }; }
    public override IdentityError LoginAlreadyAssociated() { return new IdentityError { Code = nameof(LoginAlreadyAssociated), Description = "Bu bilgilere sahip bir kullanıcı sistemde zaten var." }; }
    public override IdentityError InvalidUserName(string userName) { return new IdentityError { Code = nameof(InvalidUserName), Description = $"'{userName}', bu kullanıcı adı geçersiz; sadece harf ve sayı kullanın." }; }
    public override IdentityError InvalidEmail(string email) { return new IdentityError { Code = nameof(InvalidEmail), Description = $"'{email}', bu e-posta adresi geçersiz." }; }
    public override IdentityError DuplicateUserName(string userName) { return new IdentityError { Code = nameof(DuplicateUserName), Description = $"'{userName}', bu kullanıcı adı zaten kullanımda." }; }
    public override IdentityError DuplicateEmail(string email) { return new IdentityError { Code = nameof(DuplicateEmail), Description = $"'{email}', bu e-posta adresi zaten kullanımda." }; }
    public override IdentityError InvalidRoleName(string role) { return new IdentityError { Code = nameof(InvalidRoleName), Description = $"'{role}', bu rol adı geçerli değil." }; }
    public override IdentityError DuplicateRoleName(string role) { return new IdentityError { Code = nameof(DuplicateRoleName), Description = $"'{role}', bu rol adı zaten kullanımda." }; }
    public override IdentityError UserAlreadyHasPassword() { return new IdentityError { Code = nameof(UserAlreadyHasPassword), Description = "Bu kullanıcı için zaten bir şifre atanmış durumda." }; }
    public override IdentityError UserLockoutNotEnabled() { return new IdentityError { Code = nameof(UserLockoutNotEnabled), Description = "Bu kullanıcı için giriş engelleme özelliği aktif değil." }; }
    public override IdentityError UserAlreadyInRole(string role) { return new IdentityError { Code = nameof(UserAlreadyInRole), Description = $"Kullanıcı zaten '{role}' adlı role sahip." }; }
    public override IdentityError UserNotInRole(string role) { return new IdentityError { Code = nameof(UserNotInRole), Description = $"Kullanıcı '{role}' adlı role sahip değil." }; }
    public override IdentityError PasswordTooShort(int length) { return new IdentityError { Code = nameof(PasswordTooShort), Description = $"Parola en az {length} uzunluğunda olmalı." }; }
    public override IdentityError PasswordRequiresNonAlphanumeric() { return new IdentityError { Code = nameof(PasswordRequiresNonAlphanumeric), Description = "Parola en az bir özel karakter içermelidir (örn. *,!_- vb.)." }; }
    public override IdentityError PasswordRequiresDigit() { return new IdentityError { Code = nameof(PasswordRequiresDigit), Description = "Parola en az bir rakam içermelidir." }; }
    public override IdentityError PasswordRequiresLower() { return new IdentityError { Code = nameof(PasswordRequiresLower), Description = "Parola en az bir küçük harf içermelidir. ('a'-'z')." }; }
    public override IdentityError PasswordRequiresUpper() { return new IdentityError { Code = nameof(PasswordRequiresUpper), Description = "Parola en az bir büyük harf içermelidir. ('A'-'Z')." }; }

}

0

Bản dịch tiếng Ukraina cho câu trả lời của Andrew Basarab

Dữ liệu tệp tài nguyên:

<data name="ConcurrencyFailure" xml:space="preserve">
  <value>Помилка паралельності, об’єкт змінено.</value>
</data>
<data name="DefaultError" xml:space="preserve">
  <value>Сталася невідома помилка.</value>
</data>
<data name="DuplicateEmail" xml:space="preserve">
  <value>Адреса '{0}' зайнята.</value>
</data>
<data name="DuplicateRoleName" xml:space="preserve">
  <value>Ім'я групи '{0}' зайняте.</value>
</data>
<data name="DuplicateUserName" xml:space="preserve">
  <value>Ім'я користувача '{0}' зайняте.</value>
</data>
<data name="InvalidEmail" xml:space="preserve">
  <value>Неприпустима адреса Email '{0}'.</value>
</data>
<data name="InvalidRoleName" xml:space="preserve">
  <value>Неприпустима назва групи '{0}'.</value>
</data>
<data name="InvalidToken" xml:space="preserve">
  <value>Недійсний або невірний токен.</value>
</data>
<data name="InvalidUserName" xml:space="preserve">
  <value>Неприпустиме ім'я користувача '{0}', ім'я може містити тільки символи і цифри.</value>
</data>
<data name="LoginAlreadyAssociated" xml:space="preserve">
  <value>Користувач з таким іменем вже існує.</value>
</data>
<data name="PasswordMismatch" xml:space="preserve">
  <value>Невірний пароль.</value>
</data>
<data name="PasswordRequiresDigit" xml:space="preserve">
  <value>Пароль повинен мати хоча б одну цифру ('0'-'9').</value>
</data>
<data name="PasswordRequiresLower" xml:space="preserve">
  <value>Пароль повинен мати як мінімум одну малу літеру ('a'-'z').</value>
</data>
<data name="PasswordRequiresNonAlphanumeric" xml:space="preserve">
  <value>Пароль повинен мати хоча б один буквенно-цифровий символ.</value>
</data>
<data name="PasswordRequiresUniqueChars" xml:space="preserve">
  <value>Пароль повинен мати {0} спеціальних символів.</value>
</data>
<data name="PasswordRequiresUpper" xml:space="preserve">
  <value>Пароль повинен мати хоча б одну велику літеру ('A'-'Z').</value>
</data>
<data name="PasswordTooShort" xml:space="preserve">
  <value>Пароль повинен містити як мінімум {0} символів.</value>
</data>
<data name="UserAlreadyHasPassword" xml:space="preserve">
  <value>Пароль користувача вже встановлений.</value>
</data>
<data name="UserAlreadyInRole" xml:space="preserve">
  <value>Користувач вже має призначену групу '{0}'.</value>
</data>
<data name="UserLockoutNotEnabled" xml:space="preserve">
  <value>Блокування не встановлено для цього користувача.</value>
</data>
<data name="UserNotInRole" xml:space="preserve">
  <value>Користувач не входить до групи '{0}'.</value>
</data>
Khi sử dụng trang web của chúng tôi, bạn xác nhận rằng bạn đã đọc và hiểu Chính sách cookieChính sách bảo mật của chúng tôi.
Licensed under cc by-sa 3.0 with attribution required.