React/Redux/Django WebアプリケーションからjQueryを削除し、$.ajax
メソッドをFetch APIに置き換えようとしています。私は多かれ少なかれ、私のGETリクエストがうまく動作していて、私のPOSTリクエストにヒットすることができるようですが、POSTデータを実際にDjango request.POST
オブジェクトに取り込むようにリクエストをフォーマットすることはできません。私の/ sign_inビューに当たるたびに、request.POST
オブジェクトは空です。私のアプリケーション全体のバックエンドは、Djangoフォーム(Djangoテンプレートなし、制御されたコンポーネントのみ)を使用して構築されています。request.body
またはrequest.data
を使用するようにすべてのビューを書き直す必要はありません。ここでDjango POSTリクエスト用のFetch API
が、私はそれが関連することだと思うことができるすべてのコードで、参考になるものではありませなら、私に教えてください:
これは私が私の完全なPOSTデータを作成し、添付するために使用するカリー化関数でありますCSRFトークンは:
export const signIn = data => {
return post('/api/account/sign_in/', data)
}
:
const setUpCsrfToken =() => {
const csrftoken = Cookies.get('csrftoken')
return function post (url, options) {
const defaults = {
'method': 'POST',
'credentials': 'include',
'headers': {
'X-CSRFToken': csrftoken,
'Content-Type': 'application/x-www-form-urlencoded'
}
}
const merged = merge(options, defaults)
return fetch(url, merged)
}
}
export const post = setUpCsrfToken()
これは私が私のリアクトアプリから使用するAPIメソッドであります
それは元々リアクトアプリ自体にパッケージ化されたデータは、文字列値を持つオブジェクトと同様に簡単です:
{
email: '[email protected]',
password: 'password
}
私はこれらの質問を見て、彼らは名目上有用であることが判明しましたが、私は、私が想定し何を考慮に入れて自分のために答えを合成するために把握することはできませんジャンゴの複雑さの一部です:
ありがとう!
が同じような状況に直面し、任意の解決策はあります?。ビューの変更をスキップするより良い方法。 – Ajaykumar