


Intégration d'un tableau de bord Power BI : une solution sécurisée et simple
L'intégration de tableaux de bord Power BI dans une application Web constitue un moyen puissant de partager des informations en toute sécurité avec les utilisateurs. Dans ce tutoriel, je vais vous guider à travers les étapes pour mettre en place une solution de base utilisant Express pour le backend et React pour le frontend, tout en couvrant les configurations essentielles dans Azure et Power BI.
1. Configurations dans Azure
Pour intégrer des rapports Power BI, vous devez enregistrer une application dans Azure Active Directory :
-
Enregistrer une candidature :
- Accédez au portail Azure → Azure Active Directory → Inscriptions d'applications → Nouvelle inscription.
- Entrez un nom (par exemple, "PowerBIEmbedApp") et définissez l'URI de redirection sur l'URL de base de votre interface.
-
Autorisations API :
- Ajouter des autorisations pour le service Power BI (délégué et application).
- Accordez le consentement de l'administrateur pour les autorisations.
-
Secret client :
- Créez un nouveau secret client sous Certificats et secrets.
- Notez l'ID d'application (client), l'ID de répertoire (locataire) et le Secret client.
2. Configurations dans Power BI
-
Activer la génération de jetons intégrés :
- Connectez-vous au service Power BI → Portail d'administration → Paramètres du locataire.
- Activez « Autoriser les principaux de service à utiliser les API Power BI ».
-
Attribuer l'accès à l'espace de travail :
- Ajoutez le principal du service (application enregistrée) à l'espace de travail Power BI en tant qu'administrateur ou membre.
-
Obtenir les identifiants du tableau de bord/rapport :
- Notez l'espace de travail, le tableau de bord et les ID de rapport du contenu que vous souhaitez intégrer.
3. Backend : configuration express
Le backend est chargé de générer un jeton intégré pour le tableau de bord.
Installer les dépendances :
npm install express axios dotenv
Code back-end :
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. Frontend : configuration de React
Installer les dépendances :
npm install react powerbi-client axios
Code frontal :
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" /> ); }; export default Dashboard;
5. Étapes finales
- Exécutez le backend : node server.js.
- Exécutez le frontend : npm start (en supposant que Create React App ou une configuration similaire).
- Visitez votre application frontale pour voir le tableau de bord Power BI intégré.
Points à retenir
Cette configuration offre un moyen simple et sécurisé d’intégrer des tableaux de bord Power BI. Pour la production, pensez à :
- Stockage sécurisé des variables d'environnement sensibles (par exemple, à l'aide d'Azure Key Vault).
- Mise en œuvre d'une meilleure gestion et journalisation des erreurs.
- Sécurisation des routes API avec authentification/autorisation.
Pour plus d'informations, je vous invite à découvrir comment j'ai implémenté cela dans un scénario réel dans cet article. De plus, vous pouvez trouver l'implémentation en utilisant Next.js dans ce référentiel, adaptée à une pile moderne et évolutive.
N'hésitez pas à personnaliser cette solution en fonction des besoins de votre projet !
Merci d'avoir lu !! ??
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Outils d'IA chauds

Undresser.AI Undress
Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover
Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool
Images de déshabillage gratuites

Clothoff.io
Dissolvant de vêtements AI

Video Face Swap
Échangez les visages dans n'importe quelle vidéo sans effort grâce à notre outil d'échange de visage AI entièrement gratuit !

Article chaud

Outils chauds

Bloc-notes++7.3.1
Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

SublimeText3 version Mac
Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Sujets chauds

Des questions et des solutions fréquemment posées pour l'impression de billets thermiques frontaux pour le développement frontal, l'impression de billets est une exigence commune. Cependant, de nombreux développeurs mettent en œuvre ...

JavaScript est la pierre angulaire du développement Web moderne, et ses principales fonctions incluent la programmation axée sur les événements, la génération de contenu dynamique et la programmation asynchrone. 1) La programmation axée sur les événements permet aux pages Web de changer dynamiquement en fonction des opérations utilisateur. 2) La génération de contenu dynamique permet d'ajuster le contenu de la page en fonction des conditions. 3) La programmation asynchrone garantit que l'interface utilisateur n'est pas bloquée. JavaScript est largement utilisé dans l'interaction Web, les applications à une page et le développement côté serveur, améliorant considérablement la flexibilité de l'expérience utilisateur et du développement multiplateforme.

Il n'y a pas de salaire absolu pour les développeurs Python et JavaScript, selon les compétences et les besoins de l'industrie. 1. Python peut être davantage payé en science des données et en apprentissage automatique. 2. JavaScript a une grande demande dans le développement frontal et complet, et son salaire est également considérable. 3. Les facteurs d'influence comprennent l'expérience, la localisation géographique, la taille de l'entreprise et les compétences spécifiques.

La discussion sur la réalisation des effets de défilement de parallaxe et d'animation des éléments dans cet article explorera comment réaliser le site officiel de Shiseido (https://www.shiseido.co.jp/sb/wonderland/) ...

Apprendre JavaScript n'est pas difficile, mais c'est difficile. 1) Comprendre les concepts de base tels que les variables, les types de données, les fonctions, etc. 2) Master la programmation asynchrone et les implémenter via des boucles d'événements. 3) Utilisez les opérations DOM et promettez de gérer les demandes asynchrones. 4) Évitez les erreurs courantes et utilisez des techniques de débogage. 5) Optimiser les performances et suivre les meilleures pratiques.

Les dernières tendances de JavaScript incluent la montée en puissance de TypeScript, la popularité des frameworks et bibliothèques modernes et l'application de WebAssembly. Les prospects futurs couvrent des systèmes de type plus puissants, le développement du JavaScript côté serveur, l'expansion de l'intelligence artificielle et de l'apprentissage automatique, et le potentiel de l'informatique IoT et Edge.

Comment fusionner les éléments du tableau avec le même ID dans un seul objet en JavaScript? Lors du traitement des données, nous rencontrons souvent la nécessité d'avoir le même ID ...

Problèmes de mise à jour des données dans les opérations asynchrones de Zustand. Lorsque vous utilisez la bibliothèque de gestion de l'État de Zustand, vous rencontrez souvent le problème des mises à jour de données qui entraînent des opérations asynchrones prématurées. � ...
