ASP .NET Core和EF Core中动态过滤返回字段的API控制器
创始人
2024-11-11 14:30:10
0

在ASP .NET Core和EF Core中动态过滤返回字段的API控制器,可以使用System.Text.Json库中的JsonPropertyName特性来实现。

首先,创建一个自定义的FilterAttribute类,用于标记需要返回的字段名:

[AttributeUsage(AttributeTargets.Property, AllowMultiple = false)]
public class FilterFieldAttribute : Attribute
{
    public string Name { get; set; }

    public FilterFieldAttribute(string name)
    {
        Name = name;
    }
}

然后,在数据模型中使用FilterFieldAttribute标记需要过滤的字段:

public class Person
{
    [FilterField("id")]
    public int Id { get; set; }

    [FilterField("name")]
    public string Name { get; set; }

    [FilterField("age")]
    public int Age { get; set; }
}

接下来,在API控制器的Get方法中,根据请求参数动态过滤返回的字段:

[HttpGet]
public IActionResult Get([FromQuery] string fields)
{
    var properties = typeof(Person).GetProperties()
        .Where(p => p.GetCustomAttributes(typeof(FilterFieldAttribute), false).Any())
        .ToList();

    var filteredData = _context.Person.Select(p =>
    {
        var filteredObj = new ExpandoObject() as IDictionary;

        foreach (var property in properties)
        {
            filteredObj.Add(property.GetCustomAttribute().Name, property.GetValue(p));
        }

        return filteredObj;
    });

    return Ok(filteredData);
}

在上述代码中,首先获取Person类中标记了FilterFieldAttribute的属性列表。然后,通过linq查询从数据库中获取数据,并使用ExpandoObject动态创建一个需要返回的对象。最后,使用JsonPropertyName特性将属性名映射为请求参数中指定的字段名。

使用示例:

请求URL:https://example.com/api/person?fields=id,name

返回结果:

[
    {
        "id": 1,
        "name": "John"
    },
    {
        "id": 2,
        "name": "Alice"
    }
]

上述代码可以根据请求参数中的字段名动态过滤返回的字段,实现了动态过滤返回字段的API控制器。

相关内容

热门资讯

不少玩家反映!衢州都莱辅助器免... 不少玩家反映!衢州都莱辅助器免费下载!好像确实有开挂辅助挂(有挂教学)-哔哩哔哩1、用户打开应用后不...
教学辅助挂!透视辅助工具!原来... 教学辅助挂!透视辅助工具!原来真的有开挂辅助app(有挂分析)-哔哩哔哩1、透视辅助工具免费辅助多个...
做出回应!仙桃晃晃辅助器!其实... 做出回应!仙桃晃晃辅助器!其实是真的有开挂辅助教程(新版有挂)-哔哩哔哩1、许多玩家不知道仙桃晃晃辅...
值得注意的是!决战卡五星最新辅... 值得注意的是!决战卡五星最新辅助!真是确实有开挂辅助方法(证实有挂)-哔哩哔哩1、值得注意的是!决战...
黑科技攻略!浙江宝宝游戏辅助器... 黑科技攻略!浙江宝宝游戏辅助器是真的嘛!真是真的是有开挂辅助脚本(有挂秘诀)-哔哩哔哩1、打开软件启...
刚刚!余干五十k攻略!切实确实... 刚刚!余干五十k攻略!切实确实有开挂辅助教程(竟然有挂)-哔哩哔哩1、超多福利:超高返利,海量正版游...
2026版攻略!川南九九辅助!... 2026版攻略!川南九九辅助!一直确实有开挂辅助攻略(有挂解密)-哔哩哔哩1)川南九九辅助免费钻石:...
此事迅速冲上热搜!哥哥打大a有... 此事迅速冲上热搜!哥哥打大a有没有辅助!一贯是真的有开挂辅助脚本(有挂秘籍)-哔哩哔哩1、该软件可以...
2026版规律!约局吧透视辅助... 2026版规律!约局吧透视辅助ios下载!一直真的有开挂辅助技巧(今日头条)-哔哩哔哩约局吧透视辅助...
2026版辅助挂!胡乐辅助脚本... 2026版辅助挂!胡乐辅助脚本是真的假的!切实真的是有开挂辅助app(有挂透视)-哔哩哔哩进入游戏-...