2015-06-04 71 views
0

我的本地安装的XAMPP上有一个文件,名为TEST.PHP。当我去http://127.0.0.1/TEST.PHP并执行它,脚本应该张贴值ID和NAME到现场http://otherdomain.com/post.php和输出放到DATA。这不起作用,因为同源策略。当我跟踪包时,我收到一个错误calles “NS_ERROR_DOM_BAD_URI”。我现在的问题是,无论如何,无论如何可以不必访问http://otherdomain.com/解决同源策略问题?

test.php的

<script> 
    $(window).load(function(){ 
      var url = "http://otherdomain.com/post.php"; 

      $.post(url,{id : "12", name : "John"}, function(data) 
      { 
       alert("It worked!"); 
      }); 
    }); 
    </script> 

UPDATE

我现在改成了以下设置。我有两个名为SEND.PHP和PROXY.PHP的文件。我从SEND.PHP向PROXY.PHP发送请求,PROXY.PHP将实际请求发送给OTHERDOMAIN.COM。当我现在执行SEND.PHP(意味着我按下按钮)时,我总是得到结果“Error:403 Forbidden Access”。

SEND.PHP

<!DOCTYPE html> 
<html> 
<head> 
<script src="http://ajax.googleapis.com/ajax/libs/jquery/1.11.3/jquery.min.js"></script> 
<script> 
$(document).ready(function(){ 
    $("button").click(function(){ 
     $.post("proxy.php", function(data,status){ 
      alert("Data: " + data + "\nStatus: " + status); 
     }); 
    }); 
}); 
</script> 
</head> 
<body> 

<button>Send Data</button> 

</body> 
</html> 

PROXY.PHP

<?php 
$ch = curl_init(); 

curl_setopt($ch, CURLOPT_URL,"http://otherdomain.com/data"); 
curl_setopt($ch, CURLOPT_POST, 1); 
curl_setopt($ch, CURLOPT_POSTFIELDS,"name=Jack&age=23"); 
curl_setopt($ch, CURLOPT_RETURNTRANSFER, true); 

$server_output = curl_exec ($ch); 

curl_close ($ch); 

if ($server_output == "OK") { echo "It Worked!"; } else { echo "Error: " . $server_output; } 

?> 
+0

具有相同原产地政策的重点是防止人们做这样的事情。 –

+0

看看这个:http://stackoverflow.com/questions/3076414/ways-to-circumvent-the-same-origin-policy?rq=1 –

+0

你需要做的'otherdomain'的东西在PHP中,而不是JavaScript的。 – Lance

回答

0

没有,没有工作围绕JavaScript中的同源策略。这是一项安全功能。但是,如果您有权访问其他域,则可以使用PHP中的CURL来完成类似的操作。

2

您必须使用代理文件以避免相同的原产地策略限制。 在proxy.php中,您可以通过CURL或其他HTTP库向otherdomain.com发送请求。通过JavaScript调用代理文件,而不是直接调用otherdomain.com。

+0

它不应该有任何区别,如果我将值从mydomain.com传递给otherdomain.com或从proxydomain.com传递给otherdomain.com,对不对?我不明白为什么这应该工作,因为起源仍然不一样。谢谢! – user3877230

+0

@ user3877230 - 只有浏览器存在相同的源策略,但PHP文件正在服务器上运行。你的JavaScript可以访问PHP,因为它来自同一台服务器(即:你的服务器)。 –

+0

非常感谢您的提示和解释,我会尝试一下! – user3877230