ホームページ  >  記事  >  ウェブフロントエンド  >  Django が Ajax Post データを使用する場合の 403 エラーを解決する方法

Django が Ajax Post データを使用する場合の 403 エラーを解決する方法

亚连
亚连オリジナル
2018-05-24 16:53:283084ブラウズ

Django で jquery ajax post データを使用すると 403 エラーが発生します。これを解決するにはどうすればよいですか? Django で ajax post データを使用するときに発生する 403 エラーを解決するのに役立ちます。必要な友達は参考にしてください。この記事では、Django で jquery ajax post データを使用するときに 403 エラーが発生する 2 つの方法を紹介します。詳細は下記をご参照ください。

方法 1:

jQuery を使用して ajax を処理する場合、Django は問題を解決するコードを直接送信します。別のjsファイルに入れてhtmlページに導入します。この js ファイルは jquery js ファイルの導入後に導入する必要があることに注意してください

$(document).ajaxSend(function(event, xhr, settings) { 
 function getCookie(name) { 
  var cookieValue = null; 
  if (document.cookie && document.cookie != '') { 
   var cookies = document.cookie.split(';'); 
   for (var i = ; i < cookies.length; i++) { 
    var cookie = jQuery.trim(cookies[i]); 
    // Does this cookie string begin with the name we want? 
    if (cookie.substring(, name.length + ) == (name + &#39;=&#39;)) { 
     cookieValue = decodeURIComponent(cookie.substring(name.length + )); 
     break; 
    } 
   } 
  } 
  return cookieValue; 
 } 
 function sameOrigin(url) { 
  // url could be relative or scheme relative or absolute 
  var host = document.location.host; // host + port 
  var protocol = document.location.protocol; 
  var sr_origin = &#39;//&#39; + host; 
  var origin = protocol + sr_origin; 
  // Allow absolute or scheme relative URLs to same origin 
  return (url == origin || url.slice(, origin.length + ) == origin + &#39;/&#39;) || 
   (url == sr_origin || url.slice(, sr_origin.length + ) == sr_origin + &#39;/&#39;) || 
   // or any other URL that isn&#39;t scheme relative or absolute i.e relative. 
   !(/^(\/\/|http:|https:).*/.test(url)); 
 } 
 function safeMethod(method) { 
  return (/^(GET|HEAD|OPTIONS|TRACE)$/.test(method)); 
 } 
 if (!safeMethod(settings.type) && sameOrigin(settings.url)) { 
  xhr.setRequestHeader("X-CSRFToken", getCookie(&#39;csrftoken&#39;)); 
 } 
});

方法 2:

投稿データを処理するビューの前に @csrf_exempt デコレータを追加します

例:

@csrf_exempt 
def profile_delte(request): 
 del_file=request.POST.get("delete_file",&#39;&#39;)

上記はまとめました 皆さん、今後も皆さんのお役に立てれば幸いです。

関連記事:

ライブラリ(フレームワーク)を使わずに自分でajaxを書く簡単な紹介

MVCにAjaxとHTML5をベースにしたファイルアップロード機能を実装

jqueryとphpを組み合わせてAJAX longを実装投票

以上がDjango が Ajax Post データを使用する場合の 403 エラーを解決する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。