There is a page index.html in domainA, and a page other.html in domainB is nested through an iframe Since the other.html page is displayed in an iframe, and its page content will increase or decrease dynamically, now you need to remove the iframe The scroll bar Due to the restrictions of the JavaScript same-origin policy, cross-domain operations cannot be performed, which makes the problem more difficult Referring to the online practice, an agent page, or called intermediary agent.html, is introduced, which belongs to domainA Then, in other.html in domainB, use iframe to nest agent.html
Okay, now the situation is like this:
index.html Use iframe to embed Nest other.html other.html Use iframe to nest agent.html The reason why the third page agent.html is introduced is to comply with the rules of the "same origin policy" and complete the transfer of parameters under different domains !
Our ultimate goal is to remove the scroll bar and ensure that all embedded page content is displayed 1. Get the actual height of the other.html page 2. Set the height to On the src attribute of the embedded iframe 3. Intercept the height value in the src attribute of the iframe in agent.html
In the following example, a trick is used to avoid using setInterval( ) Constantly set the height of the iframe The method is to attach a timestamp to the src of the iframe, so that the browser reloads agent.html every time Then let the js function invokeMethodInTopWindow() in agent.hml get Execute 2 html in domainA
Window adaptation---bypassing the restrictions of the same-origin policy, and at the same time using the same-origin policy to remove the scroll bar of the iframe and dynamically adjust the height of the window so that it can Display all content of the nested page
For example, a hacker program uses IFrame to embed the real bank login page on his page. When you log in with your real username and password At this time, his page can read the input content in your form through Javascript, so that the username and password can be easily obtained. For example, a hacker program uses IFrame to embed the real bank login page into his page. When you log in with your real username and password, his page can read you through Javascript. The content of the input in the form, so that the user name and password can be easily obtained. For example, a hacker program uses IFrame to embed the real bank login page into his page. When you log in with your real username and password, his page can read you through Javascript. The content of the input in the form, so that the user name and password can be easily obtained. For example, a hacker program uses IFrame to embed the real bank login page into his page. When you log in with your real username and password, his page can read you through Javascript. The content of the input in the form, so that the user name and password can be easily obtained. For example, a hacker program uses IFrame to embed the real bank login page into his page. When you log in with your real username and password, his page can read you through Javascript. The content of the input in the form, so that the user name and password can be easily obtained. For example, a hacker program uses IFrame to embed the real bank login page into his page. When you log in with your real username and password, his page can read you through Javascript. The content of the input in the form, so that the user name and password can be easily obtained. For example, a hacker program uses IFrame to embed the real bank login page into his page. When you log in with your real username and password, his page can read you through Javascript. The content of the input in the form, so that the user name and password can be easily obtained. For example, a hacker program uses IFrame to embed the real bank login page into his page. When you log in with your real username and password, his page can read you through Javascript. The content of the input in the form, so that the user name and password can be easily obtained.
Statement:
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn