努力載入中

rails app(web) 嵌入到 iframe 中

2024-10-05

假設我的 ruby on rails web 的 domain 為 example.localhost,當我想要在 foo.localhost 中嵌入 iframe 連到 example.localhost 時,會獲得以下錯誤訊息:

Refused to display 'example.localhost'; in a frame because it set 'X-Frame-Options' to 'sameorigin'.

這是因為 rails 預設 response 的 http headers 中,X-Frame-Options 的值為 sameorigin。
查詢 X-Frame-OptionsMDN 文件,其值只有 sameorigin 或 deny 兩種。
因此解決辦法為,直接在 rails 端刪掉 X-Frame-Options。 

# xxx_controller.rb
response.headers.delete 'X-Frame-Options'

另外,從 MDN 文件中可知 X-Frame-Options 在未來將會停用。
取而代之的是在 http headers 中的 Content-Security-Policy 加入 frame-ancestors 相關參數

相關文章

設定電子郵件 DKIM

設定電子郵件 DKIM

以 AWS SES 和 Gmail 為例,說明如何設定 DKIM,並且提供相關檢測工具。DKIM 除了需要透過 DNS TXT 設定完,需要先申請好簽署用的金鑰。
正念冥想使用心得

正念冥想使用心得

在實行正念冥想後一年半的日子裡,所獲得的體悟,以及對生活和工作上的改變,同時分享正念冥想的一些小技巧。
用 AWS Transfer + S3 架設 FTP

用 AWS Transfer + S3 架設 FTP

本篇文章將一步步教學如何利用 AWS 架設 FTP,使用的服務包含 AWS Transfer 、S3、SNS(Simple Notification Service)。實現檔案傳輸,以及被動獲得檔案上傳的通知。
Sidekiq 介面壞掉

Sidekiq 介面壞掉

很久以前修過的問題,再次出現時,又忘了為何如此,所以這次完整把 Sidekiq web 介面遇到的壞掉問題修復方式完整記錄起來。