在网站后台跨域访问另一服务器时,若被访问服务器未设置response[‘Access-Control-Allow-Origin\'] = ‘*\' 那么将无法获取。
jsonp方法
伪造ajax提交请求
请求端
// 基于jsonp
// 原理: ajax 不能直接跨域 。
//向html中加入 标签 含有访问路径, 标签直接访问路径达到效果
$(\'.get_service2\').click(function () {
// 伪造ajax提交请求
$.ajax({
url:\'http://127.0.0.1:8001/service/\',
type: \'get\',
dataType: \'jsonp\', // 伪造ajax 基于
jsonp: \'callbacks\',
// 随机取一个函数名发给请求方,对方解析好后返回过来
success: function (data) {
console.log(data)
}
})
});
服务端
import json
def service(request):
# 等待请求返回json数据
func = request.GET.get(\'callbacks\') # 固定方法名jsonp
info = {\'name\': \'zok\', \'age\': 18}
return HttpResponse(\"%s(\'%s\')\" % (func, json.dumps(info)))
jsonp获电视台节目案例
取到后并渲染到页面上
// 实例基于jsonp 电视台节目获取
$(\'.get_service3\').click(function () {
// 伪造ajax 基于
$.ajax({
url:\'http://www.jxntv.cn/data/jmd-jxtv2.html\',
type: \'get\',
dataType: \'jsonp\', // 伪造ajax 基于
jsonp: \'callbacks\',
jsonpCallback: \'list\', // 拼函数名,如果不写就随机发一个函数名,对面解析好发回来
success: function (data) {
var html=\"\"; //自己拼接
// 循环取出数据 index 索引计次,weekday 每一天 必须要2个参数
$.each(data.data,function (index, weekday) {
//取到每天的数据
html+=\'<p>\'+weekday.week+\'</p>\';
$.each(weekday.list,function (i,show) {
html+=\'<a href=\'+show. +\'>\'+show.name+\'</a></br>\'
})
});
$(\'body\').append(html)
}
})
})
cors 最简单的方法
需要在服务端上加入白名单ponse[‘Access-Control-Allow-Origin\'] = ‘*\' 设置好能正常传送的ip
服务端
def serviceCors(request):
\"\"\"
基于cors跨域
白名单域名
\"\"\"
info = {\'name\': \'zok\', \'age\': 18}
response = HttpResponse(json.dumps(info))
# 设置指定ip 或 * 全部通过
response[\'Access-Control-Allow-Origin\'] = \'http://127.0.0.1:8000\'
response[\'Access-Control-Allow-Origin\'] = \'*\'
return response
请求端
// cors 跨域请求,方法最简单
$(\'.get_service1\').click(function () {
$.ajax({
url:\'http://127.0.0.1:8001/serviceCors/\',
type:\'get\',
success:function (data) {
console.log(data)
}
})
});
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。
继续阅读与本文标签相同的文章
上一篇 :
Yahaoo在反对数据泄露的诉讼中失去了叫牌资格
下一篇 :
特朗普阻止了Broadcom收购案
-
FFMPEG常用命令收录(持续更新)
2026-05-19栏目: 教程
-
OpenSSL 1.1.1的裁剪
2026-05-19栏目: 教程
-
Springboot+mockito进行单元测试心得整体
2026-05-19栏目: 教程
-
如何用“云”读懂女生的心?TA 做到了
2026-05-19栏目: 教程
-
基于ASP.Net Core开发的一套通用后台框架
2026-05-19栏目: 教程
