浏览器端的同源策略: 如果两个页面的协议,端口和域名中的其中任意一个不相同, 它们就是不同源的, 浏览器会限制他们之间的资源交互;
跨域: 跨域的安全限制只针对浏览器, 服务器是没有跨域的安全限制的;
解决跨域的两种方法:
// 1.jquery 里 利用 <script src=‘‘> 来解决跨域问题
//1.引如jquery文件
<script src="jquery/jquery.min.js"></script>
//实现逻辑: 1.点击"获取跨域数据"按钮 ->在head中添加一个src 为请求数据地址的script 标签, 地址后面带回调函数名;
$(‘#btn-getData‘).on(‘click‘, function(){
$(‘head‘).append(‘<script src="http://localhost:9090/user?callback=showData">‘)
})
//2.自定义函数名获取返回
function showData(res) {
//将json对象转换为字符串
var data = JSON.stringify(result);
$(‘#box‘).html(data)
// 2. jquery jsonp方式实现 ajax 的跨域请求
//只需要设置 dataType: ‘jsonp‘ 即可发送ajax请求, 请求会自动生成回调函数, 返回的数据 为jsonp 格式,
//可以直接在ajax 的回调函数 success 中获取到数据, JSON.stringify转为字符串即可
原文:https://www.cnblogs.com/noraZhang/p/10192258.html