Embedding YouTube videos on Azure Static Web Apps
I tried embedding a YouTube video on a page hosted on Azure Static Web Apps, but saw a "Video unavailable" error:
data:image/s3,"s3://crabby-images/26acb/26acb3242b52b97f2f744abb4b3ff48a845ca416" alt=""
I tried the same embed code locally and on another site, and it worked in both places. After much digging, I found that this had to do with the default Referrer Policy set by Azure Static Web Apps:
data:image/s3,"s3://crabby-images/907a6/907a618befa1db29b1a5bd7225ce00749db38988" alt=""
Referrer-Policy: same-origin
would cause the browser to skip the Referer
header for YouTube (i.e. cross-origin) requests. And it turns out, YouTube does not like that!
To fix this, override the default Referrer-Policy
by creating a staticwebapp.config.json
in the repository root:
{
"globalHeaders": {
"Referrer-Policy": "strict-origin-when-cross-origin"
}
}
That should update the header correctly:
data:image/s3,"s3://crabby-images/2338a/2338a5ce294a5996741bb148823900aba6f48208" alt=""
And the YouTube embed should now work like it should:
data:image/s3,"s3://crabby-images/695ea/695eaabfdd88fa7d769bd12c6943a38aba383f24" alt=""