《C#开发BIMFACE系列3 服务端API之获取应用访问凭证AccessToken》中详细介绍了应用程序访问API的令牌凭证。我们知道 Access token 代表自身应用的身份,使用应用的 appkey, secret,通过调用/oauth2/token接口获取。BIMFACE所有的接口调用都需要传递 Access token

本篇主要介绍 ViewToken。

View token

代表对单个模型/集成模型/模型对比的访问权限,使用 access token,通过调用/view/token或其他相关接口获得。

使用 Access token,可以对自己应用内的文件发起文件上传,下载,删除,模型转换,模型集成,模型对比等操作, 同时也能访问所有 BIMFACE 的数据接口获取转换后的模型BIM信息;而 View token 只代表对单个模型/集成模型/模型对比的临时的访问凭证, 只能访问对应模型的数据接口,通过使用应用的 Access token 调用下面的接口可以获得。 通常情况下,View token 可以直接传入前端 JSSDK 用来加载/浏览模型。

View token的使用方法是在调用对应的数据接口的时候,添加一个查询参数(Query parameter):

view_token={your_view_token}

只有在文件转换或模型集成任务成功以后,才能获取View token。

请求地址:GET https://api.bimface.com/view/token

说明:通过fileId, integrateId, compareId 获取View token, 然后把View token传入前端JavaScript组件提供的接口中,即可加载和浏览文件所包含的三维模型或二维图纸。

参数:application/octet-stream

请求 path(示例):https://api.bimface.com/view/token

请求 header(示例):"Authorization: Bearer dc671840-bacc-4dc5-a134-97c1918d664b"

HTTP响应示例(200):

{
"code": "success",
"message": null,
"data": "389c28de59ee62e66a7d87ec12692a76"
}

失败时返回:

{
"code": "authentication.failed",
"message": "Token was not recognized."
}

失败时返回的错误码:

C#实现方法:

 /// <summary>
/// 获取模型的 ViewToken
/// </summary>
/// <param name="accessToken">令牌</param>
/// <param name="modelType">模型类型</param>
/// <param name="objectId">文件转换ID(fileId)、模型对比ID(compareId)、集成模型ID(integrateId)的值,三者中的一个</param>
/// <returns></returns>
protected ViewTokenResponse GetViewToken(string accessToken, ModelType modelType, long objectId)
{
//GET https://api.bimface.com/view/token
string url = string.Format(BimfaceConstants.API_HOST + "/view/token?{0}={1}", modelType.ToString(), objectId);
BimFaceHttpHeaders headers = new BimFaceHttpHeaders();
headers.AddOAuth2Header(accessToken); try
{
ViewTokenResponse response;
HttpManager httpManager = new HttpManager(headers);
HttpResult httpResult = httpManager.Get(url);
if (httpResult.Status == HttpResult.STATUS_SUCCESS)
{
response = httpResult.Text.DeserializeJsonToObject<ViewTokenResponse>();
}
else
{
response = new ViewTokenResponse
{
Message = httpResult.RefText
};
} return response;
}
catch (Exception ex)
{
throw new Exception("[获取ViewToken] 发生异常!", ex);
}
}

其中调用到的 httpManager.Get() 方法,请参考《C# HTTP系列》

其中 ModelType 枚举,是为了区分不同模型的种类

 /// <summary>
/// 模型类型枚举
/// </summary>
public enum ModelType
{
/// <summary>
/// 文件转换ID
/// </summary>
fileId, /// <summary>
/// 模型对比ID
/// </summary>
compareId, /// <summary>
/// 集成模型ID
/// </summary>
integrateId
}

为了使调用更加的方便,扩展了3个更细致的方法

 /// <summary>
/// 获取单个模型的 ViewToken
/// </summary>
/// <param name="accessToken">令牌</param>
/// <param name="fileId">文件转换ID</param>
/// <returns></returns>
public ViewTokenResponse GetViewTokenByFileId(string accessToken, long fileId)
{
return GetViewToken(accessToken, ModelType.fileId, fileId);
}
 /// <summary>
/// 获取模型集成的 ViewToken
/// </summary>
/// <param name="accessToken">令牌</param>
/// <param name="integrateId">集成模型ID</param>
/// <returns></returns>
public ViewTokenResponse GetViewTokenByIntegrateId(string accessToken, long integrateId)
{
return GetViewToken(accessToken, ModelType.integrateId, integrateId);
}
 /// <summary>
