zoukankan      html  css  js  c++  java
  • 浏览器同源策略问题解决方式

    在我们日常开发中,经常会遇见使用postman工具可以成功请求到后台的api接口,但是通过浏览器就不能够使用post请求了。

    这个问题就是因为浏览器的同源策略问题。

    什么是同源策略呢?

    同源策略是浏览器的一个安全功能,不同源的客户端脚本在没有明确授权的情况下,不能读写对方资源。所以a.com下的js脚本采用ajax读取b.com里面的文件数据是会报错的。

    在Django中如何解决同源策略问题呢?

    我们使用CORS来解决后端对跨域访问的支持。

    使用django-cors-headers扩展

    参考文档https://github.com/ottoyiu/django-cors-headers/

    安装

    pip install django-cors-headers

    添加应用

    INSTALLED_APPS = (
        ...
        'corsheaders',
        ...
    )

    中间层设置

    MIDDLEWARE = [
        'corsheaders.middleware.CorsMiddleware',
        ...
    ]

    注意,这个中间件必须放在所有中间件的最上面,即第一个中间件。

    添加白名单

    # CORS
    CORS_ORIGIN_WHITELIST = (
        'http://127.0.0.1:8080',
        'http://localhost:8080',
        'http://域名e:8080',
        'http://域名:8000'
    )
    CORS_ALLOW_CREDENTIALS = True  # 允许携带cookie
    • 凡是出现在白名单中的域名,都可以访问后端接口
    • CORS_ALLOW_CREDENTIALS 指明在跨域访问中,后端是否支持对cookie的操作。
  • 相关阅读:
    hdu 1429 胜利大逃亡(续)(BFS+位压缩)
    hdu 2955 Robberies
    POJ—Building a Space Station
    POJ-1287 Networking
    POJ-1251 Jungle Roads
    BFS ZOJ problem-1671 Waking Ant
    POJ-1308 Is It A Tree?
    poj 1611The Suspects
    POJ Wireless Network
    POJ 2524 Ubiquitous Religions
  • 原文地址:https://www.cnblogs.com/chao666/p/12758845.html
Copyright © 2011-2022 走看看