Django通過設(shè)置CORS解決跨域問題
一、Ajax 跨域請(qǐng)求
Ajax 請(qǐng)求一個(gè)目標(biāo)地址為非本域(協(xié)議、主機(jī)、端口任意一個(gè)不同)的 web 資源。
前端http://192.168.10.50:8080后端http://192.168.10.50:8000
Ajax 跨域請(qǐng)求保護(hù)的作用:防止跨站的攻擊。
二、如何解決跨域的訪問
當(dāng)我們?cè)诂F(xiàn)實(shí)當(dāng)中有需要跨域訪問資源,有兩種解決方案:
前端解決:jsonp 后端解決(Django):CORS 專門解決方案這篇文章主要介紹使用 Django 框架進(jìn)行開發(fā)時(shí)的后端解決方案。
三、Django 解決跨域問題
Django 框架中通過 django-cors-headers 這個(gè)模塊解決。
1. 安裝
pip install django-cors-headers
2. 注冊(cè)應(yīng)用
注冊(cè)到 settings 的 INSTALLED_APPS 中。
INSTALLED_APPS = ( ... ’corsheaders’, ...)
3. 添加到中間件
添加到 settings 的 MIDDLEWARE 中,一般放在 django.middleware.csrf.CsrfViewMiddleware 前面。
MIDDLEWARE = [ ’corsheaders.middleware.CorsMiddleware’, ...]
4. 添加白名單
添加允許訪問的白名單,凡是出現(xiàn)在白名單的域名都可以訪問后端接口。
# 添加 CORS 配置# 1. 設(shè)置白名單CORS_ORIGIN_WHITELIST = ( ’127.0.0.1:8080’, ’localhost:8080’, ’http://192.168.10.50:8080’, # 凡是出現(xiàn)在白名單中的域名,都可以訪問后端接口)# 2. 設(shè)置 CORS CookieCORS_ALLOW_CREDENTIALS = True # 指明在跨域訪問中,后端是否支持對(duì)cookie的操作
到此這篇關(guān)于Django 通過設(shè)置CORS解決跨域問題的文章就介紹到這了,更多相關(guān)Django CORS跨域內(nèi)容請(qǐng)搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!
相關(guān)文章:
1. ASP基礎(chǔ)知識(shí)VBScript基本元素講解2. Python 利用Entrez庫篩選下載PubMed文獻(xiàn)摘要的示例3. Python 合并拼接字符串的方法4. Python 制作查詢商品歷史價(jià)格的小工具5. Python 如何調(diào)試程序崩潰錯(cuò)誤6. Python sublime安裝及配置過程詳解7. python使用jenkins發(fā)送企業(yè)微信通知的實(shí)現(xiàn)8. Linux刪除系統(tǒng)自帶版本Python過程詳解9. ASP.NET MVC使用jQuery ui的progressbar實(shí)現(xiàn)進(jìn)度條10. Python3 json模塊之編碼解碼方法講解

網(wǎng)公網(wǎng)安備