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. django queryset相加和篩選教程2. 利用ajax+php實(shí)現(xiàn)商品價(jià)格計(jì)算3. Java實(shí)現(xiàn)的迷宮游戲4. idea設(shè)置提示不區(qū)分大小寫的方法5. JS圖片懶加載庫VueLazyLoad詳解6. Java利用TCP協(xié)議實(shí)現(xiàn)客戶端與服務(wù)器通信(附通信源碼)7. 使用AJAX(包含正則表達(dá)式)驗(yàn)證用戶登錄的步驟8. Java PreparedStatement用法詳解9. Spring如何集成ibatis項(xiàng)目并實(shí)現(xiàn)dao層基類封裝10. IDEA 2020.1.2 安裝教程附破解教程詳解

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