Calling all developers! We invite you to provide your input on Feature Experimentation by completing this brief survey.
Calling all developers! We invite you to provide your input on Feature Experimentation by completing this brief survey.
Not sure if this will work. But this is what we used to do on our projects. I saw you have things in lower case, may not work everywhere unless you are on Windows OS. Try using rule AddCrossDomainHeader
<rewrite>
<rules configSource="Config\System.WebServer.RewriteRules.config"/>
<outboundRules>
<clear/>
<rule name="AddCrossDomainHeader">
<match serverVariable="RESPONSE_Access_Control_Allow_Origin" pattern=".*"/>
<conditions logicalGrouping="MatchAll" trackAllCaptures="true">
<add input="{HTTP_ORIGIN}" pattern="(http(s)?://((.+\.)?xxxxx.b2clogin\.com|(.+\.)?xxxxx.b2clogin\.com|(.+\.)?login.microsoftonline\.com))"/>
</conditions>
<action type="Rewrite" value="{C:0}"/>
</rule>
</outboundRules>
</rewrite>
Not sure if Access-Control-Allow-Origin value can be {HTTP_ORIGIN}, it should either * or it should be static domain values.
<httpProtocol>
<customHeaders>
<add name="Access-Control-Allow-Origin" value="*" />
<add name="Access-Control-Allow-Headers" value="Origin, X-Requested-With, Content-Type, Accept" />
<add name="Access-Control-Allow-Credentials" value="true" />
<add name="Access-Control-Allow-Methods" value="GET,PUT,POST,DELETE" />
</customHeaders>
</httpProtocol>
Hi,
I am currently working on a React application that uses the Fetch API to retrieve documents stored in Episerver. However, we are encountering CORS errors. We have tried several methods using the Web.config file, but they haven't resolved the issue. Below are the approaches we’ve attempted:
1- Modifying Custom Headers and Rewrite Rules for Outbound Traffic in Web.config:
We modified the Web.config file to add CORS headers, but this approach did not work as expected. The XML changes are provided below. Unfortunately, this method did not resolve the issue.
2- Using the CORS Module in Web.config:
I installed the CORS module and configured it based on the cors-module-configuration-reference
The configuration is provided below. However, this approach caused issues, and the application stopped functioning as expected.
3- Additional Rewrite Rule in Web.config:
I attempted another rewrite rule in the Web.config file, but it didn’t resolve the CORS issue. Below is the configuration I used.
This approach only includes Header &Methods. Origin is missing in the response header which is why CORS fails.
4- Current Workaround:
As a temporary solution, I have enabled CORS at the WebApp level via the Azure Portal. Please refer to the attached screenshot for more details.
However, the issue with this workaround is that, since I only have access to the lower environments, I can make this change there. But for the business testing and production environments, which are managed by Optimizely, they will not implement this change. Here is the response I received from Optimizely regarding enabling CORS and adding the necessary domains to the production and business test environments:
Optimizely's Response:
"CORS is not a feature that can be configured on the DXP platform. This was a decision made by the product team, and the configurations must be done within the code base."
I would like to know if there is a more efficient way to configure CORS in Episerver 11 for specific domains only. While I am aware that Episerver 12 provides built-in settings for configuring CORS, I am specifically looking for a solution for Episerver 11.
Regards.