Задать вопрос
serii81
@serii81
Я люблю phр...

Почему не работает axios.put в laravel + vue?

Очень странно, метод store у контроллера работает, но update нет.

Вот контроллер.
public function store(StoreEmployeeRequest $request)
    {
        if ($request->file()) {
            $upload_path = public_path('upload/employees');
            $generated_new_name = time() . '.' . $request->file('photo')->getClientOriginalExtension();
            $request->file('photo')->move($upload_path, $generated_new_name);
            $db_path = '/upload/employees/' . $generated_new_name;
            $data = $request->validated();
            $data['photo'] = $db_path;
            $employee = Employee::create($data);
            return new EmployeeResource($employee);
        }
    }

    public function show(Employee $employee)
    {
        return new EmployeeResource($employee);
    }

    public function update(UpdateEmployeeRequest $request, Employee $employee)
    {
        $employee->update($request->validated());

        return new EmployeeResource($employee);
    }


И метод submit для страницы create.

Добрый день.
Очень странно, метод store у контроллера работает, но update нет.

Вот контроллер.
public function store(StoreEmployeeRequest $request)
    {
        if ($request->file()) {
            $upload_path = public_path('upload/employees');
            $generated_new_name = time() . '.' . $request->file('photo')->getClientOriginalExtension();
            $request->file('photo')->move($upload_path, $generated_new_name);
            $db_path = '/upload/employees/' . $generated_new_name;
            $data = $request->validated();
            $data['photo'] = $db_path;
            $employee = Employee::create($data);
            return new EmployeeResource($employee);
        }
    }

    public function show(Employee $employee)
    {
        return new EmployeeResource($employee);
    }

    public function update(UpdateEmployeeRequest $request, Employee $employee)
    {
        $employee->update($request->validated());

        return new EmployeeResource($employee);
    }


И метод submit для страницы create.
onSubmit() {
      let form = new FormData();

      for (let key in this.form) {
        form.append(key, this.form[key]);
      }

      axios
        .post("/api/auth/employee", form)
        .then((res) => {
          console.log(res.data, "res");
          // this.$router.push({ name: "admin.employee" });
        })
        .catch((error) => {
          this.errors = error.response.data.errors;
          // this.form_submitting = false;
        });
    },


И тот же submit для страницы edit.

onSubmit() {
      const config = {
        headers: {
          "content-type": "multipart/form-data",
        },
      };
      let form = new FormData();

      for (let key in this.form) {
        form.append(key, this.form[key]);
      }

      axios
        .put("/api/auth/employee/" + this.$route.params.id, form, config)
        .then((res) => {
          console.log(res.data, "res");
          // this.$router.push({ name: "admin.employee" });
        })
        .catch((error) => {
          this.errors = error.response.data.errors;
          // this.form_submitting = false;
        });
    },
  },


Тут еще добавляются заголовки, но что с ними, что без них, но request в методе update контроллера пустой.

Поменял метод update, и request пустой.

public function update(Request $request, Employee $employee)
    {
        return response()->json([
            'result' => $request->all()
        ]);
        $employee->update($request->validated());

        return new EmployeeResource($employee);
    }

Почему?
  • Вопрос задан
  • 409 просмотров
Подписаться 1 Простой 2 комментария
Решения вопроса 1
serii81
@serii81 Автор вопроса
Я люблю phр...
Какие же программисты криворукие.
А еще хотят создать искусственный интелект.
А еще все так хвалят ларавель, а он на одних костылях построен.

Нашел решение, это убого.

onSubmit() {
            let form = new FormData();
            for (let key in this.form) {
                form.append(key, this.form[key]);
            }
            form.append('_method', 'PUT');

            axios
                .post("/api/auth/employee/" + this.$route.params.id, form)
                .then((res) => {
                    console.log(res.data, "res");
                    // this.$router.push({ name: "admin.employee" });
                })
                .catch((error) => {
                    this.errors = error.response.data.errors;
                    // this.form_submitting = false;
                });
        },
Ответ написан
Пригласить эксперта
Ваш ответ на вопрос

Войдите, чтобы написать ответ

Похожие вопросы