/// 获取模型比对的 ViewToken
/// </summary>
/// <param name="accessToken">令牌</param>
/// <param name="compareId">模型比对ID</param>
/// <returns></returns>
public ViewTokenResponse GetViewTokenByCompareId(string accessToken, long compareId)
{
return GetViewToken(accessToken, ModelType.compareId, compareId);
}
测试

在BIMFACE的控制台中可以看到我们上传的文件列表,共计2个文件。模型状态均为转换成功。

【获取ViewToken】、【公开链接】按钮只有在模型转换成功之后才启用。

调用上面封装的方法来测试是否能获取到viewToken,以第一个文件“rac_advanced_sample_project-三维视图 - From Parking Area.dwg” 为例

在BIMFACE控制台中查看该文件的ViewToken

 
可以看到两者的结果是一致的。

测试程序如下:

 // 获取 ViewToken【文件转换ID】
protected void btnGetViewTokenByFileId_Click(object sender, EventArgs e)
{
BasicApi api = new BasicApi();
ViewTokenResponse response = api.GetViewTokenByFileId(txtAccessToken.Text, txtFileId.Text.ToLong()); txtResult.Text = response.Code
+ Environment.NewLine
+ response.Message
+ Environment.NewLine
+ response.Data.ToString2();
}

返回的结果对应的实体类如下:

 /// <summary>
/// 获取 ViewToken 的请求返回结果类
/// </summary>
[Serializable]
public class ViewTokenResponse : GeneralResponse<string>
{ }

继承的基类如下:

 /// <summary>
/// 请求 BIMFACE 服务端 API的响应结果统一的返回类
/// </summary>
[Serializable]
public class GeneralResponse<T> //where T : class, new()
{
#region 属性 /// <summary>
/// 请求返回代码,success 或者 xxxx.failed。
/// </summary>
[JsonProperty("code")]
public virtual string Code { get; set; } /// <summary>
/// 失败的错误原因。
/// 如果 Code 为 success 则 Message 为空。
/// 如果 Code 为 xxxx.failed 则 Message 为具体的失败信息。
/// </summary>
[JsonProperty("message")]
public virtual string Message { get; set; } /// <summary>
/// 执行成功后的返回结果
/// </summary>
[JsonProperty("data")]
public virtual T Data { get; set; } #endregion #region 构造函数
public GeneralResponse()
{
} public GeneralResponse(T data)
{
this.Data = data;
} #endregion #region 方法
public override string ToString()
{
if (Data != null)
{
return string.Format("GeneralResponse [code={0}, message={1}, data={2}]", Code, Message, Data);
}
else
{
return string.Format("GeneralResponse [code={0}, message={1}, data={2}]", Code, Message, "");
}
} #endregion
}
 

C#开发BIMFACE系列15 服务端API之获取模型的View token的更多相关文章

  1. C#开发BIMFACE系列17 服务端API之获取模型数据2:获取构件材质列表

    系列目录     [已更新最新开发文章,点击查看详细] 在上一篇<C#开发BIMFACE系列16 服务端API之获取模型数据1:查询满足条件的构件ID列表>中介绍了获取单文件(模型)的所有 ...

  2. C#开发BIMFACE系列18 服务端API之获取模型数据3:获取构件属性

    系列目录     [已更新最新开发文章,点击查看详细] 本篇主要介绍如何获取单文件/模型下单个构建的属性信息. 请求地址:GET https://api.bimface.com/data/v2/fil ...

  3. C#开发BIMFACE系列19 服务端API之获取模型数据4:获取多个构件的共同属性

    系列目录     [已更新最新开发文章,点击查看详细] 在前几篇博客中介绍了一个三维文件/模型包含多个构建,每个构建又是由多种材质组成,每个构建都有很多属性.不同的构建也有可能包含相同的属性. 上图中 ...

  4. C#开发BIMFACE系列21 服务端API之获取模型数据6:获取单模型的楼层信息

    系列目录     [已更新最新开发文章,点击查看详细] 一个文件/模型中可能包含多个楼层信息,获取楼层信息对于前端页面的动态展示非常有帮助.本篇介绍获取一个文件/模型中可能包含多个楼层信息的详细方法. ...

  5. C#开发BIMFACE系列24 服务端API之获取模型数据9:获取单个房间信息

    系列目录     [已更新最新开发文章,点击查看详细] 大厦建筑模型中,基本上包含多个楼层,每个楼层包含多个房间等信息.在<C#开发BIMFACE系列21 服务端API之获取模型数据6:获取单模 ...

  6. C#开发BIMFACE系列25 服务端API之获取模型数据10:获取楼层对应面积分区列表

    系列目录     [已更新最新开发文章,点击查看详细] 在<C#开发BIMFACE系列22 服务端API之获取模型数据7:获取多个模型的楼层信息>中,返回的楼层信息结果中包含了楼层的具体信 ...

  7. C#开发BIMFACE系列22 服务端API之获取模型数据7:获取多个模型的楼层信息

    系列目录     [已更新最新开发文章,点击查看详细] 在<C#开发BIMFACE系列21 服务端API之获取模型数据6:获取单模型的楼层信息>中介绍获取单个模型的所有楼层信息.某些场景下 ...

  8. C#开发BIMFACE系列26 服务端API之获取模型数据11:获取单个面积分区信息

    系列目录     [已更新最新开发文章,点击查看详细] 在<C#开发BIMFACE系列25 服务端API之获取模型数据9:获取楼层对应面积分区列表>一文中介绍了如何获取单个模型中单个楼层包 ...

  9. C#开发BIMFACE系列20 服务端API之获取模型数据5:批量获取构件属性

    系列目录     [已更新最新开发文章,点击查看详细] 在<C#开发BIMFACE系列18 服务端API之获取模型数据3:获取构件属性>中介绍了获取单个文件/模型的单个构建的属性,本篇介绍 ...

