axios POSTリクエストでヘッダーを渡す


134

次のようなnpmパッケージドキュメントから推奨されるaxios POSTリクエストを作成しました。

var data = {
    'key1': 'val1',
    'key2': 'val2'
}
axios.post(Helper.getUserAPI(), data)       
.then((response) => {
    dispatch({type: FOUND_USER, data: response.data[0]})
})
.catch((error) => {
    dispatch({type: ERROR_FINDING_USER})
})

動作しますが、ヘッダーを受け入れるようにバックエンドAPIを変更しました。

Content-Type: 'application / json'

承認: 'JWT fefege ...'

現在、このリクエストはPostmanで正常に機能しますが、axios呼び出しを作成するときにこのリンクをたどると、うまく機能しません。

常に400 BAD Requestエラーが発生します。

これが私の変更されたリクエストです:

axios.post(Helper.getUserAPI(), {
    headers: {
        'Content-Type': 'application/json',
        'Authorization': 'JWT fefege...'
    },
    data
})      
.then((response) => {
    dispatch({type: FOUND_USER, data: response.data[0]})
})
.catch((error) => {
    dispatch({type: ERROR_FINDING_USER})
})

どんな助けでも大歓迎です。

回答:


241

axiosを使用する場合、カスタムヘッダーを渡すために、最後の引数としてヘッダーを含むオブジェクトを指定します

次のようにaxiosリクエストを変更します。

const headers = {
  'Content-Type': 'application/json',
  'Authorization': 'JWT fefege...'
}

axios.post(Helper.getUserAPI(), data, {
    headers: headers
  })
  .then((response) => {
    dispatch({
      type: FOUND_USER,
      data: response.data[0]
    })
  })
  .catch((error) => {
    dispatch({
      type: ERROR_FINDING_USER
    })
  })

@ KishoreJethava、500はサーバーの内部エラーです。ヘッダーが来ているか、他のバグがあるかどうかをサーバー側で確認できます
Shubham Khatri

@KishoreJethava、サーバーにヘッダーを記録して、正しい値を取得しているかどうかを確認できますか
Shubham Khatri

データを投稿する必要はありませんか?this.state.tokenに値が含まれていることも確認してください
Shubham Khatri


@ShubhamKhatri、axios関連する質問をここで見てもらいますか:stackoverflow.com/questions/59470085/…
Istiaque Ahmed

37

カスタムヘッダーを使用したaxios.postリクエストの完全な例を以下に示します

var postData = {
  email: "test@test.com",
  password: "password"
};

let axiosConfig = {
  headers: {
      'Content-Type': 'application/json;charset=UTF-8',
      "Access-Control-Allow-Origin": "*",
  }
};

axios.post('http://<host>:<port>/<path>', postData, axiosConfig)
.then((res) => {
  console.log("RESPONSE RECEIVED: ", res);
})
.catch((err) => {
  console.log("AXIOS ERROR: ", err);
})


取得リクエストのためにこの問題に直面しています。応答はxml形式で送られます。これは問題を解決しません。
Eswar

3

これは役立つかもしれませんが、

const data = {
  email: "me@me.com",
  username: "me"
};

const options = {
  headers: {
      'Content-Type': 'application/json',
  }
};

axios.post('http://path', data, options)
 .then((res) => {
   console.log("RESPONSE ==== : ", res);
 })
 .catch((err) => {
   console.log("ERROR: ====", err);
 })
注:400を超えるすべてのステータスコードは、Axiosキャッチブロックでキャッチされます。また、ヘッダーはAxiosのpostメソッドではオプションです

ブロッククォート

ブロッククォート


2

Shubhamの回答がうまくいきませんでした。

axiosライブラリを使用していて、カスタムヘッダーを渡すには、キー名「headers」を持つオブジェクトとしてヘッダーを作成する必要があります。ヘッダーキーにはオブジェクトが含まれている必要があります。ここではContent-TypeとAuthorizationです。

以下の例は正常に動作しています。

    var headers = {
        'Content-Type': 'application/json',
        'Authorization': 'JWT fefege...' 
    }
    axios.post(Helper.getUserAPI(), data, {"headers" : headers})

        .then((response) => {
            dispatch({type: FOUND_USER, data: response.data[0]})
        })
        .catch((error) => {
            dispatch({type: ERROR_FINDING_USER})
        })

1

インターセプターを使用してヘッダーを渡すこともできます

多くのコードを節約できます

axios.interceptors.request.use(config => {
  if (config.method === 'POST' || config.method === 'PATCH' || config.method === 'PUT')
    config.headers['Content-Type'] = 'application/json;charset=utf-8';

  const accessToken = AuthService.getAccessToken();
  if (accessToken) config.headers.Authorization = 'Bearer ' + accessToken;

  return config;
});

使用をお勧めしますconfig.method.toUpperCase()
コンスタンティン

@Constantineそれはすでに大文字だと思います
イスラエルkusayev

残念ながら、私のものは低かった
コンスタンティン

0

または、作成時に読み取ることができないvuejsプロトタイプのプロパティを使用している場合は、ヘッダーを定義して次のように書き込むこともできます。

storePropertyMaxSpeed(){
                axios.post('api/property', {
                    "property_name" : 'max_speed',
                    "property_amount" : this.newPropertyMaxSpeed
                    },
                    {headers :  {'Content-Type': 'application/json',
                                'Authorization': 'Bearer ' + this.$gate.token()}})
                  .then(() => { //this below peace of code isn't important 
                    Event.$emit('dbPropertyChanged');

                    $('#addPropertyMaxSpeedModal').modal('hide');

                    Swal.fire({
                        position: 'center',
                        type: 'success',
                        title: 'Nova brzina unešena u bazu',
                        showConfirmButton: false,
                        timer: 1500
                        })
                })
                .catch(() => {
                     Swal.fire("Neuspješno!", "Nešto je pošlo do đavola", "warning");
                })
            }
        },

-4

JSONは二重引用符でフォーマットする必要があります

お気に入り:

headers: {
                "Content-Type": "application/Jason",
                "Authorization": "JWT fefege..."
            }

だけでなく:

headers: {
                'Content-Type': 'application/json',
                'Authorization': 'JWT fefege...'
         }

これはJSON形式にも当てはまりますが、JavaScriptを使用する場合、JavaScript文字列を好きなように書くことができ、それでも機能します。axiosのJSONシリアライザーは違いを知らないためです。:-)
Jono
弊社のサイトを使用することにより、あなたは弊社のクッキーポリシーおよびプライバシーポリシーを読み、理解したものとみなされます。
Licensed under cc by-sa 3.0 with attribution required.