Content Security Policy directive: "frame-ancestors 'self'

前端 未结 2 1968
眼角桃花
眼角桃花 2020-12-31 00:46

I am embedding an iFrame in my web page, something like this:

var iframeProps = {
        \'data-type\': self.props.type,
        allowTransparency: self.pro         


        
相关标签:
2条回答
  • 2020-12-31 00:55

    The content is prohibited from being displayed within an IFRAME due the Content Security Policy being set. The webserver hosting twitter.com is configured to add a HTTP header to the response object. Specifically they are setting the Content-Security-Policy tag to frame-ancestors 'self'. There is no way you'll be able to embed their pages into a page of your own using IFRAME. There are other techniques that you could use to work around that, but none are as simple as an iframe tag.

    W3C Content Security Policy Level 3 - Frame Ancestors

    0 讨论(0)
  • 2020-12-31 00:57

    I encountered with this problems recently too and i didn't find any alternative method to solve that.Finally, I came up with idea that the attribute in the iframe,which is "src",can be filled with the origin html content and it works.

    // this demo shows the process of getting the html content 
    // from the link,and then apply it to the attribute "src" in the iframe
    $.get(link, function (response){ 
    var html = response;
    var html_src = 'data:text/html;charset=utf-8,' + html;
    $("#iframeId").attr("src" , html_src);
    });

    0 讨论(0)
提交回复
热议问题