FeishuNetSdk 1.0.6

There is a newer version of this package available.
See the version list below for details.
dotnet add package FeishuNetSdk --version 1.0.6
                    
NuGet\Install-Package FeishuNetSdk -Version 1.0.6
                    
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="FeishuNetSdk" Version="1.0.6" />
                    
For projects that support PackageReference, copy this XML node into the project file to reference the package.
<PackageVersion Include="FeishuNetSdk" Version="1.0.6" />
                    
Directory.Packages.props
<PackageReference Include="FeishuNetSdk" />
                    
Project file
For projects that support Central Package Management (CPM), copy this XML node into the solution Directory.Packages.props file to version the package.
paket add FeishuNetSdk --version 1.0.6
                    
#r "nuget: FeishuNetSdk, 1.0.6"
                    
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
#:package FeishuNetSdk@1.0.6
                    
#:package directive can be used in C# file-based apps starting in .NET 10 preview 4. Copy this into a .cs file before any lines of code to reference the package.
#addin nuget:?package=FeishuNetSdk&version=1.0.6
                    
Install as a Cake Addin
#tool nuget:?package=FeishuNetSdk&version=1.0.6
                    
Install as a Cake Tool

FeishuNetSdk

.NET

飞书开放平台网址:https://open.feishu.cn/

接口清单详见:TenantAccessToken适用接口清单-967个

用法:

1、安装Nuget包

FeishuNetSdk

2、依赖注册(直接输入应用凭证的方式,二选一)

builder.Services.AddHttpApi<IFeishuApi>();
builder.Services.AddHttpApi<IFeishuTenantApi>();
builder.Services.AddTokenProvider<IFeishuTenantApi>(async service =>
{
    //获取凭证接口
    var feishuApi = service.GetRequiredService<IFeishuApi>();
    //获取tenant_access_token
    var response = await feishuApi.PostAuthV3TenantAccessTokenInternalAsync(
            new FeishuNetSdk.Auth.Spec
                .PostAuthV3TenantAccessTokenInternalBodyDto
                {
                    //此处修改为自建的应用凭证Id和密钥
                    AppId = "cli_a5bf8739dab8d0c",
                    AppSecret = "vn7MjifCNm04dUlWBg6yWbijHvEpel6G"
                });
    //返回一个能自动缓存和过期重取的Token实例
    return new TokenResult
    {
        Access_token = response.TenantAccessToken,
        Expires_in = response.Expire
    };
});

2、依赖注册(配置文件的方式,二选一)

  1. 创建FeishuOption类:
public record FeishuOption
{
    public string app_id { get; set; } = string.Empty;
    public string app_secret { get; set; } = string.Empty;
}
  1. appsettings.json文件中添加配置:
"Feishu": {
    "app_id": "cli_a5bf8739dab8d0c",
    "app_secret": "vn7MjifCNm04dUlWBg6yWbijHvEpel6G",
}
  1. 添加绑定配置:
builder.Services.Configure<FeishuOption>(builder.Configuration.GetSection("Feishu"));
  1. 接口注册:
builder.Services.AddHttpApi<IFeishuApi>();
builder.Services.AddHttpApi<IFeishuTenantApi>();
builder.Services.AddTokenProvider<IFeishuTenantApi>(async service =>
{
    //获取配置
    var option = service.GetRequiredService<IOptionsMonitor<FeishuOption>>();
    //获取凭证接口
    var feishuApi = service.GetRequiredService<IFeishuApi>();
    //获取tenant_access_token
    var response = await feishuApi.PostAuthV3TenantAccessTokenInternalAsync(
            new FeishuNetSdk.Auth.Spec
                .PostAuthV3TenantAccessTokenInternalBodyDto
                {
                    AppId = option.CurrentValue.app_id,
                    AppSecret = option.CurrentValue.app_secret
                });
    //返回一个能自动缓存和过期重取的Token实例
    return new TokenResult
    {
        Access_token = response.TenantAccessToken,
        Expires_in = response.Expire
    };
});

3、依赖注入

