.NET Core 中具有枚举值的抽象通用自定义结果类(枚举不序列化)

发布于 2025-01-11 22:17:48 字数 1675 浏览 3 评论 0原文

您好,我尝试创建两个抽象类,一个包含内容,另一个包含状态,以便多个项目可以继承它并添加它们的枚举状态和内容,并将其用于自己的目的。我正在使用.NET 5.0。我有下一个代码。

public enum EnumValues { Success,Fail}


public abstract class EnumStatus<TEnum> where TEnum : System.Enum
{
    public TEnum Status { get; set; }
    protected EnumStatus(TEnum status)
    {
        Status = status;
    }
}

public abstract class Result<T> : EnumStatus<System.Enum>
{
    public T Content { get; set; }
    
    protected Result(System.Enum status) : base(status)
    {

    }

    protected Result(T content, System.Enum status) : base(status)
    {
        Content = content;
    }
   
}

我有我的自定义结果类,所以

public class CustomResult<T> : Result<T>
{
    public CustomResult(System.Enum status) : base(status)
    {
    }

    public CustomResult(T content, System.Enum status) : base(content, status)
    {
        
    }

    public static implicit operator CustomResult<T>(T content)
    {
        return new CustomResult<T>(content, EnumValues.Success);
    }

    public static implicit operator CustomResult<T>(EnumValues status)
    {
        return new CustomResult<T>(status);
    }

}

当我在控制器中使用它时,

public async Task<IActionResult> Test()
{
      return new JsonResult(new CustomResult<bool>(true,EnumValues.Success));
}

我在邮递员调用中得到的响应是

{
"content": true,
"status": {}
}

内容始终返回,但我的状态始终为空,调试它内容和状态是有效且正确的设置构造函数,但当它返回给客户端时,状态始终为空,但如果我使用隐式运算符返回结果,例如

返回确定(EnumValues.Success)

它返回有效结果。 有人可以向我解释为什么会发生这样的事情吗?有什么解决办法吗?或者我犯了一些愚蠢的错误

Hello I tried to create two abstract classes,one class with Content and the other with Status so multiple project can inherit it and add their enum status and their content and use it for it own purpose. I am using .NET 5.0. I have the next code.

public enum EnumValues { Success,Fail}


public abstract class EnumStatus<TEnum> where TEnum : System.Enum
{
    public TEnum Status { get; set; }
    protected EnumStatus(TEnum status)
    {
        Status = status;
    }
}

public abstract class Result<T> : EnumStatus<System.Enum>
{
    public T Content { get; set; }
    
    protected Result(System.Enum status) : base(status)
    {

    }

    protected Result(T content, System.Enum status) : base(status)
    {
        Content = content;
    }
   
}

and I have my custom result class that is

public class CustomResult<T> : Result<T>
{
    public CustomResult(System.Enum status) : base(status)
    {
    }

    public CustomResult(T content, System.Enum status) : base(content, status)
    {
        
    }

    public static implicit operator CustomResult<T>(T content)
    {
        return new CustomResult<T>(content, EnumValues.Success);
    }

    public static implicit operator CustomResult<T>(EnumValues status)
    {
        return new CustomResult<T>(status);
    }

}

So when I use it in my controller

public async Task<IActionResult> Test()
{
      return new JsonResult(new CustomResult<bool>(true,EnumValues.Success));
}

The response I get in my postman call is

{
"content": true,
"status": {}
}

The content is always returned but my status is always empty, debugging it the content and status are valid and correct set in the constructor but when it is returned to client the status is always empty, but if I return the result with the implicit operator e.g

return Ok(EnumValues.Success)

it return valid result.
Can someone explain to me why is this happening like that? is there any solution about this ? or I am making some stupid mistake

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

柏林苍穹下 2025-01-18 22:17:48

修复它的最简单方法是使用 Newtonsoft.Json。
请将此代码添加到启动中

using Newtonsoft.Json.Serialization;

services.AddControllers()
.AddNewtonsoftJson(options =>
  options.SerializerSettings.ContractResolver =
        new CamelCasePropertyNamesContractResolver());

如果您想继续使用 Text.Json

services.AddControllers()
.AddJsonOptions(options =>
new JsonSerializerOptions
{
    Converters = { new JsonStringEnumConverter() },
    WriteIndented = true,
});

var options = new JsonSerializerOptions
    {
        Converters = { new JsonStringEnumConverter() },
        WriteIndented = true,
    };
var json = System.Text.Json.JsonSerializer.Serialize(result, options);
     
var obj = System.Text.Json.JsonSerializer.Deserialize<CustomResult<bool,EnumValues>>(json,options);

并修复类,

public abstract class Result<T,TEnum> : EnumStatus<TEnum> where TEnum : Enum
{
    public T Content { get; set; }

    protected Result(TEnum status) : base(status)
    {

    }

    protected Result(T content, TEnum status) : base(status)
    {
        Content = content;
    }

    
}


public class CustomResult<T,TEnum> : Result<T,TEnum>  where TEnum : Enum
{
    
    public CustomResult(TEnum status) : base(status)
    {
    }
    [System.Text.Json.Serialization.JsonConstructorAttribute]
    public CustomResult(T content, TEnum status) : base(content, status)
    {

    }
}

the easiest way to fix it , would be using Newtonsoft.Json.
Add this code to startup

using Newtonsoft.Json.Serialization;

services.AddControllers()
.AddNewtonsoftJson(options =>
  options.SerializerSettings.ContractResolver =
        new CamelCasePropertyNamesContractResolver());

if you want to continue with Text.Json

services.AddControllers()
.AddJsonOptions(options =>
new JsonSerializerOptions
{
    Converters = { new JsonStringEnumConverter() },
    WriteIndented = true,
});

var options = new JsonSerializerOptions
    {
        Converters = { new JsonStringEnumConverter() },
        WriteIndented = true,
    };
var json = System.Text.Json.JsonSerializer.Serialize(result, options);
     
var obj = System.Text.Json.JsonSerializer.Deserialize<CustomResult<bool,EnumValues>>(json,options);

and fix classess

public abstract class Result<T,TEnum> : EnumStatus<TEnum> where TEnum : Enum
{
    public T Content { get; set; }

    protected Result(TEnum status) : base(status)
    {

    }

    protected Result(T content, TEnum status) : base(status)
    {
        Content = content;
    }

    
}


public class CustomResult<T,TEnum> : Result<T,TEnum>  where TEnum : Enum
{
    
    public CustomResult(TEnum status) : base(status)
    {
    }
    [System.Text.Json.Serialization.JsonConstructorAttribute]
    public CustomResult(T content, TEnum status) : base(content, status)
    {

    }
}
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文