Проблема Laravel + Vue + Axios с методом POST

Я работаю над проектом Laravel 5.6, который хранится на VPS (мы называем его «производственным», несмотря на отсутствие такой созданной среды).

Мы также объединили Plesk и Github для развертывания веб-приложения из наших локальных сред на сервер вручную.

Проблема - это когда я загружаю некоторые данные из API, они возвращают ошибку 405. Метод запрещен (ПОЛУЧАТЬ) ... но на самом деле они зарегистрированы как ПОЧТА в app.js и в routes/api.php.

И самое лучшее, что в моей местной среде они отлично работают.

Вот некоторая информация:

Сервер:

  • Сервер Ubuntu 14.04
  • Apache / MySQL
  • PHP 7.2.5

Мой компьютер:

  • Windows 10 с XAMPP
  • Apache / MySQL
  • PHP 7.2.2

Инструмент разработчика в каждом браузере:

Request Method: GET
Status Code:405 Method Not Allowed

А вот код в app.js:

loadCountries: function loadCountries(total) {
    axios.post('/api/properties/countries/').then(function (response) {
        app.countries = response.data;
    });

    total = total <= this.countries.length ? total : this.countries.length;

    if (total) {
        var newArr = [];
        for (i = 0; i < total; i++) {
            newArr.push(this.countries[i]);
        }
        this.countries = newArr;
    }
},

Примечание: Если я отредактирую тот же запрос в инструменте разработчика и отправлю его снова, но в качестве запроса POST он вернет мне все в порядке, поэтому API, похоже, отлично работает с запросом POST.

Этот ответ может иметь отношение к вашей проблеме stackoverflow.com/questions/46611275/…

Ryan Kozak 22.05.2018 04:38

Я не смог найти этот ответ ... Это решило мою проблему. Ответьте, пожалуйста. и спасибо

Maramal 22.05.2018 04:51

@Maramal: Если он работает в почтальоне, попробуйте удалить / из запроса. Попробуйте это так: '/api/properties/countries', потому что я думаю, что он пытался найти '/api/properties/countries/', а он не определен в ваших маршрутах!

Hiren Gohel 22.05.2018 07:13

@kozak, пожалуйста, опубликуйте как ответ

Maramal 22.05.2018 12:29

@Maramal, НП рад, что это сработало.

Ryan Kozak 22.05.2018 19:10
Стоит ли изучать PHP в 2026-2027 годах?
Стоит ли изучать PHP в 2026-2027 годах?
Привет всем, сегодня я хочу высказать свои соображения по поводу вопроса, который я уже много раз получал в своем сообществе: "Стоит ли изучать PHP в...
Symfony Station Communiqué - 7 июля 2023 г
Symfony Station Communiqué - 7 июля 2023 г
Это коммюнике первоначально появилось на Symfony Station .
Оживление вашего приложения Laravel: Понимание режима обслуживания
Оживление вашего приложения Laravel: Понимание режима обслуживания
Здравствуйте, разработчики! В сегодняшней статье мы рассмотрим важный аспект управления приложениями, который часто упускается из виду в суете...
Установка и настройка Nginx и PHP на Ubuntu-сервере
Установка и настройка Nginx и PHP на Ubuntu-сервере
В этот раз я сделаю руководство по установке и настройке nginx и php на Ubuntu OS.
Коллекции в Laravel более простым способом
Коллекции в Laravel более простым способом
Привет, читатели, сегодня мы узнаем о коллекциях. В Laravel коллекции - это способ манипулировать массивами и играть с массивами данных. Благодаря...
Как установить PHP на Mac
Как установить PHP на Mac
PHP - это популярный язык программирования, который используется для разработки веб-приложений. Если вы используете Mac и хотите разрабатывать...
6
5
3 014
2
Перейти к ответу Данный вопрос помечен как решенный

Ответы 2

Ответ принят как подходящий

Попробуйте убрать косую черту в конце вашего URL.

Такой как,

/api/properties/countries

Замена этой строки в исходном app.js приведет к следующему:

loadCountries: function loadCountries(total) {
axios.post('/api/properties/countries').then(function (response) {
    app.countries = response.data;
});

total = total <= this.countries.length ? total : this.countries.length;

if (total) {
    var newArr = [];
    for (i = 0; i < total; i++) {
        newArr.push(this.countries[i]);
    }
    this.countries = newArr;
}

},

Я столкнулся с этой проблемой, и я решил ее, сделав вычисляемый атрибут с полным URL-адресом, подобным этому

computed: {
    sendAnswersUrl: function () {
        return window.location.protocol + "//" + window.location.hostname, +  "/api/properties/countries";
     }
  }

затем при публикации с использованием аксиомов

axios.post(this.sendAnswersUrl, {
          group: this.id,
        })
        .then(data => {})
        .catch(() => {});

Другие вопросы по теме