自定义asp.net-identity错误字符串

时间:2018-02-15 18:22:46

标签: c# asp.net-identity

我尝试个人字符串asp.net-identity的错误,这是我的代码:

    private async Task< bool> addUser()
    {

        using (libProduccionDataBase.Contexto.DataBaseContexto context = new DataBaseContexto())
        {
            using (var t = new libProduccionDataBase.Identity.ApplicationUserManager( new libProduccionDataBase.Identity.ApplicationUserStore( context ) ))
            {

                ApplicationUser usr = new ApplicationUser
                {
                    Nombre = AddNombreKTbox.Text,
                    ApellidoPaterno = AddApPaternoKTbox.Text,
                    ApellidoMaterno = AddApMaternoKTbox.Text,
                    ClaveTrabajador = AddClaveKTbox.Text,
                    UserName = AddLoginNameKTbox.Text,
                    Email = AddEmailKTbox.Text
                };

                IdentityResult result = await  t.CreateAsync(usr, AddPasswordKTbox.Text);

                if (result.Succeeded) t.AddToRole( usr.Id, "Usuario General" );
                foreach(var err in result.Errors)
                {
                    Console.WriteLine( err );
                }
                return result.Succeeded;
            }
        }
    }

但是我需要西班牙语中的错误,例如如果密码为空,result.Errors [0]给了我“密码必须至少6个字符。”,但我需要个人字符串到西班牙语,这是一个例子但是,我需要更改以消除所有错误消息。

1 个答案:

答案 0 :(得分:0)

我解决了问题

首先尝试直接验证ApplicationUser,但是错误文本用英语显示,所以,我决定用DataAnotations创建一个类,然后我在方法上验证这个,如果validatio为true,则继续创建一个新用户,如果无效,则返回false。

这是班级:

public class CreatingUserModel
{
    [Required(ErrorMessage ="El nombre para inicio de sesion es Requerido")]
    [MinLength(6, ErrorMessage ="El Nombre para inicio de sesion debe contener al menos 6 caracteres")]
    public string LoginName { get; set; }


    [Required( ErrorMessage = "El Nombre del usuario es requerido" )]
    public string Nombre { get; set; }


    [Required( ErrorMessage = "El Apellido Paterno del usuario es requerido" )]
    public string ApellidoPaterno { get; set; }


    [Required( ErrorMessage = "El Apellido Materno del usuario es requerido" )]
    public string ApellidoMaterno { get; set; }


    [MaxLength( 10, ErrorMessage = "El largo maximo para la clave del trabajador es de 10 caracteres" )]
    public string ClaveTrabajador { get; set; }


    [Required(ErrorMessage ="El Email es requerido")]
    [EmailAddress(ErrorMessage ="No es un email Valido")]
    public string Email { get; set; }


    [Required( ErrorMessage = "La contraseña es requerida" )]
    [MinLength( 6, ErrorMessage = "La contraseña debe ser de al menos 6 caracteres" )]
    public string Contraseña { get; set; }


    [Required( ErrorMessage = "La confirmacion de la contraseña es requerida" )]
    [Compare(nameof(Contraseña), ErrorMessage ="La contraseña confirmada no coincide")]
    public string ConfirmeContraseña { get; set; }

    public ApplicationUser ToApplicationUser()
    {

        return new ApplicationUser
        {
            Nombre = this.Nombre,
            ApellidoPaterno = this.ApellidoPaterno,
            ApellidoMaterno = this.ApellidoMaterno,
            ClaveTrabajador = this.ClaveTrabajador,
            UserName = this.LoginName,
            Email = this.Email
        };

    }
}

并使用:

private async Task< bool> addUser()
    {

        using (libProduccionDataBase.Contexto.DataBaseContexto context = new DataBaseContexto())
        {
            using (var t = new libProduccionDataBase.Identity.ApplicationUserManager( new libProduccionDataBase.Identity.ApplicationUserStore( context ) ))
            {


                CreatingUserModel _usr= new CreatingUserModel
                {
                    Nombre = AddNombreKTbox.Text,
                    ApellidoPaterno = AddApPaternoKTbox.Text,
                    ApellidoMaterno = AddApMaternoKTbox.Text,
                    ClaveTrabajador = AddClaveKTbox.Text,
                    LoginName= AddLoginNameKTbox.Text,
                    Email = AddEmailKTbox.Text
                };

                ValidationContext validator = new ValidationContext(_usr);
                List<ValidationResult> results = new List<ValidationResult>();
                bool valid = Validator.TryValidateObject(_usr, validator, results, true);
                if (valid)
                {
                    var usr= _usr.ToApplicationUser();

                    IdentityResult result = await  t.CreateAsync(usr, AddPasswordKTbox.Text);

                    if (result.Succeeded) t.AddToRole( usr.Id, "Usuario General" );


                    return result.Succeeded;
                }else
                {
                    StringBuilder strbld = new StringBuilder();
                    results.ForEach( err => {
                        strbld.AppendFormat( "•{0}\n", err.ErrorMessage );
                    } );

                    Console.WriteLine( strbld.ToString() );
                }
                return false;
            }
        }
    }