Skip to content

云空间文件管理 - 用户权限(FeishuUserV1DriveFiles)

接口名称

云空间文件管理(用户权限) -(IFeishuUserV1DriveFiles

功能描述

提供以用户身份管理飞书云空间文件的能力,继承自租户权限文件接口的所有功能,同时支持用户视角下的云文档搜索功能。适用于需要以具体用户身份操作云文档的业务场景,如个人文件管理、用户级文档搜索等。

参考文档

函数列表

函数名称功能描述认证方式HTTP 方法
BatchQueryMetasAsync批量获取文件元数据用户令牌POST
GetFileStatisticsByFileTokenAsync获取文件统计信息用户令牌GET
GetFileViewRecordPageListByFileTokenAsync获取文件访问记录用户令牌GET
CopyFileByFileTokenAsync复制文件用户令牌POST
MoveFileByFileTokenAsync移动文件用户令牌POST
DeleteFileByFileTokenAsync删除文件用户令牌DELETE
CreateShortcutAsync创建文件快捷方式用户令牌POST
UploadAllFileAsync上传文件(完整上传)用户令牌POST
UploadPrepareFileAsync预上传(分片上传初始化)用户令牌POST
UploadPartFileAsync上传分片用户令牌POST
UploadFinishFileAsync完成分片上传用户令牌POST
DownloadFileAsync下载文件用户令牌GET
CreateImportTaskAsync创建导入任务用户令牌POST
GetImportTaskAsync查询导入任务结果用户令牌GET
CreateExportTaskAsync创建导出任务用户令牌POST
GetExportTaskAsync查询导出任务结果用户令牌GET
DownloadExportFileAsync下载导出文件用户令牌GET
DownloadExportLargeFileAsync下载导出大文件用户令牌GET
GetFileLikePageListByFileTokenAsync获取文件点赞列表用户令牌GET
SearchFilesAsync搜索云文档用户令牌POST

函数详细内容

批量获取文件元数据

函数签名

csharp
Task<FeishuApiResult<MetasBatchQueryResult>?> BatchQueryMetasAsync(
    [Body] MetasBatchQueryRequest metasBatchQueryRequest,
    [Query("user_id_type")] string? user_id_type = "open_id",
    CancellationToken cancellationToken = default);

认证:用户令牌

参数

参数名类型必填说明
metasBatchQueryRequestMetasBatchQueryRequest请求体
├─ RequestDocsRequestDoc[]请求的文件的 token 和类型,一次请求中不可超过 200 个
├─ WithUrlbool?是否获取文件的访问链接
user_id_typestring?用户 ID 类型,默认 open_id

响应

json
{
  "code": 0,
  "msg": "success",
  "data": {
    "metas": [
      {
        "doc_token": "doccnfYZzTlvXqZIGTdAHKabcef",
        "doc_type": "docx",
        "title": "项目文档",
        "owner_id": "ou_xxxxxxxx",
        "create_time": "2024-01-15T08:30:00",
        "edit_time": "2024-01-20T14:22:00",
        "url": "https://example.feishu.cn/docx/xxx"
      }
    ],
    "failed_list": []
  }
}

说明:用于根据文件 token 获取其元数据,包括标题、所有者、创建时间、密级、访问链接等数据。


获取文件统计信息

函数签名

csharp
Task<FeishuApiResult<FileStatisticsReuslt>?> GetFileStatisticsByFileTokenAsync(
    [Path] string? file_token,
    [Query("file_type")] string file_type,
    CancellationToken cancellationToken = default);

认证:用户令牌

参数

参数名类型必填说明
file_tokenstring?文件 token,示例值:doccnfYZzTlvXqZIGTdAHKabcef
file_typestring文件类型:doc/docx/sheet/bitable/mindnote/wiki/file

响应

json
{
  "code": 0,
  "msg": "success",
  "data": {
    "file_token": "doccnfYZzTlvXqZIGTdAHKabcef",
    "uv": 150,
    "pv": 320,
    "like_count": 25
  }
}

说明:获取各类文件的流量统计信息和互动信息,包括阅读人数(UV)、阅读次数(PV)和点赞数。


获取文件访问记录

函数签名

csharp
Task<FeishuApiPageListResult<FileViewRecord>?> GetFileViewRecordPageListByFileTokenAsync(
    [Path] string? file_token,
    [Query("file_type")] string file_type,
    [Query("page_size")] int page_size = 10,
    [Query("page_token")] string? page_token = null,
    [Query("viewer_id_type")] string? viewer_id_type = "open_id",
    CancellationToken cancellationToken = default);

认证:用户令牌

说明:获取文档、电子表格、多维表格等文件的历史访问记录,包括访问者的 ID、姓名、头像和最近访问时间。


复制文件

函数签名

csharp
Task<FeishuApiResult<CopyFileResult>?> CopyFileByFileTokenAsync(
    [Body] CopyFileRequest copyFileRequest,
    [Path] string? file_token,
    [Query("user_id_type")] string? user_id_type = "open_id",
    CancellationToken cancellationToken = default);

认证:用户令牌

参数

参数名类型必填说明
file_tokenstring?源文件 token
copyFileRequestCopyFileRequest复制请求体
├─ Namestring新文件名称,最大 256 字节
├─ Typestring?源文件类型
├─ FolderTokenstring目标文件夹 token
├─ ExtrasProperty[]?自定义附加参数
user_id_typestring?用户 ID 类型

响应

json
{
  "code": 0,
  "msg": "success",
  "data": {
    "file_token": "doccnNewTokenxxxx",
    "task_id": "task_xxxxxxxx"
  }
}

说明:将用户云空间中的文件复制至其它文件夹下。该接口为异步接口。


移动文件

函数签名

csharp
Task<FeishuApiResult<FileTaskResult>?> MoveFileByFileTokenAsync(
    [Body] MoveFileRequest moveFileRequest,
    [Path] string? file_token,
    CancellationToken cancellationToken = default);

认证:用户令牌

说明:将文件或者文件夹移动到用户云空间的其他位置。该接口为异步接口。


删除文件

函数签名

csharp
Task<FeishuApiResult<FileTaskResult>?> DeleteFileByFileTokenAsync(
    [Path] string? file_token,
    [Query("type")] string file_type,
    CancellationToken cancellationToken = default);

认证:用户令牌

说明:删除用户在云空间内的文件或者文件夹。文件或文件夹被删除后,会进入回收站中。


创建文件快捷方式

函数签名

csharp
Task<FeishuApiResult<CreateShortcutResult>?> CreateShortcutAsync(
    [Body] CreateShortcutRequest createShortcutRequest,
    [Query("user_id_type")] string? user_id_type = "open_id",
    CancellationToken cancellationToken = default);

认证:用户令牌

说明:创建指定文件的快捷方式到云空间的其它文件夹中。


上传文件(完整上传)

函数签名

csharp
Task<FeishuApiResult<FilesUploadAllResult>?> UploadAllFileAsync(
    [FormContent] UploadAllFileRequest uploadAllFileRequest,
    CancellationToken cancellationToken = default);

认证:用户令牌

参数

参数名类型必填说明
uploadAllFileRequestUploadAllFileRequest上传请求体
├─ FileNamestring文件名称,最大 250 字符
├─ ParentTypestring上传点类型,固定值 explorer
├─ ParentNodestring文件夹 token
├─ Sizeint文件大小(字节),最大 20971520(20MB)
├─ Checksumstring?Adler-32 校验和
├─ FilePathstring?本地文件绝对路径

响应

json
{
  "code": 0,
  "msg": "success",
  "data": {
    "file_token": "boxcnxxxxxxxx",
    "name": "demo.pdf",
    "size": 1024000,
    "url": "https://example.feishu.cn/file/xxx"
  }
}

说明:将指定文件上传至云空间指定目录中。文件大小不得超过 20 MB。


下载文件

函数签名

csharp
Task<byte[]?> DownloadFileAsync(
    [Path] string file_token,
    [Header("Range")] string? range = null,
    CancellationToken cancellationToken = default);

认证:用户令牌

说明:下载云空间中的文件,支持通过 Range 参数分片下载。


创建导入任务

函数签名

csharp
Task<FeishuApiResult<TasksResult>?> CreateImportTaskAsync(
    [Body] ImportTasksRequest importTasksRequest,
    CancellationToken cancellationToken = default);

认证:用户令牌

说明:用于创建导入文件的任务,将本地文件如 Word、TXT、Markdown、Excel 等导入为飞书在线云文档。


查询导入任务结果

函数签名

csharp
Task<FeishuApiResult<ImportTaskResult>?> GetImportTaskAsync(
    [Path] string ticket,
    CancellationToken cancellationToken = default);

认证:用户令牌

说明:根据导入任务 ID 轮询导入结果。


创建导出任务

函数签名

csharp
Task<FeishuApiResult<TasksResult>?> CreateExportTaskAsync(
    [Body] ExportTasksRequest exportTasksRequest,
    CancellationToken cancellationToken = default);

认证:用户令牌

说明:用于创建导出文件的任务,将飞书文档导出为 Word、Excel、PDF、CSV 格式。


查询导出任务结果

函数签名

csharp
Task<FeishuApiResult<ExportTasksResult>?> GetExportTaskAsync(
    [Path] string ticket,
    [Query] string? token,
    CancellationToken cancellationToken = default);

认证:用户令牌

说明:轮询导出任务结果,并返回导出文件的 token。


下载导出文件

函数签名

csharp
Task<byte[]?> DownloadExportFileAsync(
    [Path] string file_token, 
    CancellationToken cancellationToken = default);

认证:用户令牌

说明:下载导出产物到本地。需在导出任务结束 10 分钟内下载。


获取文件点赞列表

函数签名

csharp
Task<FeishuApiPageListResult<FileLikeInfo>?> GetFileLikePageListByFileTokenAsync(
    [Path] string? file_token,
    [Query("file_type")] string file_type,
    [Query("page_size")] int page_size = 10,
    [Query("page_token")] string? page_token = null,
    [Query("user_id_type")] string? user_id_type = "open_id",
    CancellationToken cancellationToken = default);

认证:用户令牌

说明:获取指定云文档的点赞者列表并按点赞时间由近到远分页返回。


搜索云文档

函数签名

csharp
Task<FeishuApiResult<SearchFileObjectResult>?> SearchFilesAsync(
    [Body] SearchFileObjectRequest searchFileObjectRequest,
    CancellationToken cancellationToken = default);

认证:用户令牌

参数

参数名类型必填说明
searchFileObjectRequestSearchFileObjectRequest搜索请求体
├─ SearchKeystring搜索关键词
├─ Countint?返回文件数量,取值范围 [0,50]
├─ Offsetint?偏移量,offset + count < 200
├─ OwnerIdsstring[]?文件所有者的 Open ID 列表
├─ ChatIdsstring[]?文件所在群的 ID 列表
├─ DocsTypesstring[]?文件类型过滤:doc/sheet/slides/bitable/mindnote/file

响应

json
{
  "code": 0,
  "msg": "success",
  "data": {
    "docs_entities": [
      {
        "docs_token": "doccnfYZzTlvXqZIGTdAHKabcef",
        "docs_type": "docx",
        "title": "产品需求文档",
        "owner_id": "ou_xxxxxxxx",
        "owner_name": "张三",
        "edit_time": "2024-01-20T14:22:00",
        "url": "https://example.feishu.cn/docx/xxx"
      }
    ],
    "has_more": false,
    "total": 15
  }
}

说明:用于根据搜索关键词对当前用户可见的云文档进行搜索。支持按所有者、群聊、文件类型等条件过滤。

代码示例

csharp
public class DocumentSearchService
{
    private readonly IFeishuUserV1DriveFiles _driveFilesClient;

    public DocumentSearchService(IFeishuUserV1DriveFiles driveFilesClient)
    {
        _driveFilesClient = driveFilesClient;
    }

    public async Task SearchUserDocumentsAsync(string keyword)
    {
        var request = new SearchFileObjectRequest
        {
            SearchKey = keyword,
            Count = 20,
            Offset = 0,
            DocsTypes = new[] { "docx", "sheet" }  // 只搜索文档和表格
        };

        var result = await _driveFilesClient.SearchFilesAsync(request);
        if (result?.Data?.DocsEntities != null)
        {
            foreach (var doc in result.Data.DocsEntities)
            {
                Console.WriteLine($"找到文档: {doc.Title}, 类型: {doc.DocsType}, 作者: {doc.OwnerName}");
            }
            Console.WriteLine($"总计: {result.Data.Total} 个结果");
        }
    }

    public async Task SearchByOwnerAsync(string keyword, string ownerId)
    {
        var request = new SearchFileObjectRequest
        {
            SearchKey = keyword,
            OwnerIds = new[] { ownerId },
            Count = 10
        };

        var result = await _driveFilesClient.SearchFilesAsync(request);
        // 处理搜索结果...
    }
}