Содержание
- «HTTP Status 401 — Authentication Failed: Error validating SAML Message» when You Use SSO
- Available Languages
- Download Options
- Bias-Free Language
- Contents
- Introduction
- Prerequisites
- Requirements
- Components Used
- Problem
- Solution
- Error: Unable to login using Idp Unable to validate SAML response
- Error Message
- Cause
- Solution or Workaround
- Related Information
- Common Issues with SAML Authentication
- Key terms
- Edit SAML configuration settings
- Errors and exceptions
- SAML Tracer
- Attribute not properly mapped
- Resolution
- Compatible data source not selected
- Resolution
- «Given URL is not well formed» error message
- Resolution
- IdP/SP Problem Scenarios
- Active Directory Federation Services (ADFS)
- «Resource not found» or «Sign on error!» warning
- Problem #1
- Problem #2
- Problem #3
- Problem #4
- Problem #5
- Problem #6
- Problem #7
- Federation Metadata
- Resolution
- Incorrect user lookup method
- Resolution
- Extra End SSO Session logout button
- Resolution
- Viewing application logs with event viewer
- Azure Active Directory
- Send first part of email
- Azure AD IdP updating certificate
- Resolution
- IdP-initiated single sign on
- Wrong document error
- Temporary resolution
- No option to add SAML to Provider Order
- Test SAML connection
- Create a SAML authentication provider and IdP for testing
- Blackboard Learn Service Provider
- Centrify Identity Provider
- Change text on End SSO Session logout page
- Redirect users to the IdP login page
«HTTP Status 401 — Authentication Failed: Error validating SAML Message» when You Use SSO
Available Languages
Download Options
Bias-Free Language
The documentation set for this product strives to use bias-free language. For the purposes of this documentation set, bias-free is defined as language that does not imply discrimination based on age, disability, gender, racial identity, ethnic identity, sexual orientation, socioeconomic status, and intersectionality. Exceptions may be present in the documentation due to language that is hardcoded in the user interfaces of the product software, language used based on RFP documentation, or language that is used by a referenced third-party product. Learn more about how Cisco is using Inclusive Language.
Contents
Introduction
This document describes an issue where you receive an «HTTP Status 401» error message after a period of inactivity when you use Single Sign-On (SSO).
Prerequisites
Requirements
Cisco recommends that you have knowledge of these topics:
- SSO
- Active Directory Federation Service (AD FS)
- CloudCenter
Components Used
This document is not restricted to specific software or hardware versions.
The information in this document was created from the devices in a specific lab environment. All of the devices used in this document started with a cleared (default) configuration. If your network is live, make sure that you understand the potential impact of any command.
Problem
When you use SSO, you can receive a «401» error after a period of inactivity, instead of a prompt to log in again as shown in the image.
The only way for you to be able to log in again is to close the entire web browser and reopen it.
Solution
This is caused by a mismatch in the timeout values between CloudCenter and the SSO server.
An enhancement allows the ForceAuthn Parameters support, which can allow a mismatch between the two values and CloudCenter to log out gracefully. This enhancement can be tracked here https://bst.cloudapps.cisco.com/bugsearch/bug/CSCvg36752.
The only workaround is to remove the mismatch. There are three locations where the timeout values need to match. The first two are on the CCM itself.
- Navigate to /usr/local/tomcat/webapps/ROOT/WEB-INF/web.xml.
- Modify the time_In_Minutes to reflect the timeout desired in minutes.
- Navigate to /usr/local/tomcat/webapps/ROOT/WEB-INF/mgmt.properties.
- Modify the saml.maxAuthenticationAge.seconds=timeout_in_seconds to reflect the timeout desired in seconds.
The third is on the SSO server and the location can vary which depends on what type of SSO server is running. The web SSO lifetime value must match the two values configured on CloudCenter.
Once all three match, when the timeout has occurred, you are dropped back to the log in screen before allowed to view the page.
Источник
Error: Unable to login using Idp Unable to validate SAML response
Error Message
The following error is returned when trying to access ArcGIS Online with configured enterprise logins:
Cause
The following are possible causes.
- Configured Shibboleth certificates do not match. This error can be prompted when the authentication signatures for the sender and receiver Shibboleth certificates do not match. A mismatch in certificates can occur when a new Identity Provider (IdP) is configured but is not updated with the appropriate Shibboleth certificate.
- Active Directory Federation Services (AD FS) certificate has changed or is expired. If the certificate is expired, ArcGIS Online is unable to connect to the Security Assertion Markup Language (SAML) on the IdP server to authenticate enterprise logins.
- Uploading the federation metadata file can return this error. This can be caused by a corrupt metadata file or if another application is using the metadata file.
- Loss of trust relationship between ArcGIS Online and the IdP, which must be re-linked.
Solution or Workaround
The following are possible solutions.
- Configure a working Shibboleth certificate. The following ArcGIS Online Help document explains this in detail: Configure Shibboleth.
- Update the X.509 certificate in ArcGIS Online. The following ArcGIS Online Help document explains this in detail: Set up enterprise logins.
- Update AD FS with a working federation metadata file. The following ArcGIS Online Help document explains this in detail: Configure Active Directory Federation Services.
Last Published: 8/2/2022
Article ID: 000012930
Software: ArcGIS Online Current
Download the Esri Support App on your phone to receive notifications when new content is available for Esri products you use
Download the Esri Support App on your phone to receive notifications when new content is available for Esri products you use
Источник
Common Issues with SAML Authentication
This page provides a general overview of the Security Assertion Markup Language (SAML) 2.0 Building Block along with common Single Sign-On (SSO) issues and troubleshooting techniques for the SAML authentication provider.
If for any reason an updated/new IdP metadata XML file is uploaded in the Blackboard Learn GUI on the SAML Authentication Settings page in the Identity Provider Settings section for a SAML authentication provider, the SAML B2 and that SAML authentication provider should also be toggled Inactive/Available, while having the SAML authentication provider in ‘Active’ status, to ensure any cached IdP metadata is cleared out and the updated IdP metadata is fully utilized.
Key terms
The following terms and abbreviations are used throughout this guide:
- SAML: Security Assertion Markup Language
- IdP: Identity Provider
- SP: Service Provider
- ADFS: Active Directory Federation Services
- GUI: Graphical User Interface. In the context of Blackboard Learn, this means working within the software.
Edit SAML configuration settings
To help troubleshoot SAML authentication issues, the SAML Building Block was updated in release 3200.2.0 to include these configuration settings and options:
- Define the SAML session age limit
- Choose a signature algorithm type
- Regenerate certificates
- Change the ResponseSkew value
Errors and exceptions
SAML related errors/exceptions are captured in the following logs:
- /usr/local/blackboard/logs/bb-services-log.txt
- /usr/local/blackboard/logs/tomcat/stdout-stderr- .log
- /usr/local/blackboard/logs/tomcat/catalina-log.txt
These logs should always be searched when investigating a reported SAML authentication issue.
SAML Tracer
With SAML 2.0 authentication troubleshooting iterations, at some point it may be necessary to confirm/view the attributes that are actually being released from the IdP and sent to Learn during the authentication process. If the attributes from the IdP are NOT encrypted in the SAML response, the Firefox browser SAML tracer Add-on or Chrome SAML Message Decoder can be used to view the attributes.
Attribute not properly mapped
If the attribute containing the userName is not properly mapped as specified in the Remote User ID field in the Map SAML Attributes section on the SAML Authentication Settings page in the Blackboard Learn GUI, the following event will be logged in the bb-services log when attempting to login to Blackboard Learn via SAML authentication:
2016-06-28 12:48:12 -0400 — userName is null or empty
A similar Sign On Error! message displayed in the browser: Blackboard Learn is currently unable to log into your account using single-sign on. Contact your administrator for assistance.
An Authentication Failure entry appears in the bb-services log:
2016-06-28 12:48:12 -0400 — BbSAMLExceptionHandleFilter — javax.servlet.ServletException: Authentication Failure
at blackboard.auth.provider.saml.customization.handler.BbAuthenticationSuccessHandler.checkAuthenticationResult(BbAuthenticationSuccessHandler.java:81)
at blackboard.auth.provider.saml.customization.handler.BbAuthenticationSuccessHandler.onAuthenticationSuccess(BbAuthenticationSuccessHandler.java:57)
at org.springframework.security.web.authentication.AbstractAuthenticationProcessingFilter.successfulAuthentication(AbstractAuthenticationProcessingFilter.java:331)
at org.springframework.security.web.authentication.AbstractAuthenticationProcessingFilter.doFilter(AbstractAuthenticationProcessingFilter.java:245)
at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:330)
at org.springframework.security.web.FilterChainProxy.doFilterInternal(FilterChainProxy.java:213)
at org.springframework.security.web.FilterChainProxy.doFilter(FilterChainProxy.java:184)
at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:330)
at org.springframework.security.web.header.HeaderWriterFilter.doFilterInternal(HeaderWriterFilter.java:64) at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:107)
at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:330)
at org.springframework.security.web.context.request.async.WebAsyncManagerIntegrationFilter.doFilterInternal(WebAsyncManagerIntegrationFilter.java:53) at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:107)
at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:330)
at org.springframework.security.web.context.SecurityContextPersistenceFilter.doFilter(SecurityContextPersistenceFilter.java:91)
at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:330)
at org.springframework.security.web.FilterChainProxy.doFilterInternal(FilterChainProxy.java:213)
at org.springframework.security.web.FilterChainProxy.doFilter(FilterChainProxy.java:176)
at org.springframework.web.filter.DelegatingFilterProxy.invokeDelegate(DelegatingFilterProxy.java:346)
at org.springframework.web.filter.DelegatingFilterProxy.doFilter(DelegatingFilterProxy.java:262)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
at java.lang.reflect.Method.invoke(Method.java:497)
[SNIP]
Resolution
You have two options to resolve the issue. First, select the Create accounts if they don’t exist in the system option on the SAML Authentication Settings page in the Blackboard Learn GUI. Alternatively, you can attempt to view the value of the attributes released by the IdP via SAML tracer or Debug Logging if the attributes are NOT encrypted:
www.w3. org/2001/XMLSchema»
xmlns:xsi=»http ://www.w3. org/2001/XMLSchema-instance»
xsi:type=»xs:anyType»
>bbuser_saml2 @bbchjones. net
and map the Attribute Name that has the desired AttributeValue to the Remote User ID on the SAML Authentication Settings page in the Blackboard Learn GUI.
Compatible data source not selected
Users won’t be able to login to Blackboard Learn via SAML authentication if the Data Source for the users is not selected in the Services Provider Settings > Compatible Data Sources section on the SAML Authentication Settings page in the Blackboard Learn GUI. The following event will be logged in the bb-services log when attempting to log in to Blackboard Learn via SAML authentication:
2016-09-23 12:33:13 -0500 — userName is null or empty
The Sign On Error! message appears in the browser, as well as the Authentication Failure in the bb-services log:
2016-09-23 12:33:13 -0500 — BbSAMLExceptionHandleFilter — javax.servlet.ServletException: Authentication Failure
at blackboard.auth.provider.saml.customization.handler.BbAuthenticationSuccessHandler.checkAuthenticationResult(BbAuthenticationSuccessHandler.java:82)
at blackboard.auth.provider.saml.customization.handler.BbAuthenticationSuccessHandler.onAuthenticationSuccess(BbAuthenticationSuccessHandler.java:58)
at org.springframework.security.web.authentication.AbstractAuthenticationProcessingFilter.successfulAuthentication(AbstractAuthenticationProcessingFilter.java:331)
at org.springframework.security.web.authentication.AbstractAuthenticationProcessingFilter.doFilter(AbstractAuthenticationProcessingFilter.java:245)
at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:330)
at org.springframework.security.web.FilterChainProxy.doFilterInternal(FilterChainProxy.java:213)
at org.springframework.security.web.FilterChainProxy.doFilter(FilterChainProxy.java:184)
at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:330)
at org.springframework.security.web.header.HeaderWriterFilter.doFilterInternal(HeaderWriterFilter.java:64)
at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:107)
at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:330)
at org.springframework.security.web.context.request.async.WebAsyncManagerIntegrationFilter.doFilterInternal(WebAsyncManagerIntegrationFilter.java:53)
at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:107)
at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:330)
at org.springframework.security.web.context.SecurityContextPersistenceFilter.doFilter (SecurityContextPersistenceFilter.java:91)
at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:330)
at org.springframework.security.web.FilterChainProxy.doFilterInternal(FilterChainProxy.java:213)
at org.springframework.security.web.FilterChainProxy.doFilter(FilterChainProxy.java:176)
at org.springframework.web.filter.DelegatingFilterProxy.invokeDelegate(DelegatingFilterProxy.java:346)
at org.springframework.web.filter.DelegatingFilterProxy.doFilter(DelegatingFilterProxy.java:262)
at sun.reflect.GeneratedMethodAccessor3399.invoke(Unknown Source)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
at java.lang.reflect.Method.invoke(Method.java:498)
[SNIP]
Resolution
- Obtain the username of a user that is unable to login.
- In the Blackboard Learn GUI, navigate to System Admin > Users and search for the user.
- Copy the Data Source Key of the user.
- Navigate to System Admin > Authentication > «Provider Name» > SAML Settings > Compatible Data Sources.
- Place a check mark next to that Data Source in the Name column and select Submit .
«Given URL is not well formed» error message
If OneLogin is configured as the IdP for the SAML authentication provider in Blackboard Learn, a Given URL is not well formed error may be displayed on the page after entering the OneLogin credentials when attempting login to Blackboard Learn.
With the following displayed in the bb-services-log:
2016-09-16 09:43:40 -0400 — Given URL is not well formed
For reference, the Error ID is 17500f44-7809-4b9f-a272-3bed1d1af131. — java.lang.IllegalArgumentException: Given URL is not well formed
at org.opensaml.util.URLBuilder. (URLBuilder.java:120)
at org.opensaml.util.SimpleURLCanonicalizer.canonicalize(SimpleURLCanonicalizer.java:87)
at org.opensaml.common.binding.decoding.BasicURLComparator.compare(BasicURLComparator.java:57)
at org.opensaml.common.binding.decoding.BaseSAMLMessageDecoder.compareEndpointURIs(BaseSAMLMessageDecoder.java:173)
at org.opensaml.common.binding.decoding.BaseSAMLMessageDecoder.checkEndpointURI(BaseSAMLMessageDecoder.java:213)
at org.opensaml.saml2.binding.decoding.BaseSAML2MessageDecoder.decode(BaseSAML2MessageDecoder.java:72)
at org.springframework.security.saml.processor.SAMLProcessorImpl.retrieveMessage(SAMLProcessorImpl.java:105)
at org.springframework.security.saml.processor.SAMLProcessorImpl.retrieveMessage(SAMLProcessorImpl.java:172)
at org.springframework.security.saml.SAMLProcessingFilter.attemptAuthentication(SAMLProcessingFilter.java:80)
at org.springframework.security.web.authentication.AbstractAuthenticationProcessingFilter.doFilter(AbstractAuthenticationProcessingFilter.java:217)
at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:330)
at org.springframework.security.web.FilterChainProxy.doFilterInternal(FilterChainProxy.java:213)
at org.springframework.security.web.FilterChainProxy.doFilter(FilterChainProxy.java:184)
at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:330)
at org.springframework.security.web.header.HeaderWriterFilter.doFilterInternal(HeaderWriterFilter.java:64)
[SNIP]
at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:617)
at org.apache.tomcat.util.threads.TaskThread$WrappingRunnable.run(TaskThread.java:61)
at java.lang.Thread.run(Thread.java:745)
Caused by: java.net.MalformedURLException: no protocol:
at java.net.URL. (URL.java:593)
at java.net.URL. (URL.java:490)
at java.net.URL. (URL.java:439)
at org.opensaml.util.URLBuilder. (URLBuilder.java:77)
. 203 more
Resolution
- Turn on the Firefox browser SAML tracer and replicate the login issue.
- Review the beginning of the SAML POST event:
https ://app.onelogin. com/saml/metadata/123456
[SNIP]
IdP/SP Problem Scenarios
- If an error appears before you are redirected to the IdP’s login page, the IdP’s metadata may be invalid.
- If an error appears after you log in on the IdP’s page, the reasons could be that:
- Attribute mapping between the SP and IdP is incorrect, or the IdP didn’t return a valid Remote User ID.
- The SAML response from the IdP wasn’t validated by the SP. This could be caused by:
- The IdP signs the SAML response with a certificate that is not issued by a valid certificate authority, and the SP’s keystore doesn’t contain this certificate.
- The SP’s system clock is incorrect.
Active Directory Federation Services (ADFS)
The attribute names are case sensitive in the Map SAML Attributes section on the SAML Authentication Settings page in the Blackboard Learn GUI. So if the Remote User ID has sAMAccountName for the Attribute Name on the settings page and the actual SAML POST from the IdP has this for the Attribute Name in the AttributeStatement :
The user will not be able to login. The Remote User ID attribute name value on the SAML Authentication Settings page would need to be changed from sAMAccountName to SamAccountName .
«Resource not found» or «Sign on error!» warning
This section contains some of the common problems that may prevent a user from logging into Learn via SAML authentication with ADFS when The specified resource was not found, or you do not have permission to access it or Sign On Error! message is displayed in the Blackboard Learn GUI.
Problem #1
After entering the login credentials on the ADFS login page, an error may be displayed after being redirected to the Blackboard Learn GUI: The specified resource was not found, or you do not have permission to access it.
With a corresponding message in the stdout-stderr log:
INFO | jvm 1 | 2016/06/22 06:08:33 | — No mapping found for HTTP request with URI [/auth-saml/saml/SSO] in DispatcherServlet with name ‘saml’
The problem occurs because the noHandlerFound() method is used in the DispatcherServlet.java code and is unable to locate/map the HTTP SSO request.
/**
* No handler found -> set appropriate HTTP response status.
* @param request current HTTP request
* @param response current HTTP response
* @throws Exception if preparing the response failed
*/
protected void noHandlerFound(HttpServletRequest request, HttpServletResponse response) throws Exception <
if (pageNotFoundLogger.isWarnEnabled()) <
pageNotFoundLogger.warn(«No mapping found for HTTP request with URI [» + getRequestUri(request) +
«] in DispatcherServlet with name ‘» + getServletName() + «‘»);
>
if (this.throwExceptionIfNoHandlerFound) <
throw new NoHandlerFoundException(request.getMethod(), getRequestUri(request),
new ServletServerHttpRequest(request).getHeaders());
>
else <
response.sendError(HttpServletResponse.SC_NOT_FOUND);
>
>
Resolution
This typically occurs because the Entity ID for the SP configured in the Blackboard Learn GUI is incorrect. This can be resolved by navigating to System Admin > Authentication > SAML Authentication Settings > Service Provider Settings and updating the Entity ID . For ADFS, the default configuration for the Entity ID would be https://[Learn Server Hostname]/auth-saml/saml/SSO .
If a school changes their URL from the default https ://school.blackboard. com to https ://their.school. edu, the Entity ID in the Blackboard Learn GUI on the SAML Authentication Settings page should be updated to https ://their.school .edu/auth-saml/saml/SSO.
Problem #2
After entering the login credentials on the ADFS login page, an error may be displayed after being redirected to the Blackboard Learn GUI: The specified resource was not found, or you do not have permission to access it.
With this corresponding message in the stdout-stderr log:
INFO | jvm 1 | 2016/06/22 06:08:33 | — No mapping found for HTTP request with URI [/auth-saml/saml/SSO] in DispatcherServlet with name ‘saml’
And this message in the catalina log:
ERROR 2016-06-27 10:47:03,664 connector-6: userId=_2_1, sessionId=62536416FB80462298C92064A7022E50 org.opensaml.xml.encryption.Decrypter — Error decrypting the encrypted data element
org.apache.xml.security.encryption.XMLEncryptionException: Illegal key size
Original Exception was java.security.InvalidKeyException: Illegal key size
at org.apache.xml.security.encryption.XMLCipher.decryptToByteArray(XMLCipher.java:1822)
at org.opensaml.xml.encryption.Decrypter.decryptDataToDOM(Decrypter.java:596)
at org.opensaml.xml.encryption.Decrypter.decryptUsingResolvedEncryptedKey(Decrypter.java:795)
at org.opensaml.xml.encryption.Decrypter.decryptDataToDOM(Decrypter.java:535)
at org.opensaml.xml.encryption.Decrypter.decryptDataToList(Decrypter.java:453)
at org.opensaml.xml.encryption.Decrypter.decryptData(Decrypter.java:414)
at org.opensaml.saml2.encryption.Decrypter.decryptData(Decrypter.java:141)
at org.opensaml.saml2.encryption.Decrypter.decrypt(Decrypter.java:69)
at org.springframework.security.saml.websso.WebSSOProfileConsumerImpl.processAuthenticationResponse(WebSSOProfileConsumerImpl.java:199)
at org.springframework.security.saml.SAMLAuthenticationProvider.authenticate(SAMLAuthenticationProvider.java:82)
at org.springframework.security.authentication.ProviderManager.authenticate(ProviderManager.java:167)
[SNIP]
at org.apache.tomcat.util.threads.TaskThread$WrappingRunnable.run(TaskThread.java:61)
at java.lang.Thread.run(Thread.java:745)
Caused by: java.security.InvalidKeyException: Illegal key size
at javax.crypto.Cipher.checkCryptoPerm(Cipher.java:1039)
at javax.crypto.Cipher.init(Cipher.java:1393)
at javax.crypto.Cipher.init(Cipher.java:1327)
at org.apache.xml.security.encryption.XMLCipher.decryptToByteArray(XMLCipher.java:1820)
. 205 more
And this message displayed in the bb-services log:
2016-06-27 10:47:03 -0400 — unsuccessfulAuthentication — org.springframework.security.authentication.AuthenticationServiceException: Error validating SAML message
at org.springframework.security.saml.SAMLAuthenticationProvider.authenticate(SAMLAuthenticationProvider.java:100)
at org.springframework.security.authentication.ProviderManager.authenticate(ProviderManager.java:167)
at org.springframework.security.saml.SAMLProcessingFilter.attemptAuthentication(SAMLProcessingFilter.java:87)
at org.springframework.security.web.authentication.AbstractAuthenticationProcessingFilter.doFilter(AbstractAuthenticationProcessingFilter.java:217)
at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:330)
at org.springframework.security.web.FilterChainProxy.doFilterInternal(FilterChainProxy.java:213)
at org.springframework.security.web.FilterChainProxy.doFilter(FilterChainProxy.java:184)
at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:330)
at org.springframework.security.web.header.HeaderWriterFilter.doFilterInternal(HeaderWriterFilter.java:64)
at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:107)
at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:330)
at org.springframework.security.web.context.request.async.WebAsyncManagerIntegrationFilter.doFilterInternal(WebAsyncManagerIntegrationFilter.java:53)
at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:107)
at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:330)
at org.springframework.security.web.context.SecurityContextPersistenceFilter.doFilter(SecurityContextPersistenceFilter.java:91)
at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:330)
at org.springframework.security.web.FilterChainProxy.doFilterInternal(FilterChainProxy.java:213)
at org.springframework.security.web.FilterChainProxy.doFilter(FilterChainProxy.java:176)
at org.springframework.web.filter.DelegatingFilterProxy.invokeDelegate(DelegatingFilterProxy.java:346)
at org.springframework.web.filter.DelegatingFilterProxy.doFilter(DelegatingFilterProxy.java:262)
at sun.reflect.GeneratedMethodAccessor3422.invoke(Unknown Source)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
at java.lang.reflect.Method.invoke(Method.java:498)
at org.apache.catalina.security.SecurityUtil$1.run(SecurityUtil.java:277)
at org.apache.catalina.security.SecurityUtil$1.run(SecurityUtil.java:274)
at java.security.AccessController.doPrivileged(Native Method)
at javax.security.auth.Subject.doAsPrivileged(Subject.java:549)
at org.apache.catalina.security.SecurityUtil.execute(SecurityUtil.java:309)
at org.apache.catalina.security.SecurityUtil.doAsPrivilege(SecurityUtil.java:249)
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:237)
at org.apache.catalina.core.ApplicationFilterChain.access$000(ApplicationFilterChain.java:55)
at org.apache.catalina.core.ApplicationFilterChain$1.run(ApplicationFilterChain.java:191)
at org.apache.catalina.core.ApplicationFilterChain$1.run(ApplicationFilterChain.java:187)
at java.security.AccessController.doPrivileged(Native Method)
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:186)
at blackboard.auth.provider.saml.customization.filter.BbSAMLExceptionHandleFilter.doFilterInternal(BbSAMLExceptionHandleFilter.java:30)
at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:107)
at sun.reflect.GeneratedMethodAccessor3421.invoke(Unknown Source)
[SNIP]
at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:617)
at org.apache.tomcat.util.threads.TaskThread$WrappingRunnable.run(TaskThread.java:61)
at java.lang.Thread.run(Thread.java:745)
Caused by: org.opensaml.common.SAMLException: Response doesn’t have any valid assertion which would pass subject validation
at org.springframework.security.saml.websso.WebSSOProfileConsumerImpl.processAuthenticationResponse(WebSSOProfileConsumerImpl.java:229)
at org.springframework.security.saml.SAMLAuthenticationProvider.authenticate(SAMLAuthenticationProvider.java:87)
. 229 more
The problem occurs because by default ADFS encrypts the attributes it sends using AES-256 and the Java runtime used by Blackboard Learn doesn’t support AES-256 out of the box.
Resolution
A universal resolution option is to open a PowerShell on the ADFS server and set the relying party created for Blackboard Learn to send the attributes as unencrypted. As the whole communication is over SSL, this will not reduce the security of the authentication. It also makes debugging of any issues easier as the attributes can be viewed using debugging tools such as the Firefox browser SAML tracer Add-on and a restart of the Blackboard Learn system is not required. To set the relying party created for Blackboard Learn to send the attributes as unencrypted, open a PowerShell and execute the following command, replacing TargetName with the name of the Relying Party Trust that is in the ADFS Management Console under Trust Relationships > Relying Party Trusts .
set-ADFSRelyingPartyTrust –TargetName «yourlearnserver.blackboard.com» –EncryptClaims $False
After this change the ADFS service will need to be restarted with the command: Restart-Service ADFSSRV
Problem #3
After entering the login credentials on the ADFS login page, an error may be displayed after being redirected to the Blackboard Learn GUI: The specified resource was not found, or you do not have permission to access it or Sign On Error!
With either, these similar corresponding SAML related events appear in the stdout-stderr log:
INFO | jvm 1 | 2016/09/06 20:33:04 | — /saml/login?apId=_107_1&redirectUrl=https%3A%2F%2Fbb.fraser.misd.net%2Fwebapps%2Fportal%2Fexecute%2FdefaultTab at position 1 of 10 in additional filter chain; firing Filter: ‘SecurityContextPersistenceFilter’
INFO | jvm 1 | 2016/09/06 20:33:04 | — No HttpSession currently exists
INFO | jvm 1 | 2016/09/06 20:33:04 | — No SecurityContext was available from the HttpSession: null. A new one will be created.
INFO | jvm 1 | 2016/09/06 20:33:04 | — /saml/login?apId=_107_1&redirectUrl=https%3A%2F%2Fbb.fraser.misd.net%2Fwebapps%2Fportal%2Fexecute%2FdefaultTab at position 2 of 10 in additional filter chain; firing Filter: ‘WebAsyncManagerIntegrationFilter’
INFO | jvm 1 | 2016/09/06 20:33:04 | — /saml/login?apId=_107_1&redirectUrl=https%3A%2F%2Fbb.fraser.misd.net%2Fwebapps%2Fportal%2Fexecute%2FdefaultTab at position 3 of 10 in additional filter chain; firing Filter: ‘HeaderWriterFilter’
INFO | jvm 1 | 2016/09/06 20:33:04 | — /saml/login?apId=_107_1&redirectUrl=https%3A%2F%2Fbb.fraser.misd.net%2Fwebapps%2Fportal%2Fexecute%2FdefaultTab at position 4 of 10 in additional filter chain; firing Filter: ‘FilterChainProxy’
INFO | jvm 1 | 2016/09/06 20:33:04 | — Checking match of request : ‘/saml/login’; against ‘/saml/login/**’
INFO | jvm 1 | 2016/09/06 20:33:04 | — /saml/login?apId=_107_1&redirectUrl=https%3A%2F%2Fbb.fraser.misd.net%2Fwebapps%2Fportal%2Fexecute%2FdefaultTab at position 1 of 1 in additional filter chain; firing Filter: ‘SAMLEntryPoint’
INFO | jvm 1 | 2016/09/06 20:33:04 | — Request for URI http ://www.w3. org/2000/09/xmldsig#rsa-sha1
INFO | jvm 1 | 2016/09/06 20:33:04 | — Request for URI http ://www.w3. org/2000/09/xmldsig#rsa-sha1
INFO | jvm 1 | 2016/09/06 20:33:04 | — SecurityContext is empty or contents are anonymous — context will not be stored in HttpSession.
INFO | jvm 1 | 2016/09/06 20:33:04 | — SecurityContextHolder now cleared, as request processing completed
INFO | jvm 1 | 2016/09/06 20:33:07 | — /saml/SSO at position 1 of 10 in additional filter chain; firing Filter: ‘SecurityContextPersistenceFilter’
INFO | jvm 1 | 2016/09/06 20:33:07 | — HttpSession returned null object for SPRING_SECURITY_CONTEXT
INFO | jvm 1 | 2016/09/06 20:33:07 | — No SecurityContext was available from the HttpSession: [email protected] A new one will be created.
INFO | jvm 1 | 2016/09/06 20:33:07 | — /saml/SSO at position 2 of 10 in additional filter chain; firing Filter: ‘WebAsyncManagerIntegrationFilter’
INFO | jvm 1 | 2016/09/06 20:33:07 | — /saml/SSO at position 3 of 10 in additional filter chain; firing Filter: ‘HeaderWriterFilter’
INFO | jvm 1 | 2016/09/06 20:33:07 | — /saml/SSO at position 4 of 10 in additional filter chain; firing Filter: ‘FilterChainProxy’
INFO | jvm 1 | 2016/09/06 20:33:07 | — Checking match of request : ‘/saml/sso’; against ‘/saml/login/**’
INFO | jvm 1 | 2016/09/06 20:33:07 | — Checking match of request : ‘/saml/sso’; against ‘/saml/logout/**’
INFO | jvm 1 | 2016/09/06 20:33:07 | — Checking match of request : ‘/saml/sso’; against ‘/saml/bbsamllogout/**’
INFO | jvm 1 | 2016/09/06 20:33:07 | — Checking match of request : ‘/saml/sso’; against ‘/saml/sso/**’
INFO | jvm 1 | 2016/09/06 20:33:07 | — /saml/SSO at position 1 of 1 in additional filter chain; firing Filter: ‘SAMLProcessingFilter’
INFO | jvm 1 | 2016/09/06 20:33:07 | — Authentication attempt using org.springframework.security.saml.SAMLAuthenticationProvider
INFO | jvm 1 | 2016/09/06 20:33:07 | — Forwarding to /
INFO | jvm 1 | 2016/09/06 20:33:07 | — DispatcherServlet with name ‘saml’ processing POST request for [/auth-saml/saml/SSO]
INFO | jvm 1 | 2016/09/06 20:33:07 | — No mapping found for HTTP request with URI [/auth-saml/saml/SSO] in DispatcherServlet with name ‘saml’
INFO | jvm 1 | 2016/09/06 20:33:07 | — SecurityContext is empty or contents are anonymous — context will not be stored in HttpSession.
INFO | jvm 1 | 2016/09/06 20:33:07 | — Successfully completed request
INFO | jvm 1 | 2016/09/06 20:33:07 | — Skip invoking on
INFO | jvm 1 | 2016/09/06 20:33:07 | — SecurityContextHolder now cleared, as request processing completed
Or these similar SAML exceptions in the bb-services log:
2016-11-29 09:04:24 -0500 — unsuccessfulAuthentication — org.springframework.security.authentication.AuthenticationServiceException: Error validating SAML message
at org.springframework.security.saml.SAMLAuthenticationProvider.authenticate(SAMLAuthenticationProvider.java:100)
at org.springframework.security.authentication.ProviderManager.authenticate(ProviderManager.java:167)
at org.springframework.security.saml.SAMLProcessingFilter.attemptAuthentication(SAMLProcessingFilter.java:87)
at org.springframework.security.web.authentication.AbstractAuthenticationProcessingFilter.doFilter(AbstractAuthenticationProcessingFilter.java:217)
at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:330)
at org.springframework.security.web.FilterChainProxy.doFilterInternal(FilterChainProxy.java:213)
at org.springframework.security.web.FilterChainProxy.doFilter(FilterChainProxy.java:184)
at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:330)
at org.springframework.security.web.header.HeaderWriterFilter.doFilterInternal(HeaderWriterFilter.java:64)
at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:107)
at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:330)
at org.springframework.security.web.context.request.async.WebAsyncManagerIntegrationFilter.doFilterInternal(WebAsyncManagerIntegrationFilter.java:53)
at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:107)
at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:330)
at org.springframework.security.web.context.SecurityContextPersistenceFilter.doFilter(SecurityContextPersistenceFilter.java:91)
at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:330)
at org.springframework.security.web.FilterChainProxy.doFilterInternal(FilterChainProxy.java:213)
at org.springframework.security.web.FilterChainProxy.doFilter(FilterChainProxy.java:176)
at org.springframework.web.filter.DelegatingFilterProxy.invokeDelegate(DelegatingFilterProxy.java:346)
at org.springframework.web.filter.DelegatingFilterProxy.doFilter(DelegatingFilterProxy.java:262)
at sun.reflect.GeneratedMethodAccessor853.invoke(Unknown Source)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
at java.lang.reflect.Method.invoke(Method.java:498)
at org.apache.catalina.security.SecurityUtil$1.run(SecurityUtil.java:282)
at org.apache.catalina.security.SecurityUtil$1.run(SecurityUtil.java:279)
at java.security.AccessController.doPrivileged(Native Method)
at javax.security.auth.Subject.doAsPrivileged(Subject.java:549)
at org.apache.catalina.security.SecurityUtil.execute(SecurityUtil.java:314)
at org.apache.catalina.security.SecurityUtil.doAsPrivilege(SecurityUtil.java:253)
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:190)
at org.apache.catalina.core.ApplicationFilterChain.access$000(ApplicationFilterChain.java:46)
at org.apache.catalina.core.ApplicationFilterChain$1.run(ApplicationFilterChain.java:148)
at org.apache.catalina.core.ApplicationFilterChain$1.run(ApplicationFilterChain.java:144)
at java.security.AccessController.doPrivileged(Native Method)
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:143)
at blackboard.auth.provider.saml.customization.filter.BbSAMLExceptionHandleFilter.doFilterInternal(BbSAMLExceptionHandleFilter.java:30)
at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:107)
at sun.reflect.GeneratedMethodAccessor853.invoke(Unknown Source)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
[SNIP]
at org.apache.catalina.valves.RemoteIpValve.invoke(RemoteIpValve.java:677)
at blackboard.tomcat.valves.LoggingRemoteIpValve.invoke(LoggingRemoteIpValve.java:44)
at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:87)
at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:349)
at org.apache.coyote.http11.Http11Processor.service(Http11Processor.java:1110)
at org.apache.coyote.AbstractProcessorLight.process(AbstractProcessorLight.java:66)
at org.apache.coyote.AbstractProtocol$ConnectionHandler.process(AbstractProtocol.java:785)
at org.apache.tomcat.util.net.NioEndpoint$SocketProcessor.doRun(NioEndpoint.java:1425)
at org.apache.tomcat.util.net.SocketProcessorBase.run(SocketProcessorBase.java:49)
at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1142)
at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:617)
at org.apache.tomcat.util.threads.TaskThread$WrappingRunnable.run(TaskThread.java:61)
at java.lang.Thread.run(Thread.java:745)
Caused by: org.opensaml.common.SAMLException: Response issue time is either too old or with date in the future, skew 60, time 2016-11-29T14:03:16.634Z
at org.springframework.security.saml.websso.WebSSOProfileConsumerImpl.processAuthenticationResponse(WebSSOProfileConsumerImpl.java:126)
at blackboard.auth.provider.saml.customization.consumer.BbSAMLWebSSOProfileConsumerImpl.processAuthenticationResponse(BbSAMLWebSSOProfileConsumerImpl.java:40)
at org.springframework.security.saml.SAMLAuthenticationProvider.authenticate(SAMLAuthenticationProvider.java:87)
. 230 more
The problem occurs when the ADFS server and the Blackboard Learn application server have a time drift close to or beyond the default of 60 seconds.
Resolution
There are two options to resolve the issue:
- Manually syncing the clocks of the Blackboard Learn application servers and the ADFS server. For Blackboard Learn, the current time and time zone of the server can be viewed in a web browser by adding /webapps/portal/healthCheck to the end of a Blackboard Learn URL.
Example: https ://mhtest1.blackboard .com//webapps/portal/healthCheck
Hostname: ip-10-145-49-11.ec2.internal
Status: Active — Database connectivity established
Running since: Sat, Dec 3, 2016 — 05:39:11 PM EST
Time of request: Thu, Dec 8, 2016 — 05:12:43 PM EST
An institution may use the above URL to compare the Blackboard Learn system time zone and clock with that of their ADFS server and then adjust those items as necessary on the ADFS server so that they are in-sync with the Blackboard Learn site.
Problem #4
After entering the login credentials on the ADFS login page, an error may be displayed after being redirected to the Blackboard Learn GUI: The specified resource was not found, or you do not have permission to access it or Sign On Error!
With the following exceptions in the bb-services log:
2016-11-01 12:47:19 -0500 — unsuccessfulAuthentication — org.springframework.security.authentication.AuthenticationServiceException: Error validating SAML message
at org.springframework.security.saml.SAMLAuthenticationProvider.authenticate(SAMLAuthenticationProvider.java:100)
at org.springframework.security.authentication.ProviderManager.authenticate(ProviderManager.java:167)
at org.springframework.security.saml.SAMLProcessingFilter.attemptAuthentication(SAMLProcessingFilter.java:87)
at org.springframework.security.web.authentication.AbstractAuthenticationProcessingFilter.doFilter(AbstractAuthenticationProcessingFilter.java:217)
at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:330)
at org.springframework.security.web.FilterChainProxy.doFilterInternal(FilterChainProxy.java:213)
at org.springframework.security.web.FilterChainProxy.doFilter(FilterChainProxy.java:184)
at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:330)
at org.springframework.security.web.header.HeaderWriterFilter.doFilterInternal(HeaderWriterFilter.java:64)
at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:107)
at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:330)
at org.springframework.security.web.context.request.async.WebAsyncManagerIntegrationFilter.doFilterInternal(WebAsyncManagerIntegrationFilter.java:53)
at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:107)
at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:330)
at org.springframework.security.web.context.SecurityContextPersistenceFilter.doFilter(SecurityContextPersistenceFilter.java:91)
at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:330)
at org.springframework.security.web.FilterChainProxy.doFilterInternal(FilterChainProxy.java:213)
at org.springframework.security.web.FilterChainProxy.doFilter(FilterChainProxy.java:176)
at org.springframework.web.filter.DelegatingFilterProxy.invokeDelegate(DelegatingFilterProxy.java:346)
at org.springframework.web.filter.DelegatingFilterProxy.doFilter(DelegatingFilterProxy.java:262)
at sun.reflect.GeneratedMethodAccessor929.invoke(Unknown Source)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
at java.lang.reflect.Method.invoke(Method.java:498)
at org.apache.catalina.security.SecurityUtil$1.run(SecurityUtil.java:282)
at org.apache.catalina.security.SecurityUtil$1.run(SecurityUtil.java:279)
at java.security.AccessController.doPrivileged(Native Method)
at javax.security.auth.Subject.doAsPrivileged(Subject.java:549)
at org.apache.catalina.security.SecurityUtil.execute(SecurityUtil.java:314)
at org.apache.catalina.security.SecurityUtil.doAsPrivilege(SecurityUtil.java:253)
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:190)
at org.apache.catalina.core.ApplicationFilterChain.access$000(ApplicationFilterChain.java:46)
at org.apache.catalina.core.ApplicationFilterChain$1.run(ApplicationFilterChain.java:148)
at org.apache.catalina.core.ApplicationFilterChain$1.run(ApplicationFilterChain.java:144)
at java.security.AccessController.doPrivileged(Native Method)
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:143)
at blackboard.auth.provider.saml.customization.filter.BbSAMLExceptionHandleFilter.doFilterInternal(BbSAMLExceptionHandleFilter.java:30)
at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:107)
[SNIP]
at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:617)
at org.apache.tomcat.util.threads.TaskThread$WrappingRunnable.run(TaskThread.java:61)
at java.lang.Thread.run(Thread.java:745)
Caused by: org.opensaml.common.SAMLException: Response has invalid status code urn:oasis:names:tc:SAML:2.0:status:Responder, status message is null
at org.springframework.security.saml.websso.WebSSOProfileConsumerImpl.processAuthenticationResponse(WebSSOProfileConsumerImpl.java:113)
at blackboard.auth.provider.saml.customization.consumer.BbSAMLWebSSOProfileConsumerImpl.processAuthenticationResponse(BbSAMLWebSSOProfileConsumerImpl.java:40)
at org.springframework.security.saml.SAMLAuthenticationProvider.authenticate(SAMLAuthenticationProvider.java:87)
. 230 more
2016-11-01 12:47:19 -0500 — BbSAMLExceptionHandleFilter — javax.servlet.ServletException: Unsuccessful Authentication
at blackboard.auth.provider.saml.customization.filter.BbSAMLProcessingFilter.unsuccessfulAuthentication(BbSAMLProcessingFilter.java:31)
at org.springframework.security.web.authentication.AbstractAuthenticationProcessingFilter.doFilter(AbstractAuthenticationProcessingFilter.java:235)
at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:330)
at org.springframework.security.web.FilterChainProxy.doFilterInternal(FilterChainProxy.java:213)
at org.springframework.security.web.FilterChainProxy.doFilter(FilterChainProxy.java:184)
at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:330)
at org.springframework.security.web.header.HeaderWriterFilter.doFilterInternal(HeaderWriterFilter.java:64)
at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:107)
at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:330)
at org.springframework.security.web.context.request.async.WebAsyncManagerIntegrationFilter.doFilterInternal(WebAsyncManagerIntegrationFilter.java:53)
at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:107)
at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:330)
at org.springframework.security.web.context.SecurityContextPersistenceFilter.doFilter(SecurityContextPersistenceFilter.java:91)
at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:330)
at org.springframework.security.web.FilterChainProxy.doFilterInternal(FilterChainProxy.java:213)
at org.springframework.security.web.FilterChainProxy.doFilter(FilterChainProxy.java:176)
at org.springframework.web.filter.DelegatingFilterProxy.invokeDelegate(DelegatingFilterProxy.java:346)
at org.springframework.web.filter.DelegatingFilterProxy.doFilter(DelegatingFilterProxy.java:262)
at sun.reflect.GeneratedMethodAccessor929.invoke(Unknown Source)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
at java.lang.reflect.Method.invoke(Method.java:498)
at org.apache.catalina.security.SecurityUtil$1.run(SecurityUtil.java:282)
at org.apache.catalina.security.SecurityUtil$1.run(SecurityUtil.java:279)
at java.security.AccessController.doPrivileged(Native Method)
at javax.security.auth.Subject.doAsPrivileged(Subject.java:549)
at org.apache.catalina.security.SecurityUtil.execute(SecurityUtil.java:314)
at org.apache.catalina.security.SecurityUtil.doAsPrivilege(SecurityUtil.java:253)
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:190)
at org.apache.catalina.core.ApplicationFilterChain.access$000(ApplicationFilterChain.java:46)
at org.apache.catalina.core.ApplicationFilterChain$1.run(ApplicationFilterChain.java:148)
at org.apache.catalina.core.ApplicationFilterChain$1.run(ApplicationFilterChain.java:144)
at java.security.AccessController.doPrivileged(Native Method)
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:143)
at blackboard.auth.provider.saml.customization.filter.BbSAMLExceptionHandleFilter.doFilterInternal(BbSAMLExceptionHandleFilter.java:30)
[SNIP]
Resolution
- Navigate to the Admin Panel.
- Under Building Blocks , select Building Blocks .
- Select Installed Tools.
- Locate Authentication Provider — SAML in the list. Open the menu and select Settings .
- Under Signature Algorithm Settings, choose SHA-256 in the list. After you select the Signature Algorithm Type , restart the SAML building block to apply the new settings.
- Select Submit to save your changes.
Problem #5
After entering the login credentials on the ADFS login page, an error may be displayed after being redirected to the Blackboard Learn GUI: The specified resource was not found, or you do not have permission to access it or Sign On Error!
With the following exceptions in the bb-services log:
2017-01-04 22:52:58 -0700 — unsuccessfulAuthentication — org.springframework.security.authentication.AuthenticationServiceException: Error validating SAML message
at org.springframework.security.saml.SAMLAuthenticationProvider.authenticate(SAMLAuthenticationProvider.java:100)
at org.springframework.security.authentication.ProviderManager.authenticate(ProviderManager.java:167)
at org.springframework.security.saml.SAMLProcessingFilter.attemptAuthentication(SAMLProcessingFilter.java:87)
at org.springframework.security.web.authentication.AbstractAuthenticationProcessingFilter.doFilter(AbstractAuthenticationProcessingFilter.java:217)
at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:330)
at org.springframework.security.web.FilterChainProxy.doFilterInternal(FilterChainProxy.java:213)
at org.springframework.security.web.FilterChainProxy.doFilter(FilterChainProxy.java:184)
at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:330)
at org.springframework.security.web.header.HeaderWriterFilter.doFilterInternal(HeaderWriterFilter.java:64)
at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:107)
at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:330)
at org.springframework.security.web.context.request.async.WebAsyncManagerIntegrationFilter.doFilterInternal(WebAsyncManagerIntegrationFilter.java:53)
at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:107)
at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:330)
at org.springframework.security.web.context.SecurityContextPersistenceFilter.doFilter(SecurityContextPersistenceFilter.java:91)
at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:330)
at org.springframework.security.web.FilterChainProxy.doFilterInternal(FilterChainProxy.java:213)
at org.springframework.security.web.FilterChainProxy.doFilter(FilterChainProxy.java:176)
at org.springframework.web.filter.DelegatingFilterProxy.invokeDelegate(DelegatingFilterProxy.java:346)
at org.springframework.web.filter.DelegatingFilterProxy.doFilter(DelegatingFilterProxy.java:262)
at sun.reflect.GeneratedMethodAccessor935.invoke(Unknown Source)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
at java.lang.reflect.Method.invoke(Method.java:498)
at org.apache.catalina.security.SecurityUtil$1.run(SecurityUtil.java:282)
at org.apache.catalina.security.SecurityUtil$1.run(SecurityUtil.java:279)
at java.security.AccessController.doPrivileged(Native Method)
at javax.security.auth.Subject.doAsPrivileged(Subject.java:549)
at org.apache.catalina.security.SecurityUtil.execute(SecurityUtil.java:314)
at org.apache.catalina.security.SecurityUtil.doAsPrivilege(SecurityUtil.java:253)
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:190)
at org.apache.catalina.core.ApplicationFilterChain.access$000(ApplicationFilterChain.java:46)
at org.apache.catalina.core.ApplicationFilterChain$1.run(ApplicationFilterChain.java:148)
at org.apache.catalina.core.ApplicationFilterChain$1.run(ApplicationFilterChain.java:144)
at java.security.AccessController.doPrivileged(Native Method)
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:143)
at blackboard.auth.provider.saml.customization.filter.BbSAMLExceptionHandleFilter.doFilterInternal(BbSAMLExceptionHandleFilter.java:30)
at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:107)
[SNIP]
at org.apache.tomcat.util.net.SocketProcessorBase.run(SocketProcessorBase.java:49)
at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1142)
at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:617)
at org.apache.tomcat.util.threads.TaskThread$WrappingRunnable.run(TaskThread.java:61)
at java.lang.Thread.run(Thread.java:745)
Caused by: org.opensaml.common.SAMLException: NameID element must be present as part of the Subject in the Response message, please enable it in the IDP configuration
at org.springframework.security.saml.websso.WebSSOProfileConsumerImpl.processAuthenticationResponse(WebSSOProfileConsumerImpl.java:252)
at blackboard.auth.provider.saml.customization.consumer.BbSAMLWebSSOProfileConsumerImpl.processAuthenticationResponse(BbSAMLWebSSOProfileConsumerImpl.java:40)
at org.springframework.security.saml.SAMLAuthenticationProvider.authenticate(SAMLAuthenticationProvider.java:87)
. 214 more
As stated in the above SAML exception, the NameID element is missing from the Subject in the Response message. The problem typically occurs when the NameID is not setup as an Outgoing Claim Type in a Claims Rule for the Relying Party Trust on the institution’s ADFS IdP or the Claims Rule for the NameID is not in the proper order for the Relying Party Trust on the institution’s ADFS IdP, which in turn causes the missing NameID element in the Subject in the Response message.
Example: NameID element is missing
Example: NameID element is present
testadfs
://yourschool.blackboard. com/auth-saml/saml/SSO»
/>
You can use the Firefox SAML tracer Add-on to view the Subject in the Response message.
Resolution
There are three methods to resolving this issue.
- Confirm the steps from the SAML B2 Setup Guide for ADFS were properly followed and make changes as needed to transform an incoming claim for the Relying Party Trust for their ADFS IdP:
- Select Edit Claims Rule .
- Select Add Rule .
- On the Select Rule Template page, select Transform an Incoming Claim for the Claim rule template and then select Next .
- On the Configure Rule page, in the Claim rule name field, type Transform Email to Name ID .
- Incoming claim type should be SamAccountName (it must match the Outgoing Claim Type created initially in the Transform Username to NameID rule).
- The Outgoing claim type is Name ID .
- The Outgoing name ID format is Email .
- Confirm Pass through all claim values is selected and select Finish .
- Select OK to save the rule and OK again to complete the attribute mappings.
- Ensure for the order of the Claims Rules used for their ADFS IdP that the rule which has the NameID element does not have any optional rules occurring before it.
- If using a custom attribute, ensure the NameID element is in the Relying Party Trust since Learn still expects that their ADFS IdP release a NameID value.
Problem #6
When logged into Blackboard Learn via SAML authentication, the user attempts to log out by clicking on the Sign Out button on the left side of the page and then clicks the End SSO Session button, a Sign On Error! is immediately displayed.
Sign On Error!
Blackboard Learn is currently unable to log into your account using single sign-on. Contact your administrator for assistance.
For reference, the Error ID is [error ID].
With the following exception in the bb-services log:
2017-05-08 15:10:46 -0400 — BbSAMLExceptionHandleFilter Error Id: f3299757-8d4e-4fab-98cf-49cd99f4891e — javax.servlet.ServletException: Incoming SAML message failed security validation
at org.springframework.security.saml.SAMLLogoutProcessingFilter.processLogout(SAMLLogoutProcessingFilter.java:145)
at org.springframework.security.saml.SAMLLogoutProcessingFilter.doFilter(SAMLLogoutProcessingFilter.java:104)
at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:330)
at org.springframework.security.web.FilterChainProxy.doFilterInternal(FilterChainProxy.java:213)
at org.springframework.security.web.FilterChainProxy.doFilter(FilterChainProxy.java:184)
at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:330)
at org.springframework.security.web.header.HeaderWriterFilter.doFilterInternal(HeaderWriterFilter.java:64)
at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:107)
at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:330)
at org.springframework.security.web.context.request.async.WebAsyncManagerIntegrationFilter.doFilterInternal(WebAsyncManagerIntegrationFilter.java:53)
at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:107)
at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:330)
at org.springframework.security.web.context.SecurityContextPersistenceFilter.doFilter(SecurityContextPersistenceFilter.java:91)
at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:330)
at org.springframework.security.web.FilterChainProxy.doFilterInternal(FilterChainProxy.java:213)
at org.springframework.security.web.FilterChainProxy.doFilter(FilterChainProxy.java:176)
at org.springframework.web.filter.DelegatingFilterProxy.invokeDelegate(DelegatingFilterProxy.java:346)
[SNIP]
at org.apache.tomcat.util.threads.TaskThread$WrappingRunnable.run(TaskThread.java:61)
at java.lang.Thread.run(Thread.java:745)
Caused by: org.opensaml.ws.security.SecurityPolicyException: Validation of request simple signature failed for context issuer
at org.opensaml.common.binding.security.BaseSAMLSimpleSignatureSecurityPolicyRule.doEvaluate(BaseSAMLSimpleSignatureSecurityPolicyRule.java:139)
at org.opensaml.common.binding.security.BaseSAMLSimpleSignatureSecurityPolicyRule.evaluate(BaseSAMLSimpleSignatureSecurityPolicyRule.java:103)
at org.opensaml.ws.security.provider.BasicSecurityPolicy.evaluate(BasicSecurityPolicy.java:51)
at org.opensaml.ws.message.decoder.BaseMessageDecoder.processSecurityPolicy(BaseMessageDecoder.java:132)
at org.opensaml.ws.message.decoder.BaseMessageDecoder.decode(BaseMessageDecoder.java:83)
at org.opensaml.saml2.binding.decoding.BaseSAML2MessageDecoder.decode(BaseSAML2MessageDecoder.java:70)
at org.springframework.security.saml.processor.SAMLProcessorImpl.retrieveMessage(SAMLProcessorImpl.java:105)
at org.springframework.security.saml.processor.SAMLProcessorImpl.retrieveMessage(SAMLProcessorImpl.java:172)
at org.springframework.security.saml.SAMLLogoutProcessingFilter.processLogout(SAMLLogoutProcessingFilter.java:131)
. 244 more
The error occurs because of the Single Logout Service Type setting on the SAML Settings page.
Resolution
The setting needs to be configured in Blackboard Learn and on the ADFS server.
For ADFS as the IdP, select the Post setting only and remove the Redirect endpoint for the Learn instance’s Relying Party Trust on the ADFS server.
- In Learn, navigate to Admin > Authentication > (Provider Name) > SAML Settings > Single Logout Service Type.
- Select Post and clear the Redirect checkbox.
- In the ADFS Server, go into the Relying Party Trust for your Learn Instance.
- Select Properties > Endpoints . Two SAML logout endpoints are listed.
- Remove the Redirect endpoint. Select Remove Endpoint to remove it, then Apply and OK.
After making the above changes in Learn and the ADFS server, the End SSO Session logout button will work to properly sign out the user.
Problem #7
After entering the login credentials on the ADFS login page, a Sign On Error! message is displayed when redirected to Learn.
With the following SAML exception in the bb-services log:
2017-05-26 07:39:30 -0400 — unsuccessfulAuthentication — org.springframework.security.authentication.AuthenticationServiceException: Error validating SAML message
at org.springframework.security.saml.SAMLAuthenticationProvider.authenticate(SAMLAuthenticationProvider.java:100)
at org.springframework.security.authentication.ProviderManager.authenticate(ProviderManager.java:167)
at org.springframework.security.saml.SAMLProcessingFilter.attemptAuthentication(SAMLProcessingFilter.java:87)
at blackboard.auth.provider.saml.customization.filter.BbSAMLProcessingFilter.attemptAuthentication(BbSAMLProcessingFilter.java:46)
at org.springframework.security.web.authentication.AbstractAuthenticationProcessingFilter.doFilter(AbstractAuthenticationProcessingFilter.java:217)
at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:330)
at org.springframework.security.web.FilterChainProxy.doFilterInternal(FilterChainProxy.java:213)
at org.springframework.security.web.FilterChainProxy.doFilter(FilterChainProxy.java:184)
at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:330)
at org.springframework.security.web.header.HeaderWriterFilter.doFilterInternal(HeaderWriterFilter.java:64)
at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:107)
at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:330)
at org.springframework.security.web.context.request.async.WebAsyncManagerIntegrationFilter.doFilterInternal(WebAsyncManagerIntegrationFilter.java:53)
at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:107)
at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:330)
at org.springframework.security.web.context.SecurityContextPersistenceFilter.doFilter(SecurityContextPersistenceFilter.java:91)
at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:330)
at org.springframework.security.web.FilterChainProxy.doFilterInternal(FilterChainProxy.java:213)
at org.springframework.security.web.FilterChainProxy.doFilter(FilterChainProxy.java:176)
at org.springframework.web.filter.DelegatingFilterProxy.invokeDelegate(DelegatingFilterProxy.java:346)
at org.springframework.web.filter.DelegatingFilterProxy.doFilter(DelegatingFilterProxy.java:262)
at sun.reflect.GeneratedMethodAccessor380.invoke(Unknown Source)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
at java.lang.reflect.Method.invoke(Method.java:498)
at org.apache.catalina.security.SecurityUtil$1.run(SecurityUtil.java:282)
at org.apache.catalina.security.SecurityUtil$1.run(SecurityUtil.java:279)
at java.security.AccessController.doPrivileged(Native Method)
at javax.security.auth.Subject.doAsPrivileged(Subject.java:549)
at org.apache.catalina.security.SecurityUtil.execute(SecurityUtil.java:314)
at org.apache.catalina.security.SecurityUtil.doAsPrivilege(SecurityUtil.java:253)
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:190)
at org.apache.catalina.core.ApplicationFilterChain.access$000(ApplicationFilterChain.java:46)
at org.apache.catalina.core.ApplicationFilterChain$1.run(ApplicationFilterChain.java:148)
at org.apache.catalina.core.ApplicationFilterChain$1.run(ApplicationFilterChain.java:144)
at java.security.AccessController.doPrivileged(Native Method)
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:143)
at blackboard.auth.provider.saml.customization.filter.BbSAMLExceptionHandleFilter.doFilterInternal(BbSAMLExceptionHandleFilter.java:37)
[SNIP]
at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:617)
at org.apache.tomcat.util.threads.TaskThread$WrappingRunnable.run(TaskThread.java:61)
at java.lang.Thread.run(Thread.java:745)
Caused by: org.opensaml.common.SAMLException: Response has invalid status code urn:oasis:names:tc:SAML:2.0:status:Responder, status message is null
at org.springframework.security.saml.websso.WebSSOProfileConsumerImpl.processAuthenticationResponse(WebSSOProfileConsumerImpl.java:113)
at blackboard.auth.provider.saml.customization.consumer.BbSAMLWebSSOProfileConsumerImpl.processAuthenticationResponse(BbSAMLWebSSOProfileConsumerImpl.java:56)
at org.springframework.security.saml.SAMLAuthenticationProvider.authenticate(SAMLAuthenticationProvider.java:87)
. 247 more
Resolution
Beginning in Blackboard Learn 3200.0.0, there is now an option to regenerate the SAML encryption certificate by navigating to System Admin > Building Blocks > Authentication Provider — SAML > Settings > Regenerate Certificate . The Sign On Error! problem may occur if the Regenerate certificate button is selected after the SP metadata is already uploaded to the Relying Party Trust for the Learn site on the ADFS server. To resolve the issue:
- Navigate to System Admin > Authentication > [SAML Provider Name] > SAML Settings.
- Select Generate next to Service Provider Metadata to save the new metadata file.
- Access your ADFS server and upload the new SP metadata to the Relying Party Trust for your Learn site.
If you generate a new certificate under the B2 settings, you need to toggle the SAML B2 to Inactive and then back to Active to force the change. After, you can return to the provider settings and generate the new metadata to import into the IDP. If you don’t toggle the settings, the old certificate may still be included when you generate new metadata. The IDP won’t be updated and the next time Learn restarts it will present the new certificate. SAML authentication will break because of this mismatch.
Federation Metadata
With Active Directory Federation Services (ADFS), since the metadata for an ADFS federation typically located in https://[ADFS Server Hostname]/FederationMetadata/2007-06/FederationMetadata.xml includes an element that is incompatible with SAML 2.0, the metadata needs to be edited to delete the incompatible element before it is uploaded to the Identity Provider Settings section on the SAML Authentication Settings page in the Blackboard Learn GUI. If the metadata with the incompatible element is uploaded, an error will occur when selecting the SAML login link on the Blackboard Learn login page: Metadata for entity [entity] and role <> wasn’t found. For reference, the Error ID is [error ID].
And the corresponding Java stack trace for the Error ID in the bb-services log has the following:
2016-06-21 11:42:51 -0700 — Metadata for entity https:// /adfs/ls/ and role SPSSODescriptor wasn’t found
For reference, the Error ID is c99511ae-1162-4941-b823-3dda19fea157. — org.opensaml.saml2.metadata.provider.MetadataProviderException: Metadata for entity https ://ulvsso.laverne. edu/adfs/ls/ and role SPSSODescriptor wasn’t found
at org.springframework.security.saml.context.SAMLContextProviderImpl.populateLocalEntity(SAMLContextProviderImpl.java:319)
at org.springframework.security.saml.context.SAMLContextProviderImpl.populateLocalContext(SAMLContextProviderImpl.java:216)
at org.springframework.security.saml.context.SAMLContextProviderImpl.getLocalAndPeerEntity(SAMLContextProviderImpl.java:126)
at org.springframework.security.saml.SAMLEntryPoint.commence(SAMLEntryPoint.java:146)
at org.springframework.security.saml.SAMLEntryPoint.doFilter(SAMLEntryPoint.java:107)
at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:330)
at org.springframework.security.web.FilterChainProxy.doFilterInternal(FilterChainProxy.java:213)
at org.springframework.security.web.FilterChainProxy.doFilter(FilterChainProxy.java:184)
at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:330)
at org.springframework.security.web.header.HeaderWriterFilter.doFilterInternal(HeaderWriterFilter.java:64)
at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:107)
at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:330)
at org.springframework.security.web.context.request.async.WebAsyncManagerIntegrationFilter.doFilterInternal(WebAsyncManagerIntegrationFilter.java:53)
at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:107)
at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:330)
at org.springframework.security.web.context.SecurityContextPersistenceFilter.doFilter(SecurityContextPersistenceFilter.java:91)
at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:330)
at org.springframework.security.web.FilterChainProxy.doFilterInternal(FilterChainProxy.java:213)
at org.springframework.security.web.FilterChainProxy.doFilter(FilterChainProxy.java:176)
at org.springframework.web.filter.DelegatingFilterProxy.invokeDelegate(DelegatingFilterProxy.java:346)
at org.springframework.web.filter.DelegatingFilterProxy.doFilter(DelegatingFilterProxy.java:262)
at sun.reflect.GeneratedMethodAccessor1652.invoke(Unknown Source)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
at java.lang.reflect.Method.invoke(Method.java:498)
[SNIP]
Resolution
Since the default metadata location for an ADFS federation is https://[ADFS server hostname]/FederationMetadata/2007-06/FederationMetadata.xml :
- Download this file and open it in a text editor. Carefully delete the section starting ://www.w3. org/2000/09/xmldsig#»> . and ending
://www.w3. org/2000/09/xmldsig#»>
://www.w3. org/2001/10/xml-exc-c14n#»/>
://www.w3. org/2001/04/xmldsig-more#rsa-sha256″/>
://www.w3. org/2000/09/xmldsig#enveloped-signature»/>
://www.w3. org/2001/10/xml-exc-c14n#»/>
://www.w3. org/2001/04/xmlenc#sha256″/>
z1H1[SNIP]jaYM=
FVj[SNIP]edrfNKWvsvk5A==
://www.w3. org/2000/09/xmldsig#»>
FDdd[SNIP]qTNKdk5F/vf1AocDaX
If an institution is testing SAML authentication on a Blackboard Learn site and has multiple SAML authentication providers that share the same underlying ADFS IdP metadata XML file on the Blackboard Learn site, even if the other SAML authentication providers are set to Inactive, they will also need to have the updated metadata XML file uploaded in the Blackboard Learn GUI on the SAML Authentication Settings page in the Identity Provider Settings section. The SAML B2 should then be toggled Inactive/Available, while having the SAML authentication provider in ‘Active’ status, to ensure the updated metadata XML file is recognized system-wide.
Incorrect user lookup method
After entering the login credentials on the ADFS login page, the user is redirected to the Blackboard Learn GUI, but not logged into Blackboard Learn.
The ONLY SAML authentication related event in the bb-services log is:
2016-10-18 13:03:28 -0600 — userName is null or empty
Resolution
- Login to Blackboard Learn as administrator using the default Blackboard Learn Internal authentication.
- Navigate to System Admin > «SAML Authentication Provider Name» > Edit.
- Change the User Lookup Method from Batch Uid to Username.
ADFS tries to add an extra End SSO Session logout button on the End all sessions? page that is displayed after first selecting the logout button at the top right in the Blackboard Learn GUI.
This is done by adding an extra SingleLogoutService to the IdP Metadata file:
://your.server. name/adfs/ls/»/>
://your.server. name/adfs/ls/»/>
Since that is an optional SAML B2 IdP configuration and the signature being provided in the Redirect Endpoint is not correct, an error will occur when selecting the extra End SSO Session button on the End all sessions? page: Incoming SAML message failed security validation. Validation of request simple signature failed for context issuer. For reference, the error Id is [error ID].
The corresponding Java stack trace for the Error ID in the bb-services log has:
2016-10-17 16:57:44 -0400 — Incoming SAML message failed security validation Validation of request simple signature failed for context issuer
For reference, the Error ID is 930c7767-8710-475e-8415-2077152280e0. — org.opensaml.ws.security.SecurityPolicyException: Validation of request simple signature failed for context issuer
at org.opensaml.common.binding.security.BaseSAMLSimpleSignatureSecurityPolicyRule.doEvaluate(BaseSAMLSimpleSignatureSecurityPolicyRule.java:139)
at org.opensaml.common.binding.security.BaseSAMLSimpleSignatureSecurityPolicyRule.evaluate(BaseSAMLSimpleSignatureSecurityPolicyRule.java:103)
at org.opensaml.ws.security.provider.BasicSecurityPolicy.evaluate(BasicSecurityPolicy.java:51)
at org.opensaml.ws.message.decoder.BaseMessageDecoder.processSecurityPolicy(BaseMessageDecoder.java:132)
at org.opensaml.ws.message.decoder.BaseMessageDecoder.decode(BaseMessageDecoder.java:83)
at org.opensaml.saml2.binding.decoding.BaseSAML2MessageDecoder.decode(BaseSAML2MessageDecoder.java:70)
at org.springframework.security.saml.processor.SAMLProcessorImpl.retrieveMessage(SAMLProcessorImpl.java:105)
at org.springframework.security.saml.processor.SAMLProcessorImpl.retrieveMessage(SAMLProcessorImpl.java:172)
at org.springframework.security.saml.SAMLLogoutProcessingFilter.processLogout(SAMLLogoutProcessingFilter.java:131)
at org.springframework.security.saml.SAMLLogoutProcessingFilter.doFilter(SAMLLogoutProcessingFilter.java:104)
at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:330)
at org.springframework.security.web.FilterChainProxy.doFilterInternal(FilterChainProxy.java:213)
at org.springframework.security.web.FilterChainProxy.doFilter(FilterChainProxy.java:184)
at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:330)
at org.springframework.security.web.header.HeaderWriterFilter.doFilterInternal(HeaderWriterFilter.java:64)
at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:107)
at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:330)
at org.springframework.security.web.context.request.async.WebAsyncManagerIntegrationFilter.doFilterInternal(WebAsyncManagerIntegrationFilter.java:53)
at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:107)
at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:330)
at org.springframework.security.web.context.SecurityContextPersistenceFilter.doFilter(SecurityContextPersistenceFilter.java:91)
at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:330)
at org.springframework.security.web.FilterChainProxy.doFilterInternal(FilterChainProxy.java:213)
at org.springframework.security.web.FilterChainProxy.doFilter(FilterChainProxy.java:176)
at org.springframework.web.filter.DelegatingFilterProxy.invokeDelegate(DelegatingFilterProxy.java:346)
at org.springframework.web.filter.DelegatingFilterProxy.doFilter(DelegatingFilterProxy.java:262)
at sun.reflect.GeneratedMethodAccessor1652.invoke(Unknown Source)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
at java.lang.reflect.Method.invoke(Method.java:498)
[SNIP]
Resolution
- Access the ADFS Server and go into the Relying Party Trust for the Blackboard Learn Instance.
- Select Properties > Endpoints tab.
- In the Endpoints tab there will be 2 SAML Logout Endpoints.
- Remove the Redirect endpoint.
- Select Remove Endpoint to remove it, then Apply and OK.
After removing the Redirect endpoint, the End SSO Session button will work properly signing out the user.
Viewing application logs with event viewer
When troubleshooting an ADFS SAML authentication issue, it may be necessary to also have an institution review the ADFS application logs in the Event Viewer on their ADFS server for further insight. This is particularly necessary when the SAML response from the ADFS server has a Request Denied status as seen below:
The SAML response can be viewed by using the Firefox browser SAML tracer Add-on.
The Request Denied status in a response typically indicates a problem occurred when the IdP (ADFS) attempted to understand the response and process the result the SP (Blackboard Learn) provided.
To view the ADFS application logs with the Event Viewer :
- Open the Event Viewer on the ADFS server.
- On the View menu, select Show Analytic and Debug Logs.
- In the console tree, navigate to Application and Service Logs > AD FS Tracing > Debug .
Azure Active Directory
Azure AD is Microsoft’s (MS) cloud based directory and identity management service.
Send first part of email
If an institution is using Azure AD as their IdP and wishes to only have the first part of the Azure AD email username used for the Blackboard Learn username, they can configure their Azure AD IdP to use the special ExtractMailPrefix() function to remove the domain suffix from either the email or the user principal name resulting in only the first part of the username being passed through (e.g. «joesmith» instead of joesmith @example. com).
If the Blackboard Learn Remote User ID is urn:oid:1.3.6.1.4.1.5923.1.1.1.6 , the Attribute setting for the Azure IdP would look like this:
Attribute Name: urn:oid:1.3.6.1.4.1.5923.1.1.1.6
Attribute Value: ExtractMailPrefix()
Mail: user.userprincipalname
So with the example joesmith @example. com email username, it would be passed like this in the SAML assertion from the Azure IdP to Blackboard Learn:
Additional info about using the ExtractMailPrefix() function is available on the MS Azure documentation page.
After entering the login credentials on the MS Azure AD login page, a Sign On Error! may be displayed after being redirected to the Blackboard Learn GUI.
With the following exception in the bb-services log:
2016-10-13 12:03:23 +0800 — unsuccessfulAuthentication — org.springframework.security.authentication.AuthenticationServiceException: Error validating SAML message
at org.springframework.security.saml.SAMLAuthenticationProvider.authenticate(SAMLAuthenticationProvider.java:100)
at org.springframework.security.authentication.ProviderManager.authenticate(ProviderManager.java:167)
at org.springframework.security.saml.SAMLProcessingFilter.attemptAuthentication(SAMLProcessingFilter.java:87)
at org.springframework.security.web.authentication.AbstractAuthenticationProcessingFilter.doFilter(AbstractAuthenticationProcessingFilter.java:217)
at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:330)
at org.springframework.security.web.FilterChainProxy.doFilterInternal(FilterChainProxy.java:213)
at org.springframework.security.web.FilterChainProxy.doFilter(FilterChainProxy.java:184)
at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:330)
at org.springframework.security.web.header.HeaderWriterFilter.doFilterInternal(HeaderWriterFilter.java:64)
at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:107)
at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:330)
at org.springframework.security.web.context.request.async.WebAsyncManagerIntegrationFilter.doFilterInternal(WebAsyncManagerIntegrationFilter.java:53)
at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:107)
at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:330)
at org.springframework.security.web.context.SecurityContextPersistenceFilter.doFilter(SecurityContextPersistenceFilter.java:91)
at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:330)
at org.springframework.security.web.FilterChainProxy.doFilterInternal(FilterChainProxy.java:213)
at org.springframework.security.web.FilterChainProxy.doFilter(FilterChainProxy.java:176)
at org.springframework.web.filter.DelegatingFilterProxy.invokeDelegate(DelegatingFilterProxy.java:346)
at org.springframework.web.filter.DelegatingFilterProxy.doFilter(DelegatingFilterProxy.java:262)
at sun.reflect.GeneratedMethodAccessor854.invoke(Unknown Source)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
at java.lang.reflect.Method.invoke(Method.java:498)
at org.apache.catalina.security.SecurityUtil$1.run(SecurityUtil.java:282)
at org.apache.catalina.security.SecurityUtil$1.run(SecurityUtil.java:279)
at java.security.AccessController.doPrivileged(Native Method)
at javax.security.auth.Subject.doAsPrivileged(Subject.java:549)
at org.apache.catalina.security.SecurityUtil.execute(SecurityUtil.java:314)
at org.apache.catalina.security.SecurityUtil.doAsPrivilege(SecurityUtil.java:253)
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:190)
at org.apache.catalina.core.ApplicationFilterChain.access$000(ApplicationFilterChain.java:46)
at org.apache.catalina.core.ApplicationFilterChain$1.run(ApplicationFilterChain.java:148)
at org.apache.catalina.core.ApplicationFilterChain$1.run(ApplicationFilterChain.java:144)
at java.security.AccessController.doPrivileged(Native Method)
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:143)
at blackboard.auth.provider.saml.customization.filter.BbSAMLExceptionHandleFilter.doFilterInternal(BbSAMLExceptionHandleFilter.java:30)
[SNIP]
at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:617)
at org.apache.tomcat.util.threads.TaskThread$WrappingRunnable.run(TaskThread.java:61)
at java.lang.Thread.run(Thread.java:745)
Caused by: org.opensaml.common.SAMLException: Response doesn’t have any valid assertion which would pass subject validation
at org.springframework.security.saml.websso.WebSSOProfileConsumerImpl.processAuthenticationResponse(WebSSOProfileConsumerImpl.java:229)
at blackboard.auth.provider.saml.customization.consumer.BbSAMLWebSSOProfileConsumerImpl.processAuthenticationResponse(BbSAMLWebSSOProfileConsumerImpl.java:40)
at org.springframework.security.saml.SAMLAuthenticationProvider.authenticate(SAMLAuthenticationProvider.java:87)
. 230 more
Caused by: org.opensaml.xml.validation.ValidationException: Signature is not trusted or invalid
at org.springframework.security.saml.websso.AbstractProfileBase.verifySignature(AbstractProfileBase.java:272)
at org.springframework.security.saml.websso.WebSSOProfileConsumerImpl.verifyAssertionSignature(WebSSOProfileConsumerImpl.java:419)
at org.springframework.security.saml.websso.WebSSOProfileConsumerImpl.verifyAssertion(WebSSOProfileConsumerImpl.java:292)
at org.springframework.security.saml.websso.WebSSOProfileConsumerImpl.processAuthenticationResponse(WebSSOProfileConsumerImpl.java:214)
. 232 more
This is caused by the MS Azure AD IdP updating the certificate, but the metadata XML used by the Blackboard Learn SP not being adjusted to reflect the new certificate.
Resolution
- The new metadata XML file with the new certificate will need to be updated on the SAML Settings page in the Blackboard Learn GUI for the authentication provider.
- The SAML B2 and the authentication provider will then need to be toggled Inactive/Available, while having the SAML authentication provider in ‘Active’ status, to have the updated metadata with the new certificate applied.
- If a Blackboard Learn site has multiple authentication providers that share the same underlying certificate for the same underlying IdP Entity ID, ALL those authentication providers will need to be updated.
IdP-initiated single sign on
If a user first logs into their user portal and then selects the app for their Blackboard Learn site, a new browser tab opens to display a message: The specified resource was not found, or you do not have permission to access it .
With the corresponding SAML related events in the stdout-stderr.log:
INFO | jvm 1 | 2016/08/16 10:49:22 | — /saml/SSO at position 1 of 10 in additional filter chain; firing Filter: ‘SecurityContextPersistenceFilter’
INFO | jvm 1 | 2016/08/16 10:49:22 | — HttpSession returned null object for SPRING_SECURITY_CONTEXT
INFO | jvm 1 | 2016/08/16 10:49:22 | — No SecurityContext was available from the HttpSession: [email protected] A new one will be created.
INFO | jvm 1 | 2016/08/16 10:49:22 | — /saml/SSO at position 2 of 10 in additional filter chain; firing Filter: ‘WebAsyncManagerIntegrationFilter’
INFO | jvm 1 | 2016/08/16 10:49:22 | — /saml/SSO at position 3 of 10 in additional filter chain; firing Filter: ‘HeaderWriterFilter’
INFO | jvm 1 | 2016/08/16 10:49:22 | — /saml/SSO at position 4 of 10 in additional filter chain; firing Filter: ‘FilterChainProxy’
INFO | jvm 1 | 2016/08/16 10:49:22 | — Checking match of request : ‘/saml/sso’; against ‘/saml/login/**’
INFO | jvm 1 | 2016/08/16 10:49:22 | — Checking match of request : ‘/saml/sso’; against ‘/saml/logout/**’
INFO | jvm 1 | 2016/08/16 10:49:22 | — Checking match of request : ‘/saml/sso’; against ‘/saml/bbsamllogout/**’
INFO | jvm 1 | 2016/08/16 10:49:22 | — Checking match of request : ‘/saml/sso’; against ‘/saml/sso/**’
INFO | jvm 1 | 2016/08/16 10:49:22 | — /saml/SSO at position 1 of 1 in additional filter chain; firing Filter: ‘SAMLProcessingFilter’
INFO | jvm 1 | 2016/08/16 10:49:22 | — Forwarding to /
INFO | jvm 1 | 2016/08/16 10:49:22 | — DispatcherServlet with name ‘saml’ processing POST request for [/auth-saml/saml/SSO]
INFO | jvm 1 | 2016/08/16 10:49:22 | — No mapping found for HTTP request with URI [/auth-saml/saml/SSO] in DispatcherServlet with name ‘saml’
INFO | jvm 1 | 2016/08/16 10:49:22 | — SecurityContext is empty or contents are anonymous — context will not be stored in HttpSession.
INFO | jvm 1 | 2016/08/16 10:49:22 | — Successfully completed request
INFO | jvm 1 | 2016/08/16 10:49:22 | — Skip invoking on
INFO | jvm 1 | 2016/08/16 10:49:22 | — SecurityContextHolder now cleared, as request processing completed
The Service Provider Settings section of the SAML Authentication Settings page has changed and the Enable automatic SSO option should be checked to allow a user to access Blackboard Learn from their portal. If it is enabled, the ACS URL will also be changed to include an alias.
Wrong document error
After entering the login credentials on the SAML authentication provider login page, a Sign On Error! may be displayed after being redirected to the Blackboard Learn GUI.
With the following DOMException and WRONG_DOCUMENT_ERR in the bb-services log:
2016-11-18 12:27:31 -0600 — WRONG_DOCUMENT_ERR: A node is used in a different document than the one that created it.
For reference, the Error ID is 86ebb81d-d3a3-4da5-95ab-1c94505f4281. — org.w3c.dom.DOMException: WRONG_DOCUMENT_ERR: A node is used in a different document than the one that created it.
at org.apache.xerces.dom.ParentNode.internalInsertBefore(Unknown Source)
at org.apache.xerces.dom.ParentNode.insertBefore(Unknown Source)
at org.apache.xerces.dom.NodeImpl.appendChild(Unknown Source)
at org.opensaml.xml.encryption.Decrypter.parseInputStream(Decrypter.java:832)
at org.opensaml.xml.encryption.Decrypter.decryptDataToDOM(Decrypter.java:610)
at org.opensaml.xml.encryption.Decrypter.decryptUsingResolvedEncryptedKey(Decrypter.java:795)
at org.opensaml.xml.encryption.Decrypter.decryptDataToDOM(Decrypter.java:535)
at org.opensaml.xml.encryption.Decrypter.decryptDataToList(Decrypter.java:453)
at org.opensaml.xml.encryption.Decrypter.decryptData(Decrypter.java:414)
at org.opensaml.saml2.encryption.Decrypter.decryptData(Decrypter.java:141)
at org.opensaml.saml2.encryption.Decrypter.decrypt(Decrypter.java:69)
at org.springframework.security.saml.websso.WebSSOProfileConsumerImpl.processAuthenticationResponse(WebSSOProfileConsumerImpl.java:199)
at org.springframework.security.saml.SAMLAuthenticationProvider.authenticate(SAMLAuthenticationProvider.java:82)
at org.springframework.security.authentication.ProviderManager.authenticate(ProviderManager.java:167)
at org.springframework.security.saml.SAMLProcessingFilter.attemptAuthentication(SAMLProcessingFilter.java:87)
at org.springframework.security.web.authentication.AbstractAuthenticationProcessingFilter.doFilter(AbstractAuthenticationProcessingFilter.java:217)
at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:330)
at org.springframework.security.web.FilterChainProxy.doFilterInternal(FilterChainProxy.java:213)
at org.springframework.security.web.FilterChainProxy.doFilter(FilterChainProxy.java:184)
at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:330)
at org.springframework.security.web.header.HeaderWriterFilter.doFilterInternal(HeaderWriterFilter.java:64)
at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:107)
at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:330)
at org.springframework.security.web.context.request.async.WebAsyncManagerIntegrationFilter.doFilterInternal(WebAsyncManagerIntegrationFilter.java:53)
at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:107)
at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:330)
at org.springframework.security.web.context.SecurityContextPersistenceFilter.doFilter(SecurityContextPersistenceFilter.java:91)
at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:330)
at org.springframework.security.web.FilterChainProxy.doFilterInternal(FilterChainProxy.java:213)
at org.springframework.security.web.FilterChainProxy.doFilter(FilterChainProxy.java:176)
at org.springframework.web.filter.DelegatingFilterProxy.invokeDelegate(DelegatingFilterProxy.java:346)
at org.springframework.web.filter.DelegatingFilterProxy.doFilter(DelegatingFilterProxy.java:262)
at sun.reflect.GeneratedMethodAccessor1209.invoke(Unknown Source)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
at java.lang.reflect.Method.invoke(Method.java:498)
at org.apache.catalina.security.SecurityUtil$1.run(SecurityUtil.java:277)
at org.apache.catalina.security.SecurityUtil$1.run(SecurityUtil.java:274)
at java.security.AccessController.doPrivileged(Native Method)
at javax.security.auth.Subject.doAsPrivileged(Subject.java:549)
at org.apache.catalina.security.SecurityUtil.execute(SecurityUtil.java:309)
at org.apache.catalina.security.SecurityUtil.doAsPrivilege(SecurityUtil.java:249)
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:237)
at org.apache.catalina.core.ApplicationFilterChain.access$000(ApplicationFilterChain.java:55)
at org.apache.catalina.core.ApplicationFilterChain$1.run(ApplicationFilterChain.java:191)
at org.apache.catalina.core.ApplicationFilterChain$1.run(ApplicationFilterChain.java:187)
at java.security.AccessController.doPrivileged(Native Method)
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:186)
at blackboard.platform.servlet.DevNonceFilter.doFilter(DevNonceFilter.java:68)
[SNIP]
The reason the problem occurs is another B2/Project changed the system property javax.xml.parsers.DocumentBuilderFactory value from org.apache.xerces.jaxp.DocumentBuilderFactoryImpl to com.sun.org.apache.xerces.internal.jaxp.DocumentBuilderFactoryImpl.
Temporary resolution
Until a fix is released, the temporary resolution options are:
- Restart Bb services on each node.
- Turn off SAML response encryption on the IdP side. As the whole communication is over SSL, this will not reduce the security of the authentication.
No option to add SAML to Provider Order
When configuring SAML authentication, an institution may notice there is not an option to add a SAML authentication provider in the Provider Order section in Blackboard Learn GUI when navigating to System Admin > Building Blocks: Authentication > Provider Order .
The reason there is not an option to add a SAML authentication provider to the Provider Order is that redirect type providers such as CAS and SAML hand off authentication to the remote authentication source. Those are not listed in the Provider Order as they are considered the authoritative source for authentication and handle their own authentication failures.
Test SAML connection
Beginning with the Q4 2016 release of Blackboard Learn, there is now an option to test the connection for a SAML provider in the Authentication section in the Blackboard Learn GUI. The connection test will check the following items:
- Parse IdP metadata
- Connect to IdP
- Receive SAML response
- Parse SAML response
- Remote User ID match
- Log in to Blackboard Learn
To test the connection for a SAML authentication provider:
- Login to Blackboard Learn as an administrator.
- Navigate to System Admin > Building Blocks: Authentication > «SAML Provider Name» > Test Connection .
- Enter the IdP login credentials if prompted.
The Test Connection feature can be used in lieu of manually enabling SAML debug logging in Blackboard Learn for multiple reasons.
The Identity Provider Entity ID value that is displayed on the Test Connection output page is pulled from the Issuer element in the SAML POST from the IdP to Blackboard Learn after the user has been authenticated:
http: //bbpdcsi-adfs1.bbpdcsi. local/a. services/trust
The SAML Attribute values displayed on the Test Connection output page in the SAML Response section are pulled from the Subject and AttributeStatement elements in the SAML POST from the IdP to Blackboard Learn after the user has been authenticated:
Create a SAML authentication provider and IdP for testing
Use the steps below to create an Identity Provider (IdP) using Centrify’s free SSO authentication solution.
That IdP can then be configured as the SAML authentication provider in a Blackboard Learn Service Provider (SP):
Blackboard Learn Service Provider
- Login to the Blackboard Learn GUI as an administrator and navigate to System Admin > Authentication.
- Select Create Provider > SAML.
- Input the following settings:
- Name > SAML or anything you want.
- Authentication Provider > Inactive (for now).
- User Lookup Method > Username
- Restrict by Hostname > Use this provider for any hostnames
- Link Text > SAML Centrify Login
- Select Save and Configure.
- In the Entity ID field, set this to anything you want (but if you change it you must provide the updated Service Provider Metadata to the Identity Provider). Simply copy/paste the ACS URL.
- Under Service Provider Metadata, select Generate and save the file to your desktop.
- Under Data Source , it is recommended to create a new Data Source for this named CENTRIFY, otherwise use SYSTEM or whatever you choose
- Next to Enable JIT Provisioning , check this box so that an account is automatically created when attempting to login via this SAML authentication provider if the user does not exist. If JIT Provisioning is not selected, the user in Blackboard Learn will need to be created manually.
- In the Compatible Data Sources list, be sure to select the data sources that this authentication provider should be compatible with.
- Select Point Identity Provider for the Identity Provider Type .
- Skip the Identity Provider Metadata for now, you will upload the file after it has been created in the Centrify IdP section.
- For the Map SAML Attributes section, use NameID for the Remote User ID .
- Select Submit.
Centrify Identity Provider
- Go to the Centrify website and select Start Now .
- Enter your information to sign up and select Start Now .
- You will receive a welcome email with your admin credentials. Use them to log in to https://cloud.centrify.com.
- Select Skip on the Welcome to Centrify Identify Service window.
- In the Apps tab at the top of the page, select the Add Web Apps button.
- In the Custom tab, scroll down and select the Add button for SAML. Select Yes .
- Select Close at the bottom of the Add Web Apps window.
- Go to the Apps tab. In the Application Settings section, select the Upload SP Metadata button and upload the file that was created in Step 6 of the Blackboard Learn SP section.
- The Assertion Consumer Service URL should automatically populate after uploading the SP Metadata.
- Uncheck Encrypt Assertion. This allows the attributes being released from the IdP and sent to Blackboard Learn to be viewed using the Firefox browser SAML tracer Add-on or Chrome SAML Message Decoder. As the whole communication is over SSL this will not reduce the security of the authentication.
- Scroll down and select Download Identity Provider SAML Metadata . Save the file to your desktop.
- Select Save and go to the next section.
- Enter a name for the Description section. Select Save and go to the next section.
- In the User Access section, select Everybody and System Administrator . Select Save .
- Do not make any selections in the Policy section.
- For the Account Mapping section, confirm that userprincipalname is entered for the Directory Service field name.
- For the Advanced section, add the following line to the bottom of the script used to generate a SAML assertion for the application:
The complete script will be:
setIssuer(Issuer);
setSubjectName(UserIdentifier);
setAudience(‘https ://YourLearnServer.blackboard. c. saml/saml/SSO’);
setRecipient(ServiceUrl);
setHttpDestination(ServiceUrl);
setSignatureType(‘Assertion’);
setNameFormat(’emailaddress’);
setAttribute(«NameID», LoginUser.Get(«userprincipalname»));
Which will allow the Centrify IdP to release an AttributeStatement with the User ID in the SAML POST.
The Centrify IdP user that was created can now login to Blackboard Learn via SAML by selecting that authentication provider on the login page, and logout of Blackboard Learn using the extra End SSO Session logout button on the End all sessions? page that is displayed after selecting the logout button at the top right of Blackboard Learn.
Change text on End SSO Session logout page
An institution may inquire if it is possible to change the text on the End SSO Session logout page. It is possible to change the text on the End SSO Session logout page by editing the Language Pack:
- Open the Language Pack file.
- Navigate to auth-provider-saml/src/main/webapp/WEB-INF/bundles/bb-manifest-en_US.properties .
- Update the Message Keys:
saml.single.logout.warning.conent.description // the first line
saml.single.logout.warning.conent.recommend // second line
saml.single.logout.warning.endsso.title // third line
saml.single.logout.warning.endsso.button // the button
saml.single.logout.warning.backtolearn // the cancel button
Redirect users to the IdP login page
The standard Blackboard Learn login page presents username and password fields for the default Learn Internal authentication provider. When you enable SAML authentication, a small «Sign in using. » link for SAML appears at the bottom of this page, so you may want to redirect users to the IdP’s authentication server automatically when they access the Learn login page.
One option to accomplish this is to navigate to System Admin > Authentication and set the default Learn Internal authentication to Inactive, which means a login page is no longer displayed, and immediately the user is redirected to the SAML login. The problem with that option is that it overrides the default login URL and prevents any non-SAML user to login.
To avoid this issue and provide almost the same result, use a Custom Login Page. Users are redirected to the SAML authentication provider’s IdP login page, but the default login link is also usable.
- Ensure the default Learn Internal authentication is active
- On the default login page, copy the location of the provider redirect e.g. Sign in using. SAML. Right-click on the link and select Copy Link Location .
- Navigate to System Admin > Communities > Brands and Themes > Customize Login Page.
- Select Download next to Default Login Page to download the default login JSP file.
- Open the JSP file with a text editor. Add the following sample HTML to the login JSP file and replace the URL text with the URL that was copied in Step 2.
Blackboard Learn — Redirect
Redirecting. Go to login page if you are not automatically redirected.
Источник
При возникновении ошибок, связанных с SAML (языком разметки декларации безопасности), следуйте инструкциям ниже.
Как кодировать или декодировать запросы и ответы SAML
Чтобы вам было проще устранять неполадки, воспользуйтесь инструментом кодирования и декодирования для обработки запросов и ответов SAML из файла в формате HTTP Archive Format (HAR) в словесной форме.
Ошибки при добавлении приложения SAML
При добавлении приложения SAML в консоль администратора может возникнуть ошибка 400.
400 неуникальный идентификатор объекта
Это сообщение появляется, когда вы пытаетесь добавить приложение с уже существующим идентификатором объекта.
Чтобы исправить эту ошибку, выполните следующие действия:
Используйте уже настроенное приложение или укажите другой идентификатор объекта.
500 ошибки при создании приложения SAML
При добавлении SAML-приложения в консоли администратора вы можете столкнуться с ошибками 500. Они появляются в следующих случаях:
- В разделе Сведения о поставщике идентификационной информации Google вы нажали кнопку Скачать сертификат или Скачать метаданные, когда сервер сертификатов был недоступен.
- Во время загрузки схемы при сопоставлении идентификатора названия или атрибута, если превышено время ожидания отклика от сервиса схем или возникли ошибки на сервере.
- Сервис настройки поставщика услуг недоступен. Ошибка 500 возникает на последнем этапе, когда вы нажимаете Готово.
Чтобы устранить ошибки 500 при добавлении SAML-приложения:
При возникновении этих проблем подождите немного и повторите попытку. Если ошибку устранить не удалось, обратитесь в службу поддержки Google Cloud.
Ошибки выполнения SAML
Если в ходе процессов, запущенных поставщиком услуг или поставщиком услуг идентификации (IdP), вы использовали систему единого входа на базе SAML, могут возникнуть следующие ошибки:
403 app_not_configured (приложение не настроено)
Эта ошибка может появиться в следующих случаях:
-
Приложение, соответствующее указанному в запросе идентификатору объекта, не было добавлено в консоль администратора.
- Идентификатор объекта, указанный в запросе SAML, не соответствует ни одному из идентификаторов для существующих приложений. Если кто-либо исказил идентификатор приложения, указанный в URL от поставщика услуг идентификации, вы увидите ошибку
app_not_configured
.
Чтобы устранить эту ошибку, выполните следующие действия:
- Убедитесь, что приложение, соответствующее идентификатору объекта в запросе, было установлено до отправки этого запроса.
- Удостоверьтесь, что идентификатор объекта в запросе SAML указан правильно и соответствует выбранному приложению.
- Убедитесь, что идентификатор поставщика услуг в URL запроса соответствует значению, указанному для приложения.
403 app_not_configured_for_user (приложение не настроено для пользователя)
Чтобы устранить эту ошибку, выполните следующие действия:
Убедитесь, что значение тега saml:Issuer в запросе SAML совпадает со значением идентификатора объекта, заданным для SAML-приложения в разделе Сведения о поставщике услуг консоли администратора. Значение чувствительно к регистру.
403 app_not_enabled_for_user (приложение не включено для пользователя)
Чтобы устранить эту ошибку, выполните следующие действия:
- В списке приложений найдите SAML-приложение, из-за которого возникает ошибка.
- Нажмите на его название, чтобы открыть страницу настроек.
- Выберите Доступ пользователей.
- Включите приложение для всех пользователей или для нужного организационного подразделения.
400 saml_invalid_user_id_mapping (неправильное сопоставление имени пользователя в SAML)
Если в запросе SAML поставщик услуг отправил параметр Идентификатор названия, он должен соответствовать значению, указанному на стороне поставщика идентификационной информации. В противном случае система выдаст ошибку.
Чтобы исправить эту ошибку, выполните следующие действия:
- Откройте раздел Основные сведения и проверьте параметр Идентификатор названия.
- Убедитесь, что он соответствует значению запроса SAML, указанному на стороне поставщика идентификационной информации.
400 saml_invalid_sp_id (SAML неправильный идентификатор поставщика услуг)
Ошибка возникает, если идентификатор поставщика услуг в URL указан неверно, так как был некорректно настроен или подменен.
Чтобы исправить эту ошибку, выполните следующие действия:
-
Откройте раздел Основные сведения и проверьте идентификатор приложения.
-
Убедитесь, что идентификатор поставщика услуг в URL запроса соответствует значению, указанному для приложения.
Иногда в ответ на запрос SAML приходит отказ. В этом случае может появиться одно из трех сообщений об ошибке, указанных ниже.
Недопустимый запрос от поставщика услуг, URL ACS в запросе не соответствует настроенному
Эта ошибка означает, что URL ACS в запросе SAML не соответствует значению, указанному для приложения в консоли администратора.
Чтобы исправить эту ошибку, выполните следующие действия:
-
Перейдите в раздел Сведения о поставщике услуг.
-
Введите URL ACS, который указан в запросе SAML.
Недопустимый идентификатор поставщика услуг идентификационной информации в URL
Указанный в URL идентификатор поставщика идентификационной информации (зашифрованный идентификатор клиента) был искажен и является некорректным.
Чтобы исправить эту ошибку, выполните следующие действия:
-
Перейдите в раздел Безопасность
Настройка системы единого входа для SAML-приложений.
-
В конце URL идентификатора объекта найдите идентификатор поставщика услуг идентификационной информации.
- Убедитесь, что он соответствует идентификатору, указанному в URL запроса.
Недопустимый идентификатор поставщика услуг идентификации в запросе
URL системы единого входа со стороны поставщика услуг идентификации был искажен. Идентификатор поставщика скрытым образом изменен на идентификатор другого клиента.
Чтобы исправить эту ошибку, выполните следующие действия:
-
Перейдите в раздел Безопасность
Настройка системы единого входа для SAML-приложений.
-
В конце URL идентификатора объекта найдите идентификатор поставщика услуг идентификационной информации.
- Убедитесь, что он соответствует идентификатору, указанному в URL запроса.
Ошибки 500 при тестировании системы единого входа на базе SAML
Когда пользователи выполняют аутентификацию в системе единого входа на базе SAML через поставщика услуг или поставщика услуг идентификационной информации, они могут столкнуться с одной из ошибок 500 из-за недоступности сервера.
Чтобы устранить ошибки 500 при тестировании системы единого входа на базе SAML:
При возникновении этих ошибок подождите немного и повторите попытку. Если неполадку устранить не удалось, обратитесь в службу поддержки Google Cloud.
Сообщения об ошибках доступа к приложениям SAML
1000 ошибка доступа к приложению SAML
Чтобы исправить эту ошибку, выполните следующие действия:
Обратитесь в службу поддержки Google Cloud.
1000 ошибка доступа к настройкам приложения SAML
Чтобы исправить эту ошибку, выполните следующие действия:
Обратитесь в службу поддержки Google Cloud.
Сообщение об ошибке в приложении SAML при удалении схемы пользователя
400
Эта ошибка возникает, если вы пытаетесь удалить специальную схему, которая выполняет роль сопоставления атрибутов для удаленного SAML-приложения. Ошибка 400 может возникать, если вы создали схему до устранения этой проблемы.
Чтобы исправить ошибку, выполните следующие действия:
Обратитесь в службу поддержки Google Cloud.
Эта информация оказалась полезной?
Как можно улучшить эту статью?
Обновлено: 08.02.2023
Не открывается, не грузится, не доступен, лежит или глючит?
Что не работает?
Кэш браузера.
Чтобы удалить кэш и получить актуальную версию страницы, обновите в браузере страницу с помощью комбинации клавиш Ctrl + F5.
Блокировка доступа к сайту.
Очистите файлы cookie браузера и смените IP-адрес компьютера.
DNS-кэш.
Очистите DNS-кэш на вашем компьютере и повторите попытку доступа на сайт. Смотреть видео-инструкцию ↓
VPN и альтернативные службы DNS.
VPN: например, мы рекомендуем NordVPN.
Альтернативные DNS: OpenDNS или Google Public DNS.
Плагины браузера.
Например, расширение AdBlock вместе с рекламой может блокировать содержимое сайта. Найдите и отключите похожие плагины для исследуемого вами сайта.
Сбой драйвера микрофона
Быстро проверить микрофон: Тест Микрофона.
или рассказать о сегодняшнем сбое без регистрации
идентификация не требуется
комментарии с нецензурной лексикой и оскорблениями удаляются
Второй день подряд проблемы в системе. И зайти не возможно, и если все же удалось, то каждое действие прогружается до минуты. Как работать-то?!
При возникновении ошибок, связанных с SAML (языком разметки декларации безопасности), следуйте инструкциям ниже.
Как кодировать или декодировать запросы и ответы SAML
Ошибки при добавлении приложения SAML
При добавлении приложения SAML в консоль администратора может возникнуть ошибка 400.
400 неуникальный идентификатор объекта
Используйте уже настроенное приложение или укажите другой идентификатор объекта.
500 ошибки при создании приложения SAML
При добавлении SAML-приложения в консоли администратора вы можете столкнуться с ошибками 500. Они появляются в следующих случаях:
Чтобы устранить ошибки 500 при добавлении SAML-приложения:
При возникновении этих проблем подождите немного и повторите попытку. Если ошибку устранить не удалось, обратитесь в службу поддержки Google Cloud.
Ошибки выполнения SAML
Если в ходе процессов, запущенных поставщиком услуг или поставщиком услуг идентификации (IdP), вы использовали систему единого входа на базе SAML, могут возникнуть следующие ошибки:
403 app_not_configured (приложение не настроено)
Эта ошибка может появиться в следующих случаях:
Приложение, соответствующее указанному в запросе идентификатору объекта, не было добавлено в консоль администратора.
Чтобы устранить эту ошибку, выполните следующие действия:
- Убедитесь, что приложение, соответствующее идентификатору объекта в запросе, было установлено до отправки этого запроса.
- Удостоверьтесь, что идентификатор объекта в запросе SAML указан правильно и соответствует выбранному приложению.
- Убедитесь, что идентификатор поставщика услуг в URL запроса соответствует значению, указанному для приложения.
403 app_not_configured_for_user (приложение не настроено для пользователя)
Чтобы устранить эту ошибку, выполните следующие действия:
Убедитесь, что значение тега saml:Issuer в запросе SAML совпадает со значением идентификатора объекта, заданным для SAML-приложения в разделе Сведения о поставщике услуг консоли администратора. Значение чувствительно к регистру.
403 app_not_enabled_for_user (приложение не включено для пользователя)
Чтобы устранить эту ошибку, выполните следующие действия:
На главной странице консоли администратора нажмите ПриложенияМобильные и веб-приложения.
400 saml_invalid_user_id_mapping (неправильное сопоставление имени пользователя в SAML)
Если в запросе SAML поставщик услуг отправил параметр Идентификатор названия, он должен соответствовать значению, указанному на стороне поставщика идентификационной информации. В противном случае система выдаст ошибку.
- Откройте раздел Основные сведения и проверьте параметр Идентификатор названия.
- Убедитесь, что он соответствует значению запроса SAML, указанному на стороне поставщика идентификационной информации.
400 saml_invalid_sp_id (SAML неправильный идентификатор поставщика услуг)
Ошибка возникает, если идентификатор поставщика услуг в URL указан неверно, так как был некорректно настроен или подменен.
Откройте раздел Основные сведения и проверьте идентификатор приложения.
Убедитесь, что идентификатор поставщика услуг в URL запроса соответствует значению, указанному для приложения.
Недопустимый запрос от поставщика услуг, URL ACS в запросе не соответствует настроенному
Эта ошибка означает, что URL ACS в запросе SAML не соответствует значению , указанному для приложения в консоли администратора.
Перейдите в раздел Сведения о поставщике услуг.
Введите URL ACS, который указан в запросе SAML.
Недопустимый идентификатор поставщика услуг идентификационной информации в URL
Указанный в URL идентификатор поставщика идентификационной информации (зашифрованный идентификатор клиента) был искажен и является некорректным.
Перейдите в раздел БезопасностьНастройка системы единого входа для SAML-приложений.
В конце URL идентификатора объекта найдите идентификатор поставщика услуг идентификационной информации.
Недопустимый идентификатор поставщика услуг идентификации в запросе
URL системы единого входа со стороны поставщика услуг идентификации был искажен. Идентификатор поставщика скрытым образом изменен на идентификатор другого клиента.
Перейдите в раздел БезопасностьНастройка системы единого входа для SAML-приложений.
В конце URL идентификатора объекта найдите идентификатор поставщика услуг идентификационной информации.
Ошибки 500 при тестировании системы единого входа на базе SAML
Когда пользователи выполняют аутентификацию в системе единого входа на базе SAML через поставщика услуг или поставщика услуг идентификационной информации, они могут столкнуться с одной из ошибок 500 из-за недоступности сервера.
Чтобы устранить ошибки 500 при тестировании системы единого входа на базе SAML:
При возникновении этих ошибок подождите немного и повторите попытку. Если неполадку устранить не удалось, обратитесь в службу поддержки Google Cloud.
1000 ошибка доступа к приложению SAML
1000 ошибка доступа к настройкам приложения SAML
Эта ошибка возникает, если вы пытаетесь удалить специальную схему, которая выполняет роль сопоставления атрибутов для удаленного SAML-приложения. Ошибка 400 может возникать, если вы создали схему до устранения этой проблемы.
При выполнении очередного госзаказа наша команда столкнулась с проблемой интеграции сайта с ЕСИА. Инструкции по решению этой задачи в сети нет, кроме информации в официальных документах МинКомСвязи (примерно 300 страниц в трех регламентах). Также есть компании, которые оказывают платные услуги по интеграции ЕСИА. Мы реализовали, описали процесс интеграции и решили поделиться с сообществом habrahabr.
Что такое ЕСИА
Единая Система Идентификации и Аутентификации — российская информациия система, обеспечивающая доступ (регистрация, аутентификация) на сайты государтсвенных структур и некоторых коммерческих организаций. Подробнее на википедии
В процессе интеграции ЕСИА, система сможет отправлять запрос на ЕСИА и при успешной авторизации получать в качестве ответа данные пользователя
Сценарий авторизации выглядит примерно так:
Содержание
- Общие сведения
- Установка SimpleSAMLphp
- Настройка SimpleSAMLphp для подключения к тестовой среде ЕСИА
- Конфигурация файла метаданных
- Отправка заявки в адрес МинКомСвзяи на подключение ИС к тестовой среде ЕСИА
- Функциональная интеграция с ЕСИА и получение данных авторизированных пользователей через ЕСИА
- Отправка заявки на подключение ИС к продуктивной среде ЕСИА
Общие сведения
Подключить ИС к ЕСИА возможно двумя способами:
- Посредством стандарта SAML 2.0
- На базе подхода REST
Если сравнивать 2 подхода, то по факту разницы между ними большой нет, есть несколько плюсов у способа на базе подхода REST. Есть ребята, которые на мой взгляд за немалые деньги подключают ЕСИА и о преимуществах REST они написали тут.
Но для подавляющего большинста случаев первый подход охватывает все необходимые функции. Поэтому расскажу о внедрении ЕСИА посредством SAML 2.0
Установка SimpleSAMLphp
Для интеграции будем использовать SimpleSAMLphp. Если система, которую вы настраиваете написана не на PHP, то все равно можно использовать этот модуль, просто на вашем сайте будет функция аутентификации реализована на php, данные от ЕСИА вы получите в xml формате.
Последняя официальная версия SimplSAMLphp доступна на официальном сайте SimpleSamlPHP. Скачиваете архив, распаковываете модуль в папку /var.В целях безопасности для папки с разархивированным модулем необходимо настроить права доступа только для root пользователя. В конфигурации сервера необходимо добавить алиас и следующие правила:
Суть в том, чтобы по запросу ServerName/simplesaml открывалась приветственная страница simplesaml. Если вы все сделали правильно, то по запросу ServerName/simplesaml вы увидите такую страничку
Настройка SimpleSAMLphp для подключения к тестовой среде ЕСИА
Для интеграции необходимы сертификат ( cert.crt ) и ключ ( key.key ). Важно(!) с ГОСТовским сертфикатом ничего не выйдет, можно получить бесплатный сертификат, погуглив как это делается, либо выпустить сертификат самому. Ключ и сертификат кладем в папку simplesamlphp/cert
Для конфигурации SimpleSAMLphp необходимо отредактировать следующие файлы:
- simplesamlphp/config/config.php
- simplesamlphp/config/authsources.php
- simplesamlphp/metadata/saml20-idp-remote.php
Важное замечание — время на сервере не должно отличаться от времени ЕСИА больше 1 минуты.
Важно знать, есть ли у системы entityID, если его нет, то в поле ‘entityID’ необходимо указать адрес системы
Теперь надо получить подпись для нашего сертификата (fingerprint). Это можно сделать в терминале одной из команд
- openssl x509 -noout -fingerprint -in «cert.crt» SHA1
- sha1sum cert.crt
Конфигурация файла метаданных
Файл метаданных доступен по ссылке: ServerName/simplesaml/module.php/saml/sp/metadata.php/esia?output=xhtml
Пример файла метаданных:
Но, к сожалению, SimpleSaml формирует файл метаданных, который немного отличается от требования ЕСИА, поэтому необходимо его подкорретировать в соотвествии с рекомендациями пункт А.6 Шаблон файла метаданных
Пример файла метаданных, удовлетворяющий требованиям ЕСИА, может скачать по ссылке example.xml
Отправка заявки в адрес МинКомСвзяи на подключение ИС к тестовой среде ЕСИА
- скан заявки в формате pdf,
- сертификат в формате crt
- файл метаданных xml
Функциональная интеграция с ЕСИА и получение данных авторизированных пользователей через ЕСИА
Проверить подключения ИС к тестовой среде можно по ссылке
ServerName/simplesaml/module.php/core/authenticate.php?as=esia .
Теперь напишем скрипт, который будет обрабатывать данные. Для начала добавим кнопку для авторизации на сайт.
Обработчик inc/esia.php . Тут мы получаем данные и можем записать их в базу, добавить в сессию и т.д. Вообще надо правильно парсить xml. Сейчас просто выведем данные на экран.
Отправка заявки на подключение ИС к продуктивной среде ЕСИА
В файлах simplesamlphp/config/authsources.php , simplesamlphp/metadata/saml20-idp-remote.php необходимо заменить idp поставщика услуг с Тестовой среды на продуктивную:
Теперь формируем новый файл метаданных, по факту меняются только ссылки в полях Service
- Новый файл метаданных
- Заявку по форме М
На момент написания статьи актуальная версии Регламента — 2.7. При обновлении регламента возможны некоторые изменения во взаимодействии ИС с ЕСИА.
Ниже приведены ответы на распространённые вопросы, которые возникают у пользователей при настройке и обслуживании Smartsheet, а также при входе с использованием функции единого входа на базе SAML. Узнайте больше о настройке и поддержке SAML в статье Обзор SAML и функции единого входа для Smartsheet.
Ниже перечислено несколько возможных причин.
- В вашем браузере сохранены устаревшие данные для входа. Очистите кэш и файлы cookie в браузере и попробуйте войти снова.
- Возможно, профиль поставщика удостоверений, используемый вами для проверки подлинности, еще не добавлен, или требуется его обновление. Попросите администратора поставщика удостоверений или ИТ-специалистов своей организации проверить, поступила ли информация о вашем профиле поставщику удостоверений.
- Возможно, вас не добавили в учётную запись, с которой связан ваш домен. Попросите своего системного администратора добавить вас в учётную запись.
Вы можете обновить информацию о своих сертификатах в Smartsheet с помощью процедуры, описанной в статье Замена просроченного SAML-сертификата поставщика удостоверений. Учтите, что перед внесением изменений в Smartsheet у вас уже должен быть новый сертификат, сгенерированный вашим поставщиком удостоверений.
- Убедитесь, что устройство, с которого вы пытаетесь войти, подключено к внутренней сети вашей компании.
- Если для подключения к корпоративной сети вы используете VPN, убедитесь, что этот сервис запущен и подключение установлено.
Почему мне недоступна функция обновления метаданных поставщика удостоверений в Smartsheet?
Если вы используете тот же идентификатор сущности в другой учётной записи Smartsheet, вы не сможете изменить эти метаданные. Системный администратор второй учётной записи Smartsheet должен выполнить процедуру Замена просроченного SAML-сертификата поставщика удостоверений, чтобы обновить метаданные для всех её пользователей.
Уточнить администратора второй учётной записи Smartsheet можно в нашей службе поддержки.
На этом этапе ошибка вызвана соответствующими проблемами в метаданных. Ниже приведено несколько примеров возможных ошибок.
- Не удалось выполнить проверку DNS. Убедитесь в том, что запись DNS распространилась, и повторите попытку.
- Домен уже связан с поставщиком удостоверений
- Отсутствуют метаданные SAML
Свяжитесь с администратором поставщика удостоверений и попросите его настроить запросы метаданных, а затем повторите процедуру настройки SAML. Пример утверждения и полный список поддерживаемых форматов запросов см. в статье Примеры настроек и запросов для протокола SAML в Smartsheet.
Как добавить домен поставщику удостоверений в Smartsheet?
Если у вас активировано больше одного поставщика удостоверений, вы можете добавлять этим поставщикам домены, чтобы все пользователи указанного домена проходили проверку подлинности через определенного поставщика удостоверений. Пользователи, которые не соответствуют указанному домену, будут проходить проверку подлинности через поставщика по умолчанию.
BlooDy писал(а): Пишу чисто поржать, сегодня приверно в 5:30-5:45 по мск, все заработало. Я немного ох***л от такого счастья, что же думаю за ночь такого случилось. Решил проверить, сохранил настройки, скинул все настройки IE11 в дефолт, даже удалил закупки.гов.ру из доверенных, и о чудо, работает. Без настроек IE СОВСЕМ!
P.S. Е**ло мне голову начальство целую неделю этим, я е**л голову себе, а оказалось просто у рукожопов что-то не работало(не было обновлено и т.д.), и ладно бы сказать типа потерпите ребята о проблеме знаем — занимаемся. Делал 4 заявки в саппорт, ничего кроме «еще раз проверьте/скиньте настройки IE» не услышал. Мало того они эти заявки даже не читают, отписывают боты видимо пользователям. Писал в заявке «антивирус удален», в ответе — отключите антивирус Это просто пи***ц
Машины времени есть у каждого. Те, что переносят в прошлое, зовутся воспоминаниями, а те, что уносят в будущее — мечтами ©
APXAPOBETC писал(а): Тоже сейчас пытаюсь зарегистрироваться, впервые, в качестве ИП. В самом начале, на этапе подтверждения того, что я действительно хочу зарегистрироваться, меня выбрасывает на страницу ошибки: «Не удается открыть эту страницу. Убедитесь, что веб-адрес https://eruz.zakupki.gov.ru правильный». Поддержка ЕИС ничего не отвечает пока что, жду. Торги стоят ((( Использую IE11. Может, кто-то сталкивался с таким?
Временное явление, скорее всего. Надеюсь, уже исправили.
Если нет, то проверяйте, что у Вас указано в адресах DNS-серверов и как эти сервера работают. Возможно, глючит локальная сеть.
Машины времени есть у каждого. Те, что переносят в прошлое, зовутся воспоминаниями, а те, что уносят в будущее — мечтами ©
Ошибка регистрации сертификата по госту 2012
Добрый день, коллега.
Вам бы азы работы в ЕИС поизучать, дабы таких глупостей не совершать.
Сертификат регистрируется в администрировании, а не при входе. При входе было аж 4 года назад.
Читайте FAQ в данном разделе.
П.С. Надеюсь, Вы прохожий заказчик, а не прохожий поставщик.
Машины времени есть у каждого. Те, что переносят в прошлое, зовутся воспоминаниями, а те, что уносят в будущее — мечтами ©
Читайте также:
- Подготовьте и запишите сообщение о том какие способы использовали люди для общения
- В какой сфере легче сделать карьеру сообщение
- Основание баргузинского острога сообщение
- Вымершие животные по вине человека сообщение
- Сообщение о новочебоксарске кратко
Introduction
This document describes an issue where you receive an «HTTP Status 401» error message after a period of inactivity when you use Single Sign-On (SSO).
Prerequisites
Requirements
Cisco recommends that you have knowledge of these topics:
- SSO
- Active Directory Federation Service (AD FS)
- CloudCenter
Components Used
This document is not restricted to specific software or hardware versions.
The information in this document was created from the devices in a specific lab environment. All of the devices used in this document started with a cleared (default) configuration. If your network is live, make sure that you understand the potential impact of any command.
Problem
When you use SSO, you can receive a «401» error after a period of inactivity, instead of a prompt to log in again as shown in the image.
The only way for you to be able to log in again is to close the entire web browser and reopen it.
Solution
This is caused by a mismatch in the timeout values between CloudCenter and the SSO server.
An enhancement allows the ForceAuthn Parameters support, which can allow a mismatch between the two values and CloudCenter to log out gracefully. This enhancement can be tracked here https://bst.cloudapps.cisco.com/bugsearch/bug/CSCvg36752.
The only workaround is to remove the mismatch. There are three locations where the timeout values need to match. The first two are on the CCM itself.
- Navigate to /usr/local/tomcat/webapps/ROOT/WEB-INF/web.xml.
- Modify the <session-timeout>time_In_Minutes</session-timeout> to reflect the timeout desired in minutes.
- Navigate to /usr/local/tomcat/webapps/ROOT/WEB-INF/mgmt.properties.
- Modify the saml.maxAuthenticationAge.seconds=timeout_in_seconds to reflect the timeout desired in seconds.
The third is on the SSO server and the location can vary which depends on what type of SSO server is running. The web SSO lifetime value must match the two values configured on CloudCenter.
Once all three match, when the timeout has occurred, you are dropped back to the log in screen before allowed to view the page.
Цитата | ||
---|---|---|
МихаилИгоревич пишет:
Добрый день! |
На сайте ГИС ЖКХ / Регламенты и инструкции / Ресурсоснабжающие организации / Проект шаблона импорта ЛС в версию 8.7.0
Цитата |
---|
На сайте ГИС ЖКХ / Регламенты и инструкции / Ресурсоснабжающие организации / Проект шаблона импорта ЛС в версию 8.7.0 |
Это же только проект, ждем обновления 8.7 или кто то умудрился загрузить этот шаблон?
Цитата |
---|
ecoins77 пишет: Всем доброго дня. Подскажите, что за «Доля внесения платы, размер доли в %» в шаблоне ЛС? |
Это если 1 собственник, то ставиться 100%.
Я лично везде ставлю 100 %, а где разделение счетов то по площади ЛС высчитываю % внесения платы, только не уверена, что это так должно быть.
Цитата | ||||
---|---|---|---|---|
ecoins77 пишет:
На сайте ГИС ЖКХ / Регламенты и инструкции / Ресурсоснабжающие организации / Проект шаблона импорта ЛС в версию 8.7.0 |
Как и говорят, это «ПРОЕКТ». Он сделан для определения, подготовки и структурирования информации. Потом эту информацию можно будет жик-жик и быстренько загрузить))
Цитата |
---|
Как и говорят, это «ПРОЕКТ». Он сделан для определения, подготовки и структурирования информации. Потом эту информацию можно будет жик-жик и быстренько загрузить)) |
Ну хоть вы повеселили , как правило новый шаблон без бубна с гармошкой не грузится, я сначала добьюсь нормальной загрузки (методом тыка) а уж потом буду заполнять.
Московская область! Письмо счастья пришло?
Цитата |
---|
olynka1403 пишет: Московская область! Письмо счастья пришло? |
А вот интересно , предлагаемые вам шаблоны сильно отличаются от шаблонов на ГИС ЖКХ ? можете сказать
Отправлено спустя 2 минуты 28 секунды:
Цитата |
---|
ktlty пишет: кто уже размещал работы покажите скриншот |
А мы решили дождаться обновления версии и обновления Справочника типовых работ , который обещали изменить в соответствии с 290 постановлением
Цитата |
---|
olynka1403 пишет: Московская область! Письмо счастья пришло? |
Сами шаблоны в студию! Пожалста!
Цитата |
---|
nsk31129 пишет: А мы решили дождаться обновления версии и обновления Справочника типовых работ , который обещали изменить в соответствии с 290 постановлением |
Кто и когда обещал? огласите весь текст обещания, пожалуйста! вчера в тех поддержку только звонила по этому вопросу, ничего подобного не сказали…
Цитата | ||
---|---|---|
Klever пишет:
Кто и когда обещал? огласите весь текст обещания, пожалуйста! вчера в тех поддержку только звонила по этому вопросу, ничего подобного не сказали… |
Вот письменный ответ от поддержки :
Обращение №30568 от 22.04.2016 по вопросу Вопрос по законодательству
Уважаемый пользователь!
В следующих версиях системы будет выполнено обновление справочника «Работы и услуги организации» в соответствии с Постановлением Правительства РФ от 03.04.2013 N 290 «О минимальном перечне услуг и работ, необходимых для обеспечения надлежащего содержания общего имущества в многоквартирном доме, и порядке их оказания и выполнения».
Обращаем Ваше внимание, что после выхода каждой новой версии Системы, на портале ГИС ЖКХ публикуется информация о реализованных функциональных возможностях системы в соответствии с номером версии.
Отслеживать изменения возможно в разделе «Регламенты и инструкции» по ссылке
http://dom.gosuslugi.ru/#/regulations
в подразделе «Журнал версий».
Для сохранения истории взаимодействия при последующей переписке по данному запросу просим Вас сохранять тему письма. При возникновении новых вопросов просьба направлять новое обращение по «Форме заявки в службу поддержки». Благодарим за обращение в службу технической поддержки Портала ГИС ЖКХ!
С уважением,
Служба технической поддержки
ГИС ЖКХ
Это что такое? Кто подскажет
Цитата |
---|
Башкирия пишет: Это что такое? Кто подскажет |
У всех такое, говорят. что с крипто про связанно, я жму кнопку принять и работаю!
Кто что делает с номерами приборов учета? ходить по квартирам переписывать не вариант, документов на все счетчики нет, придумывать свои?
Цитата | ||
---|---|---|
МихаилИгоревич пишет:
Сами шаблоны в студию! Пожалста! |
Очень хочется на это посмотреть. Пожалуйста прикрепите если возможно. Нам это счастье еще не прислали. Зато срочно требуют заполнить АИС ГЖИ Дома Подмосковья .
По лицевым счетам думаю нет причин торопиться — там отсутствует один показатель, который будет дополнен и который очень сильно повлияет на трудоёмкость. Я пока просто готовлю первичку.
По «Работы и услуги организации» — спорно. Для реализации 290 там существует другой справочник связанный с указанным вами. Представить себе перечень на 300+ строк для утверждения собственниками получается с трудом.
Цитата |
---|
Егор пишет: По лицевым счетам думаю нет причин торопиться — там отсутствует один показатель, который будет дополнен и который очень сильно повлияет на трудоёмкость. Я пока просто готовлю первичку. По «Работы и услуги организации» — спорно. Для реализации 290 там существует другой справочник связанный с указанным вами. Представить себе перечень на 300+ строк для утверждения собственниками получается с трудом. |
По поводу подготовки к внесению перечня работ и услуг , Типовой справочник ГИС ограничен , работ не хватает ,а вносить новые — нельзя , как быть ? Нужно же составить соответствие работ один в один со своей инф.системой , может быть новая версия и новый справочник поможет решить эту задачу
Справочников будет 3.
1. Обязательные работы — по законодательству. (править нельзя)
2. Типовые работы (связан с 1). (править нельзя)
3. Пользовательские работы (связан с 1) — любые работы сделанные как на основании типовых так и полностью с нуля правятся организацией.
Отправлено спустя 45 секунды:
Цитата |
---|
olynka1403 пишет: Московская область! Письмо счастья пришло? |
Очень хочу получить приложения к этому письму. Срочно. У кого есть пришли пожалуйста.
Цитата |
---|
Серега жкх пишет: Добрый всем день! Помогите, пожалуйста, при входе в систему на организацию появляется Request failed The request failed. The reason is: Unable to validate SAML message! Stacktrace: |
Кто-нибудь поможет или ни у кого такого не было?
Цитата |
---|
Егор пишет: По лицевым счетам думаю нет причин торопиться — там отсутствует один показатель, который будет дополнен и который очень сильно повлияет на трудоёмкость. |
Что это за показатель такой если не секрет?
Только решусь что нибудь заполнить, а там все сыро…
Вот шаблоны которые мне прислали… Такое ощущение что все они из разных версий ГИС ЖКХ…
Цитата | ||
---|---|---|
platinum09 пишет:
Что это за показатель такой если не секрет? |
Кадастровый номер помещения
Цитата |
---|
Егор пишет: Кадастровый номер помещения |
Да ладно…. Он че обязательный будет??? Заняться больше нечем росреестр перерывать
Фу на этот ГИС
Не зайти в Гис, только грузит, у Вас также? снова видать какие то разработки.
Цитата |
---|
nika пишет: Не зайти в Гис, только грузит, у Вас также? снова видать какие то разработки. |
и вчера так же было, каждое утро как наркоман несусь смотреть на обновление системы и облом
издеваются. Как можно заставлять вносить данные, если проект не доработан и постоянно глючит?
А может кто-нибудь сказать, что должно быть точно внесено до 1.07.2016г?!
обычный пользователь видит только дома и квартиры.