当使用Angular和Power BI进行集成时,可能会出现 CORS(跨域资源共享)问题,这会导致Ajax请求无法成功完成。以下是一些解决 CORS 问题的方法:
1.通过服务器端来解决:可以在WebAPI或Node.js等服务器端代码中添加CORS支持,允许跨域请求。这需要在服务器端上进行配置。
2.使用HTTP代理服务:可以使用一个HTTP代理服务器,与Power BI服务进行通信。当Angular应用程序向代理服务器发送请求时,代理服务器会将请求转发到Power BI服务器,并将响应返回到Angular应用程序。这可以避免跨域请求问题。
3.使用 JSONP:原生的Ajax请求不能跨域,但是JSONP可以。可以使用Angular的 $jsonp 服务,来替代 $http。这可以帮助解决跨域问题。
以下是示例代码,使用了第一种方法(WebAPI):
config.EnableCors(new EnableCorsAttribute("", "", "*"));
const config = { type: 'report', tokenType: models.TokenType.Embed, accessToken: 'xxxxx', embedUrl: 'https://app.powerbi.com/reportEmbed' permissions: models.Permissions.Read, allowCrosOrigin: true };