AJAX 跨域数据检索
尝试对跨域 URL 执行 AJAX HTTP 请求时(例如,“http: //www.google.com"),浏览器强制执行跨域策略,禁止直接检索和显示data.
一种潜在的解决方案是在 AJAX 请求中使用“jsonp”数据类型。虽然这可能允许您从外部域接收数据,但由于接收到的数据的非 JSON 格式,您可能会遇到语法错误。
为了规避这些限制,最实用的方法是使用服务器端语言作为代理。这涉及将跨域 URL 发送到您自己的服务器上的脚本(例如,名为“proxy.php”的 PHP 脚本),然后该脚本从外部域获取数据并将其传递回您的 AJAX 调用。
这是一个使用 jQuery 和 PHP 代理的示例:
jQuery代码:
$.ajax({ url: 'proxy.php', type: 'POST', data: { address: 'http://www.google.com' }, success: function(response) { // response now contains full HTML of google.com } });
PHP代理脚本(proxy.php):
echo file_get_contents($_POST['address']);
通过利用此代理机制,您可以检索和显示数据在跨域策略的约束下来自跨域源。然而,重要的是要注意从外部域抓取数据的局限性和潜在影响。
以上是如何使用 AJAX 和服务器端代理检索跨域数据?的详细内容。更多信息请关注PHP中文网其他相关文章!