Подтвердить что ты не робот

Выбор исправления исправления не разрешен

У меня есть два приложения, один из которых - это ответный интерфейс, а второй - приложение rails-api.

Я с удовольствием использовал isomorphic-fetch, пока мне не нужно было отправить метод PATCH на сервер.

Я получаю:

Fetch API cannot load http://localhost:3000/api/v1/tasks. Method patch is not allowed by Access-Control-Allow-Methods in preflight response.

но ответ OPTIONS с сервера включает метод PATCH в списке Access-Control-Allow-Methods:

введите описание изображения здесь

Так реализуется выборка:

const API_URL = 'http://localhost:3000/'                                            
const API_PATH = 'api/v1/'

fetch(API_URL + API_PATH + 'tasks', {
  headers: {
    'Accept': 'application/json',
    'Content-Type': 'application/json'
  },
  method: 'patch',                                                              
  body: JSON.stringify( { task: task } )                                        
})

POST, GET, DELETE настроены почти одинаково, и они работают нормально.

Любая идея, что здесь происходит?

UPDATE:

Патч метода чувствителен к регистру:

https://github.com/github/fetch/blob/master/fetch.js#L200

Не уверен, что это предназначено или ошибка.

ОБНОВЛЕНИЕ 2

Это предназначено, и тип метода PATCH должен быть чувствительным к регистру. Обновление строки из метода выборки до:

method: 'PATCH'

устраняет проблему.

https://github.com/github/fetch/issues/254

4b9b3361

Ответ 1

У меня была очень похожая проблема с API-интерфейсом responseJS и rails API с помощью Rack:: Cors, а добавление patch в список разрешенных методов разрешило проблему для меня.

config.middleware.insert_before 0, Rack::Cors do
  allow do
    origins '*'
    resource '*', headers: :any, methods: [:get, :post, :patch, :options]
  end
end

Ответ 2

У меня была эта ошибка, а PATCH - все шапки. Я также получил эту ошибку с помощью DELETE и PUT. Я проверил заголовки моего fetch, и я увидел метод OPTIONS. Я использовал здесь isomorphic-fetch lib - https://www.npmjs.com/package/isomorphic-fetch

Исправление для меня было добавить на мою страницу PHP:

<?php
    header('Access-Control-Allow-Methods: GET, POST, PUT, DELETE, PATCH');

Без этого, в Firefox 53 я бы продолжал получать ошибку javascript:

NetworkError при попытке получить ресурс.

Извлечение, которое я делал, было следующим:

try {
    await fetch('https://my.site.com/', {
        method: 'PATCH',
        headers: { 'Content-Type':'application/x-www-form-urlencoded' },
        body: 'id=12&day=1'
    });
} catch(ex) {
    console.error('ex:', ex);
}