django如何解决Ajax跨域访问问题?

解决跨域问题,有两个方法:1.使用jsonp 2.使CORS生效
使用jsonp方法,需要让服务器端放回jsonp格式的response,如Django可以加jsonp相关的decorator,如:https://coderwall.com/p/k8vb_a/returning-json-jsonp-from-a-django-view-with-a-little-decorator-help由于我不太喜欢这种方式,所以这里略过了,可看后面的参考资料。
使用CORS:这个用起来比较方便,现在大多数浏览器都支持了,且我web服务器完全开放给别人调用,所以比较推荐CORS。
1.使用JSONP
使用Ajax获取json数据时,存在跨域的限制。不过,在Web页面上调用js的script脚本文件时却不受跨域的影响,JSONP就是利用这个来实现跨域的传输。因此,我们需要将Ajax调用中的dataType从JSON改为JSONP(相应的API也需要支持JSONP)格式。
JSONP只能用于GET请求。

2.直接修改Django中的views.py文件
修改views.py中对应API的实现函数,允许其他域通过Ajax请求数据:

?
1
2
3
4
5
6
7
def myview(_request):
   response = HttpResponse(json.dumps({ "key" : "value" , "key2" : "value" }))
   response[ "Access-Control-Allow-Origin" ] = "*"
   response[ "Access-Control-Allow-Methods" ] = "POST, GET, OPTIONS"
   response[ "Access-Control-Max-Age" ] = "1000"
   response[ "Access-Control-Allow-Headers" ] = "*"
   return response

3.安装django-cors-headers
这里还有一各发现!在Django中,有人开发了CORS-header的middleware,只在settings.py中做一些简单的配置即可,见:https://github.com/ottoyiu/django-cors-headers/现在用起来服务器端完全开放,开启CORS,没有跨域烦恼,真爽!~
安装django-cors-headers:

?
1
pip install django-cors-headers

在settings.py中增加:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
INSTALLED_APPS = (
   ...
   'corsheaders' ,
   ...
)
 
...
 
MIDDLEWARE_CLASSES = (
   ...
   'corsheaders.middleware.CorsMiddleware' ,
   'django.middleware.common.CommonMiddleware' ,
   ...
)

可以配置允许跨域访问的白名单或者直接设置为允许所有的跨域访问,具体的配置可以看看他们的github页说明

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值