public class TestController : ControllerBase
{
    private readonly IFeishuTenantApi _feishuApi;
    public TestController(IFeishuTenantApi feishuApi)
    {
        _feishuApi = feishuApi;
    }
}

4、方法调用

[HttpGet("t2")]
public async Task<IResult> GetT2Async()
{
    var result2 = await _feishuApi.GetImV1ChatsAsync();
    return Results.Json(result2);
}

示例:

文件上传示例

参数 FormDataFile 支持 filePathFileInfobyte[]Stream

需要注意部分接口注释上有关于文件格式限制的说明。

[HttpGet("t3")]
public async Task<IResult> GetT3Async()
{
    //定义文件存储路径
    var filePath = @"D:\Users\Downloads\e9bd937f1d7a4c4f992724f5de44bb14.jpg";
    //调用接口
    var result = await _feishuApi.PostImV1ImagesAsync(
        new FeishuNetSdk.Im.PostImV1ImagesBodyDto
        {
            ImageType = "message"
        },
        new FormDataFile(filePath));

    //当返回码不成功时,返回错误消息
    if (!result.IsSuccess)
        return Results.Problem(result.Msg);
    return Results.Json(result);
}

文件下载示例

下载操作默认返回HttpResponseMessage,由于没有返回码(code)可以判断操作是否成功,所以建议配合 EnsureSuccessStatusCode() 方法使用,当响应状态码异常时,会抛出异常,需要自行捕获处理。

[HttpGet("t4")]
public async Task<IResult> GetT4Async()
{
    //定义文件存储路径
    var filePath = @"D:\Users\Downloads\e9bd937f----1.jpg";
    //调用接口
    var result = (await _feishuApi.GetImV1ImagesByImageKeyAsync(
        "img_xxxx-fbdc-4c36-b17c-ac8aa1aee7dg"))
        //当响应状态码异常时,会抛出异常,需要自行捕获处理
        .EnsureSuccessStatusCode();

    //保存文件到指定路径
    await result.SaveAsAsync(filePath);
    return Results.Json(result);
}

个别接口支持部分下载,可以按需设置参数Range,字符串格式为bytes=0-100表示下载第0字节到第100字节的数据,默认不填或者null表示下载整个文件。示例如下:

[HttpGet("t5")]
public async Task<IResult> GetT5Async()
{
    //定义文件存储路径
    var filePath = @"D:\Users\Downloads\e9bd937f----2.jpg";
    //调用接口
    var result = (await _feishuApi.GetDriveV1MediasByFileTokenDownloadAsync(
        "OQBpbF8AEoZ0gqxpCMwcRPWFn8c",
        "bytes=0-100"))
        //当响应状态码异常时,会抛出异常,需要自行捕获处理
        .EnsureSuccessStatusCode();

    //保存到指定路径,可能只是文件的一部分,并非完整。
    await result.SaveAsAsync(filePath);
    return Results.Json(result);
}

注意事项:

云文档操作

文档操作前提需要有编辑权限,步骤如下:

  1. 自建应用添加机器人能力。
  2. 应用机器人加入或创建一个新群组
  3. 进入目标文档,将该群组设置为文档协作者
  4. 调用接口方法。

以下是仅在特殊情况下使用的特殊方法。

接口重载/覆盖

  1. 新建API,继承于 IFeishuTenantApi
  2. 使用重载/覆盖方法

如果要覆盖方法,比如是在保持参数完全一致的情况下,修改http地址,需要在方法前加 new (参数不一致是重载,重载不用加new ),然后将新地址更换到属性上。更换http方法、返回参数及其他属性也是同理。

1、新建API
public interface INewApi : IFeishuTenantApi
{
    [HttpGet("/open-apis/event/v1/outbound_ip1")]
    new System.Threading.Tasks.Task<HttpResponseMessage> GetEventV1OutboundIpAsync();
}
2、新增依赖注册
builder.Services.AddHttpApi<INewApi>();
3、修改依赖注入
public class TestController : ControllerBase
{
    //此处更改为新的API:INewApi
    private readonly INewApi _feishuApi;
    public TestController(INewApi feishuApi)
    {
        _feishuApi = feishuApi;
    }
}

