Django实现跨域请求过程详解
框架(架构)  /  管理员 发布于 7年前   177
前言
CORS 即 Cross Origin Resource Sharing 跨域资源共享.
跨域请求分两种:简单请求、复杂请求.
简单请求
简单请求必须满足下述条件.
HTTP方法为这三种方法之一:HEAD、GET、POST
HTTP头消息不超出以下字段:
Accept、Accept-Language、Content-Language、Last-Event-ID
且Content-Type只能为下列类型中的某一个:
==任何不满足上述要求的请求,都会被认为是复杂请求.
复杂请求会先发出一个预请求――预检,OPTIONS请求.==
浏览器的同源策略
无法跨域就是被浏览器的同源策略限制的.
也就是说,==浏览器会阻止非同源的请求.==
那什么是非同源呢?==域名或端口不同的,都属于非同源.==
==浏览器只会阻止表单以及Ajax请求的跨域,但不会阻止src请求跨域.==
所以,我们的cdn、图片等src请求都是正常的.
JsonP实现跨域
==JsonP跨域的原理是利用了浏览器不阻止src请求跨域来实现的.==
==JsonP只能实现GET请求跨域.==
首先 准备我们的视图文件
from django.http import HttpResponsefrom rest_framework.views import APIViewclass TestView(APIView): def get(self, request): return HttpResponse("handlerResponse('is ok')") # 注意返回的函数以及参数的格式
然后 HTML文件
<!DOCTYPE html><html lang="zh-CN"><head> <title>JsonP跨站请求测试</title></head><body><script> // 函数名应为handlerResponse,这是一种约定俗成 function handlerResponse(data) { alert(data) }</script><!--必须放在被执行函数的script标签的下面,否则会报错函数不存在--><script src="http://127.0.0.1:8000/test/"></script></body></html>
好了 我们来测试吧
可以看到,我们成功实现了跨域获取数据.
JsonP解决跨域只能发送GET请求,并且实现起来前后端交互会比较多,现在几乎已经不在使用了
在Django中间件中添加响应头
可实现简单请求和复杂请求的跨域
第一步 准备中间件
from django.utils.deprecation import MiddlewareMixinclass MyCors(MiddlewareMixin): def process_response(self, request, response): # 如下,等于'*'后,便可允许所有简单请求的跨域访问 response['Access-Control-Allow-Origin'] = '*' # 判断是否为复杂请求 if request.method == 'OPTIONS': response['Access-Control-Allow-Headers'] = 'Content-Type' response['Access-Control-Allow-Methods'] = 'PUT,PATCH,DELETE' return response
写好之后,别忘记了去注册.
第二步 视图文件
from django.http import HttpResponsefrom rest_framework.views import APIViewclass TestView(APIView): def get(self, request): return HttpResponse("这是GET请求的数据") def post(self, request): return HttpResponse("这是POST请求的数据") def put(self, request): return HttpResponse("这是PUT请求的数")
第三步 HTML文件
<!DOCTYPE html><html lang="zh-CN"><head> <script src="https://cdn.bootcss.com/jquery/3.3.1/jquery.min.js"></script> <title>test</title></head><body><button id="sign">点击发送跨站请求</button><script> $('#sign').click(function () { $.ajax({ url: 'http://127.0.0.1:8000/test/', // 要访问的外站 type: 'put', // 请求类型, put为复杂请求 contentType: 'application/json', // 指定为'application/json'后,将变为复杂请求 success: function (data) { // 请求成功后将执行该函数 // data是外站发送过来的数据 alert(data) }, }); });</script></body></html>
测试效果如下
可见,我们实现了复杂请求的跨域,简单请求就更不用说了.
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
122 在
学历:一种延缓就业设计,生活需求下的权衡之选中评论 工作几年后,报名考研了,到现在还没认真学习备考,迷茫中。作为一名北漂互联网打工人..123 在
Clash for Windows作者删库跑路了,github已404中评论 按理说只要你在国内,所有的流量进出都在监控范围内,不管你怎么隐藏也没用,想搞你分..原梓番博客 在
在Laravel框架中使用模型Model分表最简单的方法中评论 好久好久都没看友情链接申请了,今天刚看,已经添加。..博主 在
佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 @1111老铁这个不行了,可以看看近期评论的其他文章..1111 在
佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 网站不能打开,博主百忙中能否发个APP下载链接,佛跳墙或极光..
Copyright·© 2019 侯体宗版权所有·
粤ICP备20027696号