Overview
show you how easy it is to integrate Azure AD as an Authentication mechanism for your React Application
data:image/s3,"s3://crabby-images/5d33c/5d33c3595b08a274aa3edd58d0099b04534591b8" alt=""
Prerequisites
Create a AD User for testing purposes
App Registration
Search for App Registration in Azure, and create a new App Registration. Fill in the fields below. For this example we’ll leave the callback URL as localhost
STEP 1
data:image/s3,"s3://crabby-images/50adc/50adc4c7877ed4233f801e6257962e819af348e2" alt=""
STEP 2
data:image/s3,"s3://crabby-images/0d479/0d479058ff8cfcf26477ebab1107697cd2dbe849" alt=""
STEP 3
data:image/s3,"s3://crabby-images/027d6/027d6a14dac4587cd6c60a2303e2a1bb00ebfa28" alt=""
STEP 4
Take note of the Application (Client ID).
In the Authentication section, tick the ID Token checkbox
data:image/s3,"s3://crabby-images/c772b/c772b39316dc2f6f87747d2a96122366e32a12c3" alt=""
React App
Download and Install NodeJS. Open a command prompt or terminal and create a react application
npx create-react-app my-app
cd my-app
Install the AAD Microsoft Authentication Library for React
npm install react-aad-msal msal –save
Add the following authProvider.js file, replacing the placeholders for Client ID with the one we generated above
data:image/s3,"s3://crabby-images/f9b72/f9b72b5aebee1854ba7d37b0a550ff90caa017a6" alt=""
data:image/s3,"s3://crabby-images/0a43e/0a43ecea847216d363ca6ffc22305e971aca7153" alt=""
//my-app/src/authProvider.jsimport { MsalAuthProvider, LoginType } from 'react-aad-msal';
// Msal Configurations
const config = {
auth: {
authority: 'https://login.microsoftonline.com/common',
clientId: '<Client ID>',
redirectUri: 'http://localhost:3000/callback'
},
cache: {
cacheLocation: "localStorage",
storeAuthStateInCookie: true
}
};
// Authentication Parameters
const authenticationParameters = {
scopes: [
'user.read'
]
}
// Options
const options = {
loginType: LoginType.Popup,
tokenRefreshUri: window.location.origin + '/auth.html'
}
export const authProvider = new MsalAuthProvider(config, authenticationParameters, options)
Update index.js with the below. This will just prompt for authentication straight away when you navigate to your app
//my-app/src/index.jsimport React from 'react';
import ReactDOM from 'react-dom';
import { AzureAD } from 'react-aad-msal';
import App from './App';
import { authProvider } from './authProvider';
ReactDOM.render(
<AzureAD provider={authProvider} forceLogin={true}>
<App />
</AzureAD>,
document.getElementById('root'),
Update App.js with the below. We’re just adding an Auth section to the sample provided to display the username as well as the actual JWT token for this tutorial purposes
//my-app/src/App.jsimport logo from './logo.svg';
import './App.css';
import { authProvider } from './authProvider';
import { AzureAD, AuthenticationState } from 'react-aad-msal';function App() {
return (
<div className="App">
<AzureAD provider={authProvider}>
<span>Only authenticated users can see me.</span>
</AzureAD>
<AzureAD provider={authProvider} forceLogin={true}>
{
({login, logout, authenticationState, error, accountInfo}) => {
switch (authenticationState) {
case AuthenticationState.Authenticated:
return (
<p>
<span>Welcome, {accountInfo.account.userName}!</span>
<span>{accountInfo.jwtIdToken}</span>
<button onClick={logout}>Logout</button>
</p>
);
case AuthenticationState.Unauthenticated:
return (
<div>
{error && <p><span>An error occured during authentication, please try again!</span></p>}
<p>
<span>Hey stranger, you look new!</span>
<button onClick={login}>Login</button>
</p>
</div>
);
case AuthenticationState.InProgress:
return (<p>Authenticating...</p>);
}
}
}
</AzureAD>
<header className="App-header">
<img src={logo} className="App-logo" alt="logo" />
<p>
Edit <code>src/App.js</code> and save to reload.
</p>
<a
className="App-link"
href="https://reactjs.org"
target="_blank"
rel="noopener noreferrer"
>
Learn React
</a>
</header>
</div>
);
}export default App;
Run
npm start
data:image/s3,"s3://crabby-images/252ba/252ba254ecfd208746fec14490ec66396a5d9357" alt=""
data:image/s3,"s3://crabby-images/4c649/4c649bc791e182bcce7bf070d57e77b6f3ff66b2" alt=""
The ID token above can now be used as a bearer token when talking to a services backend. Here you can validate the ID token so you can then trust the claims in this token
data:image/s3,"s3://crabby-images/aadae/aadae749ade03e6b8ce15d0ed9b9d095b0cb2aa8" alt=""