启用状态异常错误

默认:关闭

飞书接口在返回结果异常时,同时会返回状态异常,状态异常通常无法实质判断异常原因,具体原因会在返回结果中提示。所以接口默认忽略状态异常,开启方法如下:

  1. 新建API,继承于 IFeishuTenantApi
  2. 添加接口属性 IgnoreStatusExceptionFilter 并将属性 Enable 设置为 false ,意为停用忽略,即启用异常提示。
  3. 参照上述使用新接口进行方法调用。
[IgnoreStatusExceptionFilter(Enable = false)]
public interface INewApi : IFeishuTenantApi
{ }

开启状态异常之后的捕获方法:

try
{
    var result2 = await _feishuApi.GetEventV1OutboundIpAsync();
    return Results.Json(result2);
}
catch (HttpRequestException ex) when (ex.InnerException is ApiResponseStatusException statusException)
{
    // 响应状态码异常
    return Results.Problem(statusException.Message);
}

关闭接口日志

默认:开启

  1. 新建API,继承于 IFeishuTenantApi
  2. 添加接口属性 LoggingFilter 并设置属性 Enablefalse ,即可停用日志。
  3. 参照上述使用新接口进行方法调用。
  4. LoggingFilterIgnoreStatusExceptionFilter 可以同时存在。
[LoggingFilter(Enable = false), IgnoreStatusExceptionFilter(Enable = false)]
public interface INewApi : IFeishuTenantApi
{ }

需要注意: IFeishuApiIFeishuTenantApi 各有独立的 LoggingFilterIgnoreStatusExceptionFilter 属性,若想全部关闭,需要分别继承接口并将属性 Enable 设置为 false

启用缓存

默认:关闭

缓存属性Cache,在接口上使用表示对接口内所有方法启用,建议仅针对具体方法使用,在单个方法上增加属性即可。数值单位是毫秒

public interface INewApi : IFeishuTenantApi
{
    [Cache(10 * 1000)]
    [HttpGet("/open-apis/event/v1/outbound_ip1")]
    new System.Threading.Tasks.Task<HttpResponseMessage> GetEventV1OutboundIpAsync();
}
Product Compatible and additional computed target framework versions.
.NET net6.0 is compatible.  net6.0-android was computed.  net6.0-ios was computed.  net6.0-maccatalyst was computed.  net6.0-macos was computed.  net6.0-tvos was computed.  net6.0-windows was computed.  net7.0 was computed.  net7.0-android was computed.  net7.0-ios was computed.  net7.0-maccatalyst was computed.  net7.0-macos was computed.  net7.0-tvos was computed.  net7.0-windows was computed.  net8.0 was computed.  net8.0-android was computed.  net8.0-browser was computed.  net8.0-ios was computed.  net8.0-maccatalyst was computed.  net8.0-macos was computed.  net8.0-tvos was computed.  net8.0-windows was computed.  net9.0 was computed.  net9.0-android was computed.  net9.0-browser was computed.  net9.0-ios was computed.  net9.0-maccatalyst was computed.  net9.0-macos was computed.  net9.0-tvos was computed.  net9.0-windows was computed.  net10.0 was computed.  net10.0-android was computed.  net10.0-browser was computed.  net10.0-ios was computed.  net10.0-maccatalyst was computed.  net10.0-macos was computed.  net10.0-tvos was computed.  net10.0-windows was computed. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

NuGet packages (2)

Showing the top 2 NuGet packages that depend on FeishuNetSdk:

Package Downloads
FeishuNetSdk.WebSocket

适用于飞书开放平台的.Net开发包

FeishuNetSdk.Endpoint

适用于飞书开放平台的.Net开发包

GitHub repositories

This package is not used by any popular GitHub repositories.

