最新公告
  • 欢迎您光临起源地模板网,本站秉承服务宗旨 履行“站长”责任,销售只是起点 服务永无止境!立即加入钻石VIP
  • django如何实现跨域请求

    正文概述    2020-06-03   368

    django如何实现跨域请求

    CORS 即 Cross Origin Resource Sharing 跨域资源共享.

    跨域请求分两种:简单请求、复杂请求.

    简单请求

    简单请求必须满足下述条件.

    HTTP方法为这三种方法之一:HEAD、GET、POST

    HTTP头消息不超出以下字段:

    Accept、Accept-Language、Content-Language、Last-Event-ID

    且Content-Type只能为下列类型中的某一个:

    application/x-www-from-urlencodedmultipart/form-datatext/plain.

    ==任何不满足上述要求的请求,都会被认为是复杂请求.

    复杂请求

    会先发出一个预请求——预检,OPTIONS请求.==

    浏览器的同源策略

    无法跨域就是被浏览器的同源策略限制的.

    也就是说,==浏览器会阻止非同源的请求.==

    那什么是非同源呢?==域名或端口不同的,都属于非同源.==

    ==浏览器只会阻止表单以及Ajax请求的跨域,但不会阻止src请求跨域.==

    所以,我们的cdn、图片等src请求都是正常的.

    JsonP实现跨域

    ==JsonP跨域的原理是利用了浏览器不阻止src请求跨域来实现的.==

    ==JsonP只能实现GET请求跨域.==

    首先 准备我们的视图文件

    from django.http import HttpResponse
    from rest_framework.views import APIView
    
    class TestView(APIView):
      def get(self, request):
        return HttpResponse("handlerResponse('is ok')")
        # 注意返回的函数以及参数的格式

    然后html文件

    <!DOCTYPE html>
    <html>
    <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>

    django如何实现跨域请求

    可以看到,我们成功实现了跨域获取数据.

    JsonP解决跨域只能发送GET请求,并且实现起来前后端交互会比较多,现在几乎已经不在使用了

    在Django中间件中添加响应头

    可实现简单请求和复杂请求的跨域

    第一步 准备中间件

    from django.utils.deprecation import MiddlewareMixin
    
    class 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 HttpResponse
    from rest_framework.views import APIView
    
    class 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>
    <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>

    测试效果如下

    django如何实现跨域请求


    起源地下载网 » django如何实现跨域请求

    常见问题FAQ

    免费下载或者VIP会员专享资源能否直接商用?
    本站所有资源版权均属于原作者所有,这里所提供资源均只能用于参考学习用,请勿直接商用。若由于商用引起版权纠纷,一切责任均由使用者承担。更多说明请参考 VIP介绍。
    提示下载完但解压或打开不了?
    最常见的情况是下载不完整: 可对比下载完压缩包的与网盘上的容量,若小于网盘提示的容量则是这个原因。这是浏览器下载的bug,建议用百度网盘软件或迅雷下载。若排除这种情况,可在对应资源底部留言,或 联络我们.。
    找不到素材资源介绍文章里的示例图片?
    对于PPT,KEY,Mockups,APP,网页模版等类型的素材,文章内用于介绍的图片通常并不包含在对应可供下载素材包内。这些相关商业图片需另外购买,且本站不负责(也没有办法)找到出处。 同样地一些字体文件也是这种情况,但部分素材会在素材包内有一份字体下载链接清单。
    模板不会安装或需要功能定制以及二次开发?
    请QQ联系我们

    发表评论

    还没有评论,快来抢沙发吧!

    如需帝国cms功能定制以及二次开发请联系我们

    联系作者

    请选择支付方式

    ×
    迅虎支付宝
    迅虎微信
    支付宝当面付
    余额支付
    ×
    微信扫码支付 0 元