在 Web 应用程序中嵌入 Power BI 仪表板是与用户安全共享见解的强大方法。在本教程中,我将指导您完成使用 Express 为后端和 React 为前端设置基本解决方案的步骤,同时涵盖 Azure 中的基本配置 和 Power BI。
1. Azure 中的配置
要嵌入 Power BI 报告,您需要在 Azure Active Directory 中注册应用程序:
-
注册申请:
- 转到 Azure 门户 → Azure Active Directory → 应用程序注册 → 新注册。
- 输入名称(例如“PowerBIEmbedApp”)并将重定向 URI 设置为前端的基本 URL。
-
API 权限:
- 添加 Power BI 服务的权限(委派和应用程序)。
- 授予管理员同意权限。
-
客户秘密:
- 在证书和机密下创建新的客户端机密。
- 记下应用程序(客户端)ID、目录(租户)ID和客户端密钥。
2. Power BI 中的配置
-
启用嵌入令牌生成:
- 登录 Power BI 服务 → 管理门户 → 租户设置。
- 启用“允许服务主体使用 Power BI API”。
-
分配工作空间访问权限:
- 以管理员或成员身份将服务主体(注册的应用)添加到 Power BI 工作区。
-
获取仪表板/报告 ID:
- 记下要嵌入的内容的工作区、仪表板和报告 ID。
3. 后端:快速设置
后端负责为仪表板生成嵌入式令牌。
安装依赖项:
npm install express axios dotenv
后端代码:
const express = require('express'); const axios = require('axios'); const dotenv = require('dotenv'); dotenv.config(); const app = express(); app.use(express.json()); // Environment variables from .env const { TENANT_ID, CLIENT_ID, CLIENT_SECRET, WORKSPACE_ID, REPORT_ID, } = process.env; const POWER_BI_AUTH_URL = `https://login.microsoftonline.com/${TENANT_ID}/oauth2/v2.0/token`; app.get('/api/getEmbedToken', async (req, res) => { try { // Get Access Token const authResponse = await axios.post(POWER_BI_AUTH_URL, new URLSearchParams({ grant_type: 'client_credentials', client_id: CLIENT_ID, client_secret: CLIENT_SECRET, scope: 'https://analysis.windows.net/powerbi/api/.default', })); const accessToken = authResponse.data.access_token; // Get Embed Token const embedResponse = await axios.post( `https://api.powerbi.com/v1.0/myorg/groups/${WORKSPACE_ID}/reports/${REPORT_ID}/GenerateToken`, { accessLevel: 'View' }, { headers: { Authorization: `Bearer ${accessToken}` } } ); res.json(embedResponse.data); } catch (error) { console.error(error.message); res.status(500).send('Error generating embed token'); } }); const PORT = 5000; app.listen(PORT, () => console.log(`Server running on port ${PORT}`));
4. 前端:React 设置
安装依赖项:
npm install react powerbi-client axios
前端代码:
import React, { useEffect, useState } from 'react'; import axios from 'axios'; import { PowerBIEmbed } from 'powerbi-client-react'; const Dashboard = () => { const [embedConfig, setEmbedConfig] = useState(null); useEffect(() => { const fetchEmbedToken = async () => { try { const response = await axios.get('http://localhost:5000/api/getEmbedToken'); setEmbedConfig({ type: 'report', tokenType: 1, accessToken: response.data.token, embedUrl: response.data.embedUrl, settings: { panes: { filters: { visible: false } } }, }); } catch (error) { console.error('Error fetching embed token:', error); } }; fetchEmbedToken(); }, []); if (!embedConfig) return <div>Loading...</div>; return ( <powerbiembed embedconfig="{embedConfig}" cssclassname="dashboard-embed"></powerbiembed> ); }; export default Dashboard;
5. 最后步骤
- 运行后端:node server.js。
- 运行前端:npm start(假设创建React App或类似设置)。
- 访问您的前端应用程序以查看嵌入式 Power BI 仪表板。
要点
此设置提供了一种安全且简单的方式来嵌入 Power BI 仪表板。对于生产,请考虑:
- 安全地存储敏感环境变量(例如,使用 Azure Key Vault)。
- 实现更好的错误处理和日志记录。
- 通过身份验证/授权保护 API 路由。
有关更多信息,我邀请您查看本文中我如何在现实场景中实现这一点。此外,您可以在此存储库中找到使用 Next.js 的实现,该实现适用于现代且可扩展的堆栈。
您可以根据您的项目需求随意定制此解决方案!
感谢您的阅读! ??
以上是嵌入 Power BI 仪表板:安全且简单的解决方案的详细内容。更多信息请关注PHP中文网其他相关文章!