Version Downloads Last Updated
3.5.4 95 9/12/2025
3.5.3 158 9/5/2025
3.5.2 166 8/29/2025
3.5.1 83 8/23/2025
3.5.0 158 8/16/2025
3.4.9 121 8/9/2025
3.4.8 106 8/1/2025
3.4.7 243 7/26/2025
3.4.6 95 7/18/2025
3.4.5 101 7/11/2025
3.4.4 328 7/5/2025
3.4.3 101 6/27/2025
3.4.2 90 6/21/2025
3.4.1 233 6/13/2025
3.4.0 148 6/6/2025
3.3.9 106 5/30/2025
3.3.8 113 5/25/2025
3.3.7 174 5/18/2025
3.3.6 184 5/6/2025
3.3.5 185 4/18/2025
3.3.4 131 4/12/2025
3.3.3 120 4/5/2025
3.3.2 170 3/30/2025
3.3.1 143 3/21/2025
3.3.0 152 3/14/2025
3.2.9 263 3/7/2025
3.2.8 189 2/28/2025
3.2.7 190 2/21/2025
3.2.6 256 2/14/2025
3.2.5 267 2/9/2025
3.2.4 268 2/5/2025
3.2.3 328 1/17/2025
3.2.2 218 1/11/2025
3.2.1 426 1/6/2025
3.2.0 150 12/27/2024
3.1.9 159 12/21/2024
3.1.8 242 12/15/2024
3.1.7 478 12/8/2024
3.1.6 304 11/30/2024
3.1.5 267 11/27/2024
3.1.4 151 11/22/2024
3.1.3 162 11/15/2024
3.1.2 141 11/8/2024
3.1.1 249 11/3/2024
3.1.0 372 10/26/2024
3.0.9 283 10/23/2024
3.0.8 336 10/19/2024
3.0.7 166 10/12/2024
3.0.6 169 10/9/2024
3.0.5 141 9/27/2024
3.0.4 182 9/24/2024
3.0.3 154 9/21/2024
3.0.2 159 9/18/2024
3.0.1 176 9/13/2024
3.0.0 664 9/8/2024
2.4.6 229 9/1/2024
2.4.5 138 8/28/2024
2.4.4 191 8/24/2024
2.4.3 166 8/15/2024
2.4.2 175 8/8/2024
2.4.1 122 8/2/2024
2.4.0 403 7/30/2024
2.3.9 163 7/24/2024
2.3.8 153 7/22/2024
2.3.7 164 7/18/2024
2.3.6 169 7/12/2024
2.3.5 145 7/9/2024
2.3.4 152 7/4/2024
2.3.3 150 7/1/2024
2.3.2 158 6/27/2024
2.3.1 186 6/23/2024
2.3.0 158 6/20/2024
2.2.9 173 6/14/2024
2.2.8 152 6/7/2024
2.2.7 554 6/3/2024
2.2.6 129 5/28/2024
2.2.5 181 5/23/2024
2.2.4 129 5/13/2024
2.2.3 132 5/10/2024
2.2.2 164 4/30/2024
2.2.1 162 4/27/2024
2.2.0 186 4/23/2024
2.1.9.1 153 4/19/2024
2.1.8 222 4/11/2024
2.1.7 229 4/9/2024
2.1.6 157 4/2/2024
2.1.5 173 3/29/2024
2.1.4 151 3/26/2024
2.1.3 212 3/19/2024
2.1.2 185 3/7/2024
2.1.1 182 3/1/2024
2.1.0 180 2/20/2024
2.0.9 177 2/5/2024
2.0.8 387 1/26/2024
2.0.7 165 1/23/2024
2.0.6 187 1/12/2024
2.0.5 167 1/9/2024
2.0.4 170 1/4/2024
2.0.3 185 12/28/2023
2.0.2 182 12/21/2023
2.0.1 1,009 12/12/2023
2.0.0 197 12/6/2023
1.0.13 178 11/13/2023
1.0.12 171 11/12/2023
1.0.11 173 11/9/2023
1.0.10 178 11/7/2023
1.0.9 258 11/2/2023
1.0.8 149 10/31/2023
1.0.7 170 10/27/2023
1.0.6 175 10/26/2023
1.0.5 186 10/26/2023