随机推荐

  1. Geodesic 什么是“测地线的”?

    确定是使用上椭球体(测地线)还是平地上(平面)的最短路径.强烈建议将 Geodesic 方法用于在不适合进行距离测量的坐标系(例如 Web 墨卡托或任何地理坐标系)中存储的数据,以及任何地理区域跨度较 ...

  2. SpringCloudGateWay修改请求路径,从注册中心获得服务

    SpringCloudGateWay修改请求路径,从注册中心获得服务 @Resource    private DiscoveryClient disClient;    @Resource    p ...

  3. 选择IT公司的雇主提问

    做为IT从业人员,我们去一家公司时,判断一家公司的专业性时,可以通过以下提问获得反馈: 技术问题 1.这个项目使用了哪些技术(语言,框架,库)?2.应用程序是一体化架构还是微服务架构?3.采用了哪些设 ...

  4. avd manger创建的虚拟机启动不起来,或者启动起来后黑屏

    最近鼓捣安卓虚拟机,整的都差点重装系统,刚开始下载了genymotion_vbox,装完以后要在vbox中导入一个虚拟机,结果我导入完,虚拟机怎么也启动不了,然后各种找办法无果,最后重启电脑发现电脑也 ...

  5. Linux目录详解,软件应该安装到哪个目录

    原文地址:https://www.w3h5.com/post/336.html 我们应该知道 Windows 有一个默认的安装目录专门用来安装软件.Linux 的软件安装目录也应该是有讲究的,遵循这一 ...

  6. 12. Go 语言文件处理

    Go 语言文件处理 本章我们将带领大家深入了解一下 Go语言中的文件处理,重点在于文件而非目录或者通用的文件系统,特别是如何读写标准格式(如 XML 和 JSON 格式)的文件以及自定义的纯文本和二进 ...

  7. TestNG如何用命令行运行

    TestNG如何用命令行运行 调用TestNG最简单的方法事下面的: java org.testng.TestNG testng1.xml 以上是我在网上搜索到的最多的答案,但对于第一次接触testn ...

  8. [考试反思]1114csp-s模拟测试115:零迟

    最后一次了,允许自己混进榜里吧. 没有心态,原题不会做(真的忘了) T2的搜索没有分. 「 零 · 迟 」:酷刑 只有在最后的时刻才开始意识到,一切的一切都已经晚了. 就在眼前了.没有机会了. 退役, ...

  9. MySQL常用SQL语句总结

    1.with rollup 可以实现在分组统计数据基础上再进行相同的统计 SELECT name, SUM(score) as score_count FROM  score GROUP BY nam ...

  10. 2019年百度最新Java工程师面试题

    一.单选题(共27题,每题5分) 1若下列所用变量均已经正确定义,以下表达式中不合法的是?   A.x>>3 B.+++j C.a=x>y?x:y D.x%=4 参考答案:B 答案解 ...