久久r热视频,国产午夜精品一区二区三区视频,亚洲精品自拍偷拍,欧美日韩精品二区

您的位置:首頁技術文章
文章詳情頁

django 取消csrf限制的實例

瀏覽:162日期:2024-10-20 17:24:23

# 導入包

from django.views.decorators.csrf import csrf_exempt

# 使用裝飾器即可避免csrf限制

@csrf_exemptdef add_bookshelf(request): user_id = request.POST.get(’user_id’) print(user_id) return HttpResponse(’123’)

補充知識:Django 前后端分離跨域AJAX獲取csrftoken及獲取cookie時遇到的問題

獲取CSRFTOKEN

Django的中間件’django.middleware.csrf.CsrfViewMiddleware’會將csrftoken的值設置在cookie中。在前后端不分離的項目中,若需要在AJAX使用csrftoken的值則可在js腳本中通過document.cookie直接獲取cookie的值(也可以通過其他更快捷的輪子如js-cookie)。

在前后端分離的項目中(已配置django-cors-headers),無法直接使用js從cookie中獲取csrfToken的值(瀏覽器的同源策略),即使已經成功設置了csrfToken的cookie值

django 取消csrf限制的實例

解決方法

在中間件中引入

corsheaders.middleware.CorsPostCsrfMiddleware’corsheaders.middleware.CorsMiddleware’,’django.middleware.security.SecurityMiddleware’,’django.contrib.sessions.middleware.SessionMiddleware’,’django.middleware.common.CommonMiddleware’,’django.middleware.csrf.CsrfViewMiddleware’,’corsheaders.middleware.CorsPostCsrfMiddleware’,

有些博客中使用該中間件替代django.middleware.csrf.CsrfViewMiddleware是不可行的,因為該中間件并沒有期望中csrf校驗的功能,下面為該中間件的源代碼。

class CorsPostCsrfMiddleware(MiddlewareMixin): def _https_referer_replace_reverse(self, request): ''' Put the HTTP_REFERER back to its original value and delete the temporary storage ''' if conf.CORS_REPLACE_HTTPS_REFERER and ’ORIGINAL_HTTP_REFERER’ in request.META: http_referer = request.META[’ORIGINAL_HTTP_REFERER’] request.META[’HTTP_REFERER’] = http_referer del request.META[’ORIGINAL_HTTP_REFERER’] def process_request(self, request): self._https_referer_replace_reverse(request) return None def process_view(self, request, callback, callback_args, callback_kwargs): self._https_referer_replace_reverse(request) return None

以上這篇django 取消csrf限制的實例就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持好吧啦網。

標簽: Django
相關文章:
主站蜘蛛池模板: 额尔古纳市| 邳州市| 修水县| 曲阜市| 南京市| 务川| 陇南市| 新乡县| 桐城市| 宜阳县| 渑池县| 东乌珠穆沁旗| 老河口市| 富顺县| 汶上县| 南开区| 巨野县| 包头市| 交城县| 富锦市| 临桂县| 保康县| 桃源县| 邹城市| 资溪县| 淄博市| 襄垣县| 汕尾市| 怀化市| 敦化市| 锡林郭勒盟| 云和县| 岳阳县| 江源县| 郴州市| 东阳市| 扶沟县| 永宁县| 抚州市| 南宫市| 清徐县|