Python更适合初学者,学习曲线平缓,语法简洁;JavaScript适合前端开发,学习曲线较陡,语法灵活。1.Python语法直观,适用于数据科学和后端开发。2.JavaScript灵活,广泛用于前端和服务器端编程。

Python和JavaScript在社区、库和资源方面的对比各有优劣。1)Python社区友好,适合初学者,但前端开发资源不如JavaScript丰富。2)Python在数据科学和机器学习库方面强大,JavaScript则在前端开发库和框架上更胜一筹。3)两者的学习资源都丰富,但Python适合从官方文档开始,JavaScript则以MDNWebDocs为佳。选择应基于项目需求和个人兴趣。

从C/C 转向JavaScript需要适应动态类型、垃圾回收和异步编程等特点。1)C/C 是静态类型语言,需手动管理内存,而JavaScript是动态类型,垃圾回收自动处理。2)C/C 需编译成机器码,JavaScript则为解释型语言。3)JavaScript引入闭包、原型链和Promise等概念,增强了灵活性和异步编程能力。

不同JavaScript引擎在解析和执行JavaScript代码时,效果会有所不同,因为每个引擎的实现原理和优化策略各有差异。1.词法分析:将源码转换为词法单元。2.语法分析:生成抽象语法树。3.优化和编译:通过JIT编译器生成机器码。4.执行:运行机器码。V8引擎通过即时编译和隐藏类优化,SpiderMonkey使用类型推断系统,导致在相同代码上的性能表现不同。

JavaScript在现实世界中的应用包括服务器端编程、移动应用开发和物联网控制:1.通过Node.js实现服务器端编程,适用于高并发请求处理。2.通过ReactNative进行移动应用开发,支持跨平台部署。3.通过Johnny-Five库用于物联网设备控制,适用于硬件交互。

我使用您的日常技术工具构建了功能性的多租户SaaS应用程序(一个Edtech应用程序),您可以做同样的事情。 首先,什么是多租户SaaS应用程序? 多租户SaaS应用程序可让您从唱歌中为多个客户提供服务

本文展示了与许可证确保的后端的前端集成,并使用Next.js构建功能性Edtech SaaS应用程序。 前端获取用户权限以控制UI的可见性并确保API要求遵守角色库

JavaScript是现代Web开发的核心语言,因其多样性和灵活性而广泛应用。1)前端开发:通过DOM操作和现代框架(如React、Vue.js、Angular)构建动态网页和单页面应用。2)服务器端开发:Node.js利用非阻塞I/O模型处理高并发和实时应用。3)移动和桌面应用开发:通过ReactNative和Electron实现跨平台开发,提高开发效率。


热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

Atom编辑器mac版下载
最流行的的开源编辑器

安全考试浏览器
Safe Exam Browser是一个安全的浏览器环境,用于安全地进行在线考试。该软件将任何计算机变成一个安全的工作站。它控制对任何实用工具的访问,并防止学生使用未经授权的资源。

禅工作室 13.0.1
功能强大的PHP集成开发环境

SublimeText3 英文版
推荐:为Win版本,支持代码提示!

记事本++7.3.1
好用且免费的代码编辑器