Java本地应用程序嵌入PowerBi报表

1 篇文章 0 订阅
1 篇文章 0 订阅

需求:使用Power bi 分析数据,生成报表页面,将指定的报表页面嵌入到自己的应用程序。
建议:如果没有了解oauth2.0协议的,可以先了解一下这个协议。这样可以更好的理解微软是如何让第三方应用访问它的服务的。
实现方式:使用access token访问Power bi 服务,将业务嵌入应用程序中。 那么问题来了,我们如何获取access token呢?别着急,先给大家一个官方参考文档:https://docs.microsoft.com/zh-cn/power-bi/developer/register-app

  1. 首先我们需要将自己的应用程序注册到Azure中:在这里插入图片描述
  2. 点击新注册,添加应用程序。完成注册后点击进入该应用,后添加证书和密码,创建新客户端密码:
    在这里插入图片描述
  3. 添加API 权限
    在这里插入图片描述
    这一步需要管理员授予同意,在该页面下有个“代表XXX授予管理员同意"的按钮(管理员账号)点击使新增的权限生效。

好了,上面参考文档就是为了完成这件事的。
下面我们可以进入本地应用与Azure以及Power bi的具体的交互流程了。等一下,还有一件事需要确认,我们的Azure账号是否有访问Power bi的权限,到Azure管理界面 “用户->所有用户” 选择许可证。
首先我们需要了解Azure授权流程:https://docs.microsoft.com/zh-cn/azure/active-directory/develop/v1-protocols-oauth-code 这是OAuth2.0的授权码模式获取token的方式,我之前通过这个模式获取access token,而且代码还是官方提供的Java sample,链接地址:https://github.com/Azure-Samples/ms-identity-java-webapp 但是我用这个代码获取token之后无法访问power bi,大家可以自己再摸索摸索。
下面介绍的是密码模式获取access token。官方文档中提供的OAuth2.0流程访问的地址后缀都是.com但是我们power bi中国区的域名是.cn的所以如果按照标准获取的token是无法访问的。
获取Azure access token的地址:https://login.chinacloudapi.cn/common/oauth2/token
请求方式:POST
参数:
grant_type :password
scope: openid
resource: https://analysis.chinacloudapi.cn/powerbi/api
client_id: a4bd784c-9c02-4c4e-b116-ff6993f5d97d
username:test@abc.partner.onmschina.cn
password: test1234
在这里插入图片描述
成功获取token后,使用Bearer token 方式访问power bi的列表:
请求地址:https://api.powerbi.cn/v1.0/myorg/groups/{groupId}/reports
在这里插入图片描述
返回的结果列表中有每个report的信息,但是如果我想要访问embedUrl还不行,因为power bi每个报表都要有与其对应的accesstoken,所以我们还要针对不同的report生成不同的access token,同样需要用到上一步生成的Azure token去访问
请求地址:https://api.powerbi.cn/v1.0/myorg/groups/{groupId}/reports/{reportId}/GenerateToken
请求方式:POST
参数:
{
“accessLevel”: “View”,
“allowSaveAs”: “false”
}
最终生成的token就是我们访问该报表的token了。前端用embedUrl + token 就可以访问了。
使用js开发,微软提供了封装好的js代码,地址:
https://github.com/Microsoft/powerbi-javascript/wiki
前端调试地址:https://microsoft.github.io/PowerBI-JavaScript/demo/v2-demo/index.html#

到此,我们所有流程都走完了,希望对大家对接power bi有帮助!

  • 0
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值