Django通過設(shè)置CORS解決跨域問題
一、Ajax 跨域請求
Ajax 請求一個(gè)目標(biāo)地址為非本域(協(xié)議、主機(jī)、端口任意一個(gè)不同)的 web 資源。
前端http://192.168.10.50:8080后端http://192.168.10.50:8000
Ajax 跨域請求保護(hù)的作用:防止跨站的攻擊。
二、如何解決跨域的訪問
當(dāng)我們在現(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. 注冊應(yīng)用
注冊到 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 # 指明在跨域訪問中,后端是否支持對cookie的操作
到此這篇關(guān)于Django 通過設(shè)置CORS解決跨域問題的文章就介紹到這了,更多相關(guān)Django CORS跨域內(nèi)容請搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!
相關(guān)文章:
1. JavaEE SpringMyBatis是什么? 它和Hibernate的區(qū)別及如何配置MyBatis2. python 讀txt文件,按‘,’分割每行數(shù)據(jù)操作3. 解決vue頁面刷新,數(shù)據(jù)丟失的問題4. Python 忽略文件名編碼的方法5. android studio實(shí)現(xiàn)簡單的計(jì)算器(無bug)6. Java Media Framework 基礎(chǔ)教程7. 利用單元測試對PHP代碼進(jìn)行檢查8. python excel和yaml文件的讀取封裝9. 在Mac中配置Python虛擬環(huán)境過程解析10. python如何實(shí)現(xiàn)word批量轉(zhuǎn)HTML
