C#开发BIMFACE系列7 服务端API之获取文件信息列表

本文详细介绍如何获取BIMFACE平台中所有上传过的文件信息列表。
请求地址:GET https://file.bimface.com/files
说明:根据多种查询条件获取文件详细信息列表,支持分页
参数:
请求 path(示例):https://file.bimface.com/files
请求 header(示例):"Authorization: Bearer dc671840-bacc-4dc5-a134-97c1918d664b"
HTTP响应示例(200):
{ "code" : "success", "data" : [ { "createTime" : "2017-11-09 13:25:03", "etag" : "19349858cjs98ericu989", "fileId" : 1216113551663296, "length" : 39044, "name" : "-1F.rvt", "status" : "success", "suffix" : "rvt" } ], "message" : "" }
注意上面返回的data内容是一个数组。
C#实现方法:
1 /// <summary> 2 /// 根据多种查询条件获取文件详细信息列表,支持分页 3 /// </summary> 4 /// <param name="accessToken">令牌</param> 5 /// <param name="startTime">起始日期,格式为 yyyy-MM-dd。默认为空,查询所有</param> 6 /// <param name="endTime">截止日期,格式为 yyyy-MM-dd。默认为空,查询所有</param> 7 /// <param name="rows">查询结果数, 默认为100, 最大500。默认100</param> 8 /// <param name="offset">查询结果偏移,从查询结果的第offset条开始返回数据。默认-1,查询所有</param> 9 /// <param name="status">文件状态,uploading,success,failure。默认为空,查询所有</param> 10 /// <param name="suffix">文件后缀。默认为空,查询所有</param> 11 /// <returns></returns> 12 public virtual FileInfoListGetResponse GetFileInfoList(string accessToken, string startTime = "", string endTime = "", long rows = 100, long offset = -1, string status = "", string suffix = "") 13 { 14 FileInfoListGetResponse response = new FileInfoListGetResponse(); 15 16 #region 校验 17 if (rows < 0 || rows > 500) 18 { 19 response.Message = "参数[rows]超出范围。要求控制在1到500之间!"; 20 21 return response; 22 } 23 24 #endregion 25 26 //GET https://file.bimface.com/files 27 string url = BimfaceConstants.FILE_HOST + "/files"; 28 url = url + "?rows=" + rows; 29 if (!string.IsNullOrWhiteSpace(startTime)) 30 { 31 url = url + "?rows=" + rows; 32 } 33 if (!string.IsNullOrWhiteSpace(endTime)) 34 { 35 url = url + "?endTime=" + endTime; 36 } 37 if (offset >= 0) 38 { 39 url = url + "?offset=" + offset; 40 } 41 if (!string.IsNullOrWhiteSpace(status)) 42 { 43 url = url + "?status=" + status; 44 } 45 if (!string.IsNullOrWhiteSpace(suffix)) 46 { 47 url = url + "?suffix=" + suffix; 48 } 49 50 BimFaceHttpHeaders headers = new BimFaceHttpHeaders(); 51 headers.AddOAuth2Header(accessToken); 52 53 try 54 { 55 HttpManager httpManager = new HttpManager(headers); 56 HttpResult httpResult = httpManager.Get(url); 57 if (httpResult.Status == HttpResult.STATUS_SUCCESS) 58 { 59 response = httpResult.Text.DeserializeJsonToObject<FileInfoListGetResponse>(); 60 } 61 else 62 { 63 response = new FileInfoListGetResponse 64 { 65 Message = httpResult.RefText 66 }; 67 } 68 69 return response; 70 } 71 catch (Exception ex) 72 { 73 throw new Exception("[获取文件信息列表]发生异常!", ex); 74 } 75 }
其中引用的 httpManager.Get() 方法,请参考《C#开发BIMFACE系列6 服务端API之获取文件信息》,方法完全一样。
在BIMFACE的控制台中可以看到我们上传的文件列表,共计2个文件。
下面通过调用上述的GetFileInfoList()方法来测试,结果如下,与后台的文件列表一致。
测试程序如下:
// 获取文件信息列表 protected void btnGetFileList_Click(object sender, EventArgs e) { txtFileInfo.Text = string.Empty; string token = txtAccessToken.Text; FileApi api = new FileApi(); FileInfoListGetResponse response = api.GetFileInfoList(token); List<FileInfoGetEntity> fileInfoList = response.Data; StringBuilder sbFiles = new StringBuilder(); foreach(FileInfoGetEntity fileInfo in fileInfoList) { sbFiles.AppendLine("名称:" + fileInfo.ToString()); } txtFileInfo.Text = response.Code + Environment.NewLine + response.Message + Environment.NewLine + "共获取 " + fileInfoList.Count + " 个文件。" + Environment.NewLine + sbFiles; }
成在管理,败在经验;嬴在选择,输在不学! 贵在坚持!
个人作品
BIMFace.SDK.NET
开源地址:https://gitee.com/NAlps/BIMFace.SDK
系列博客:https://www.cnblogs.com/SavionZhang/p/11424431.html
系列视频:https://www.cnblogs.com/SavionZhang/p/14258393.html
技术栈
1、AI、DeepSeek、MiniMax、通义千问
2、Visual Studio、.NET Core/.NET、MVC、Web API、RESTful API、gRPC、SignalR、Java、Python
3、jQuery、Vue.js、Bootstrap、ElementUI
4、数据库:分库分表、读写分离、SQLServer、MySQL、PostgreSQL、Redis、MongoDB、ElasticSearch、达梦DM、GaussDB、OpenGauss
5、架构:DDD、ABP、SpringBoot、jFinal
6、环境:跨平台、Windows、Linux
7、移动App:Android、IOS、HarmonyOS、微信小程序、钉钉、uni-app、MAUI
8、分布式、高并发、云原生、微服务、Docker、CI/CD、DevOps、K8S;Dapr、RabbitMQ、Kafka、RPC、Elasticsearch
欢迎关注作者头条号 张传宁IT讲堂,获取更多IT文章、视频等优质内容。
出处:www.cnblogs.com/SavionZhang
作者:张传宁 技术顾问、培训讲师、微软MCP、系统架构设计师、系统集成项目管理工程师、科技部创新工程师。
专注于企业级通用开发平台、工作流引擎、自动化项目(代码)生成器、SOA 、DDD、 云原生(Docker、微服务、DevOps、CI/CD);PDF、CAD、BIM 审图等研究与应用。
多次参与电子政务、图书教育、生产制造等企业级大型项目研发与管理工作。
熟悉中小企业软件开发过程:可行调研、需求分析、架构设计、编码测试、实施部署、项目管理。通过技术与管理帮助中小企业实现互联网转型升级全流程解决方案。
本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利。
如有问题,可以通过邮件905442693@qq.com联系。共同交流、互相学习。
如果您觉得文章对您有帮助,请点击文章右下角【推荐】。您的鼓励是作者持续创作的最大动力!
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· DeepSeek 开源周回顾「GitHub 热点速览」
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· AI与.NET技术实操系列(二):开始使用ML.NET
· 单线程的Redis速度为什么快?