当遇到跨域策略限制时,JSONP(带有 Padding 的 JSON)提供了便捷的解决方案。然而,最初掌握细节可能会令人困惑。让我们用一个简单的 jQuery、PHP 和 JSONP 示例来揭开这个过程的神秘面纱。
考虑以下错误的代码片段:
// jQuery $.post('http://MySite.com/MyHandler.php', { firstname: 'Jeff' }, function(res) { alert('Your name is ' + res); }); // PHP <?php $fname = $_POST['firstname']; if ($fname == 'Jeff') { echo 'Jeff Hansen'; } ?>
为了启用跨域请求,我们将利用 JSONP。操作方法如下:
jQuery:
$.getJSON('http://www.write-about-property.com/jsonp.php?callback=?', { firstname: 'Jeff' }, function(res) { alert('Your name is ' + res.fullname); });
PHP:
<?php $fname = $_GET['firstname']; if ($fname == 'Jeff') { header("Content-Type: application/json"); echo $_GET['callback'] . '({' . "'fullname' : 'Jeff Hansen'" . '})'; } ?>
密钥要点:
是的,您可以在 JSONP 响应中存储 HTML。修改 PHP 代码如下:
<?php if ($fname == 'Jeff') { header("Content-Type: application/json"); echo $_GET['callback'] . '({ 'name': 'Jeff Hansen', 'html': '<span>This is some HTML</span>' })'; } ?>
在 JavaScript 中,您可以使用 res.html 访问 HTML。
以上是JSONP如何解决跨源请求问题?的详细内容。更多信息请关注PHP中文网其他相关文章!