I have created a Azure AD application and a Web App. The Azure AD Application uses AAD Authentication. This works well. When I go to my URL and I am not authenticated, I hav
What you can do is construct a sign out URI in your application and when the user clicks on the Logout
link or button, you redirect your users to that URI.
The format of a sign out URI is:
https://login.microsoftonline.com/{0}/oauth2/logout?post_logout_redirect_uri={1}
Where {0}
is the Tenant Id or the Azure AD name (something.onmicrosoft.com
) and {1}
is the link to your application where a user will be redirected back after the sign out process is complete at Azure AD end.
You could use the URI
https://login.microsoftonline.com/{0}/oauth2/logout?post_logout_redirect_uri={1}
as @Gaurav suggested. But this does not clear the browser cookies. You may have to explicitly delete the cookies from your Request Object:
foreach (string cookie in HttpContext.Current.Request.Cookies.AllKeys) { HttpContext.Current.Response.Cookies[cookie].Expires=DateTime.Now.AddDays(-1);}
But, there's also one issue with this that Azure AD caches the cookies for some time interval so any request sent using the same cookie from any other source could be authenticated successfully by Azure AD. I'm still trying to figure out how to tackle this.
Hope this helps. Thanks
I finally found why I couldn't get the provided example to work which I mentioned in my start post: the setting WEBSITE_AUTH_LOGOUT_PATH
is deprecated and you can now call /.auth/logout
to log out.
Found it on this page