我知道这个问题有一个简单的解决办法,但相信我现在找不到它。无论如何,我的问题是我必须从Iframe拖动图像(内容来自另一个域)并放入图像占位符。该演示位于
http://popupbuilder.webege.com/IframeDragDropadil/
只有当Iframe从同一个域加载内容时,才应该将图片拖到框中并且它很好地放在那里。但是,如果我从其他域加载内容,就像我在演示中所做的那样(^链接已在上面提供),整个过程都不起作用。
现在我知道这是一个跨域问题。您不能只将来自其他域的数据操作到iframe中。够公平!!
所以我遇到了另一个想法,即通过PHP将整个页面复制到您的服务器,然后将其提供给iframe。听起来很有希望,但PHP功能
<?php file_get_contents(); ?>
只返回html而不是完整的网页。同样,这会破坏整个可用性概念,因为用户不会知道要拖动什么。
最后一件事,如果我将图像从另一个浏览器窗口拖放到此占位符,它就可以了!我不知道iframe导致了什么问题以及如何解决这个问题。
使用PHP在本地服务器上复制整个网站可能是一个解决方案,但我看不出如何!
答案 0 :(得分:0)
经过几天的努力,我已经提出了一个解决方案,它实际上可以帮助我们将事件绑定到Iframe的元素,即使我们打开另一个网站(属于另一个域的网站)。这里最好的选择是将完整的网站代理到我们自己的服务器上并在iframe中打开它。现在我们可以轻松绑定事件并操纵此网站。
请注意,此技术的准确率仅为70-80%。我创建的PHP脚本可能无法始终正确打开网站。有时代理网站的AJAX调用没有完成。但该脚本确实提供了一个很好的起点,欢迎其他开发人员扩展它:)
<?php
$opts = array('http' =>
array(
'method' => 'GET',
//'user_agent ' => "Mozilla/5.0 (X11; U; Linux x86_64; en-US; rv:1.9.2) Gecko/20100301 Ubuntu/9.10 (karmic) Firefox/3.6",
'header' => array(
'Accept: text/html,application/xhtml+xml,application/xml;q=0.9,*\/*;q=0.8
'
),
)
);
function is_url_exist($url){
$ch = curl_init($url);
$status = false;
curl_setopt ($ch, CURLOPT_USERAGENT, "Mozilla/5.0 (Windows; U; Windows NT 5.1; en-US; rv:1.8.1.6) Gecko/20070725 Firefox/2.0.0.6");
curl_setopt($ch, CURLOPT_CONNECTTIMEOUT, 120);
curl_setopt($ch, CURLOPT_TIMEOUT, 120);
curl_setopt($ch, CURLOPT_NOBODY, true);
curl_exec($ch);
$code = curl_getinfo($ch, CURLINFO_HTTP_CODE);
if($code == 200){
$status = true;
}else{
$status = false;
}
curl_close($ch);
return $status;
}
function get_web_page( $url )
{
$user_agent='Mozilla/5.0 (Windows NT 6.1; rv:8.0) Gecko/20100101 Firefox/8.0';
$options = array(
CURLOPT_CUSTOMREQUEST =>"GET", //set request type post or get
// CURLOPT_HTTPGET => true,
CURLOPT_POST =>false, //set to GET
// CURLOPT_USERAGENT => $user_agent, //set user agent
CURLOPT_COOKIEFILE =>"cookie.txt", //set cookie file
CURLOPT_COOKIEJAR =>"cookie.txt", //set cookie jar
CURLOPT_RETURNTRANSFER => true, // return web page
//CURLOPT_HEADER => true, // don't return headers
CURLOPT_FOLLOWLOCATION => true, // follow redirects
CURLOPT_ENCODING => "", // handle all encodings
CURLOPT_AUTOREFERER => true, // set referer on redirect
CURLOPT_CONNECTTIMEOUT => 120, // timeout on connect
CURLOPT_TIMEOUT => 120, // timeout on response
CURLOPT_MAXREDIRS => 10, // stop after 10 redirects
);
$ch = curl_init( $url );
curl_setopt_array( $ch, $options );
$content = curl_exec( $ch );
$err = curl_errno( $ch );
$errmsg = curl_error( $ch );
$header = curl_getinfo( $ch );
curl_close( $ch );
$header['errno'] = $err;
$header['errmsg'] = $errmsg;
$header['content'] = $content;
return $content;
}
function GetDomainFromAddress($url){
$parse = parse_url($url);
$scheme = $parse['scheme'];
$URL = $parse['host']; // prints 'domain.com'
$URL = $scheme.'://'.$URL.'/';
return $URL;
}
/*All functions end here*/
$url=$_GET["url"];
// $url="http://www.topshop.com/en/tsuk/product/new-in-this-week-2169932/new-in-this-week-493/blue-pleat-laceup-kilt-2441152?bi=1&ps=20";
$input= get_web_page($url);
$domain = $url;
$doc = new DOMDocument;
libxml_use_internal_errors(true);
$doc->loadHTML($input);
$tags = $doc->getElementsByTagName('img');
if(count($tags) > 0)
{
foreach ($tags as $tag) {
$src=$tag->getAttribute('src');
if( !empty($src) )
{
if(strpos($src,"https")!==false||strpos($src,'//')!==false || strpos($src,"http")!==false)
{
}
else
{
$src1 = null;
if(!is_url_exist($src))
{
$domain = GetDomainFromAddress($url);
$src1=$domain.$src;
}
$src=$src1;
}
}
$tag->setAttribute('src', $src);
}
}
$tags = $doc->getElementsByTagName('link');
$i=0;
if(count($tags) > 0)
{
foreach ($tags as $tag) {
$src=$tag->getAttribute('href');
if( !empty($src) )
{
if(strpos($src,"https")!==false||strpos($src,'//')!==false || strpos($src,"http")!==false)
{
}
else
{
$src1 = null;
if(!is_url_exist($src))
{ $domain = GetDomainFromAddress($url);
$src1=$domain.$src;
}
$src=$src1;
}
}
$tag->setAttribute('href', $src);
}
}
$tags = $doc->getElementsByTagName('script');
if(count($tags) > 0)
{
foreach ($tags as $tag) {
$src=$tag->getAttribute('src');
if( !empty($src) )
{
if(strpos($src,"https")!==false||strpos($src,'//')!==false || strpos($src,"http")!==false)
{
}
else
{
$src1 = null;
if(!is_url_exist($src))
{ $domain = GetDomainFromAddress($url);
$src1=$domain.$src;
}
$src=$src1;
}
}
$tag->setAttribute('src', $src);
}
}
echo $doc->saveHTML();
?>