Метод POST не поддерживается – Spring

Я пытаюсь отправить запрос на публикацию в Spring, но всегда получаю эту ошибку: метод POST не поддерживается.

Я также получаю эту ошибку при попытке опубликовать данные

Я использую eclipse и Spring Boot, мой проект подключен к базе данных Postgres.

Соединение с моей базой данных работает нормально

Программа должна была получать данные из HTML-формы и сохранять их в моей базе данных.

Это моя сущность:

package entity;

import jakarta.persistence.Entity;
import jakarta.persistence.GeneratedValue;
import jakarta.persistence.GenerationType;
import jakarta.persistence.Id;
import jakarta.persistence.Table;

@Entity
@Table(name = "xromy")
public class xRomy {

    @Id
    @GeneratedValue(strategy = GenerationType.IDENTITY)
    // muss wohl public sein
    public Integer id;
    private String name;
    private Integer alter;

    public xRomy() {

    }

    public xRomy(String name, Integer alter) {
        this.name = name;
        this.alter = alter;
    }

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    public Integer getAlter() {
        return alter;
    }

    public void setAlter(Integer alter) {
        this.alter = alter;
    }

    @Override
    public String toString() {
        return "xRomy{" + "\n id = " + id + "\n name = " + name + "\n alter = " + alter + "}";
    }
}

мой репозиторий:

package repository;

import org.springframework.data.jpa.repository.JpaRepository;
import org.springframework.stereotype.Repository;

import entity.xRomy;

@Repository
public interface RomyRep extends JpaRepository<xRomy, Integer> {

}

мой контроллер:

package controller;

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.validation.BindingResult;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.RestController;
import org.springframework.web.servlet.ModelAndView;

import entity.xRomy;
import jakarta.validation.Valid;
import repository.RomyRep;

@RestController
public class ConttrollNeuDs {

    @Autowired
    RomyRep romyRep;

    // um neuen Eintrag eizugeben
    @GetMapping("/neuerEintrag")
    public ModelAndView getName() {
        ModelAndView model = new ModelAndView("newName");
        model.addObject("xromy", new xRomy());
        return model;
    }

    // sollte neuen Eintrag speichern
    @PostMapping("/save")
    public String postNew(@Valid xRomy xromy, BindingResult result, ModelAndView model) {
        model.addObject("xromy", xromy);
        xRomy Xromy = new xRomy();
        Xromy.setName(xromy.getName());
        Xromy.setAlter(xromy.getAlter());
        romyRep.save(Xromy);
        return "redirect:/testView";
    }
}

мой pom.xml:

<project xmlns = "http://maven.apache.org/POM/4.0.0" xmlns:xsi = "http://www.w3.org/2001/XMLSchema-instance"
    xsi:schemaLocation = "http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>
    <parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>3.3.2</version>
        <relativePath/> <!-- lookup parent from repository -->
    </parent>
    <groupId>com.example</groupId>
    <artifactId>hilfe</artifactId>
    <version>0.0.1-SNAPSHOT</version>
    <name>hilfe</name>
    <description>Demo project for Spring Boot</description>
    <url/>
    <licenses>
        <license/>
    </licenses>
    <developers>
        <developer/>
    </developers>
    <scm>
        <connection/>
        <developerConnection/>
        <tag/>
        <url/>
    </scm>
    <properties>
        <java.version>17</java.version>
    </properties>
    <dependencies>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-data-jpa</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-thymeleaf</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>

        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-devtools</artifactId>
            <scope>runtime</scope>
            <optional>true</optional>
        </dependency>
        <dependency>
            <groupId>org.postgresql</groupId>
            <artifactId>postgresql</artifactId>
            <scope>runtime</scope>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-test</artifactId>
            <scope>test</scope>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-validation</artifactId>
        </dependency>
    </dependencies>

    <build>
        <plugins>
            <plugin>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-maven-plugin</artifactId>
            </plugin>
        </plugins>
    </build>

</project>

и мой файл application.properties:

spring.application.name=hilfe
#Datenbank Vb
spring.datasource.url=jdbc:postgresql://localhost:5433/romy
spring.datasource.username=
spring.datasource.password=
spring.datasource.driver-class-name=org.postgresql.Driver
#
spring.jpa.hibernate.ddl-auto=update
spring.jpa.properties.hibernate.dialect=org.hibernate.dialect.PostgreSQLDialect
#
spring.mvc.static-path-pattern=/resources/**
#test
spring.jpa.generate-ddl=true

имя пользователя и пароль не указаны, но, как я уже сказал, соединение с базой данных работает нормально.

Я перепробовал почти все и прочитал здесь много сообщений о подобных проблемах, но не смог найти решения.

Не уверен, в чем ваша проблема, вы определили только @GetMapping для URL-адреса, к которому обращаетесь, поэтому да, он не будет работать с запросом POST.

M. Deinum 24.07.2024 13:07

значит URL-адрес @GetMapping и @PostMapping должен быть одинаковым?

adi 24.07.2024 13:23

Либо так, либо в данном случае опубликуйте сообщение на правильный URL /save.

M. Deinum 24.07.2024 13:35

Более того, я вижу, что идентификатор генерируется автоматически, хотя других проверок атрибутов класса xRomy нет, удалите метод @Valid из @PostMapping и убедитесь, что вы отправляете запрос типа POST к URL-адресу /save.

Harsh 24.07.2024 13:47

удаление @Valid действительно сработало

adi 24.07.2024 14:25
Пользовательский скаляр GraphQL
Пользовательский скаляр GraphQL
Листовые узлы системы типов GraphQL называются скалярами. Достигнув скалярного типа, невозможно спуститься дальше по иерархии типов. Скалярный тип...
Как вычислять биты и понимать побитовые операторы в Java - объяснение с примерами
Как вычислять биты и понимать побитовые операторы в Java - объяснение с примерами
В компьютерном программировании биты играют важнейшую роль в представлении и манипулировании данными на двоичном уровне. Побитовые операции...
Поднятие тревоги для долго выполняющихся методов в Spring Boot
Поднятие тревоги для долго выполняющихся методов в Spring Boot
Приходилось ли вам сталкиваться с требованиями, в которых вас могли попросить поднять тревогу или выдать ошибку, когда метод Java занимает больше...
Полный курс Java для разработчиков веб-сайтов и приложений
Полный курс Java для разработчиков веб-сайтов и приложений
Получите сертификат Java Web и Application Developer, используя наш курс.
2
5
85
1
Перейти к ответу Данный вопрос помечен как решенный

Ответы 1

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

Единственная конечная точка, которая принимает метод POST в вашем приложении, — это /save, потому что это единственное место, где вы определили свой @PostMapping, поэтому для отправки запроса POST вам придется использовать этот URL-адрес:

localhost:8080/save

Также убедитесь, что тело вашего запроса действительно, поскольку вы добавили аннотацию @Valid.

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