django如何解决Ajax跨域访问问题?
来源:互联网 发布:知我药妆网假货多吗 编辑:程序博客网 时间:2024/06/05 17:25
解决跨域问题,有两个方法: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请求数据:
3.安装django-cors-headers
这里还有一各发现!在Django中,有人开发了CORS-header的middleware,只在settings.py中做一些简单的配置即可,见:https://github.com/ottoyiu/django-cors-headers/现在用起来服务器端完全开放,开启CORS,没有跨域烦恼,真爽!~
安装django-cors-headers:
在settings.py中增加:
可以配置允许跨域访问的白名单或者直接设置为允许所有的跨域访问,具体的配置可以看看他们的github页说明
- django如何解决Ajax跨域访问问题?
- 解决AJAX跨域访问的问题
- JSONP解决ajax跨域访问问题
- jquery ajax 解决跨域访问问题
- 解决ajax跨域访问的问题
- 解决Ajax(jsonp)跨域访问问题
- CORS解决ajax跨域访问问题
- Django解决跨域访问报错/Cros问题
- django处理Ajax跨域访问
- 如何解决Ajax跨域问题-1
- 看小白如何解决ajax跨域问题
- 如何解决ajax跨域问题
- 如何解决Ajax跨域问题
- 看小白如何解决ajax跨域问题
- 如何解决ajax跨域问题
- 如何解决ajax跨域问题
- 如何解决ajax跨域问题
- 如何解决ajax跨域问题
- Spring boot VO字段设置后台传入前台日期格式
- 在html页面显示pdf,实现pdf的预览和下载
- 二叉树的非递归的实现
- Python三级菜单大概思路
- easy ui 回车换输入焦点
- django如何解决Ajax跨域访问问题?
- iOS中arc的设置与使用-fobjc-arc或者-fno-objc-arc
- MobiCom 2016 conference - SEEM
- 简单的安卓音乐播放器-2.0版本可联网搜索、下载
- Memcached之——Memcached与Spring提供的cache接口整合
- 二分法查找C++实现
- 混合开发的大趋势之 一个Android程序员眼中的 React.js 块级作用域 和 let
- 表单元素form之input
- build.gradle配置参数详解