Невозможно получить правильный ответ GET - PullRequest
0 голосов
/ 29 мая 2019

Я пытаюсь реализовать метод GET и POST в Spring-Boot.При вызове метода GET не получен правильный ответ.

Мой класс контроллера

@RestController
@RequestMapping("api/public")
public class PublicRestApiController {

@GetMapping("users")
public List<User> users(){
    return this.userRepository.findAll();
}

@PostMapping(path="/save")
@ResponseBody public User insertusers( @RequestBody UserRequest requestUser){
    User user = new User(requestUser.getUsername(),passwordEncoder.encode(requestUser.getPassword()),requestUser.getRoles(),requestUser.getPermissions());
    try { 
        user = this.userRepository.save(user);
        return user;
    }
    catch(Error e) {
        return user;
    }
}

}

Класс UserRequest

public class UserRequest {

public String getUsername() {
    return username;
}
public void setUsername(String username) {
    this.username = username;
}
public String getPassword() {
    return password;
}
public void setPassword(String password) {
    this.password = password;
}
public int getActive() {
    return active;
}
public void setActive(int active) {
    this.active = active;
}
public String getRoles() {
    return roles;
}
public void setRoles(String roles) {
    this.roles = roles;
}
public String getPermissions() {
    return permissions;
}
public void setPermissions(String permissions) {
    this.permissions = permissions;
}
private String username;
private String password;
private int active;
private String roles = "";
private String permissions = "";

}

Класс пользователя

@Entity
@Table(name = "USER_DETAILS")
public class User {

@Id
@Column
@GeneratedValue(strategy = GenerationType.AUTO)
private int id;

@Column(nullable = false)
private String username;

@Column(nullable = false)
private String PASSWORD;

@Column
private int ACTIVE;

@Column
private String ROLES = "";

@Column
private String PERMISSIONS = "";

public User(String username, String password, String roles, String permissions){
    this.username = username;
    this.PASSWORD = password;
    this.ROLES = roles;
    this.PERMISSIONS = permissions;
    this.ACTIVE = 1;
}

public User(){}

public int getId() {
    return id;
}

public String getUsername() {
    return username;
}

public String getPassword() {
    return PASSWORD;
}

public int getActive() {
    return ACTIVE;
}

public String getRoles() {
    return ROLES;
}

public String getPermissions() {
    return PERMISSIONS;
}

public void setId(int id) {
    this.id = id;
}

public void setUsername(String username) {
    this.username = username;
}

public void setPassword(String password) {
    this.PASSWORD = password;
}

public void setActive(int active) {
    this.ACTIVE = active;
}

public void setRoles(String roles) {
    this.ROLES = roles;
}

public void setPermissions(String permissions) {
    this.PERMISSIONS = permissions;
}
}

UserRepositoryclass

@Repository
public interface UserRepository extends JpaRepository<User, Long>{

}

Метод POST работает нормально, но при вызове метода GET поле id получает значение по умолчанию 0. Не получается получить правильные значения ID.А также во время работы сервера, если я вызываю метод POST, он вставляет данные в базу данных, но эти вновь вставленные данные не получают методом GET. Получаются только те данные, которые я уже вставил в базу данных.

Это данные в базе данных

Это ответ, который я получаю из метода GET

Ответы [ 2 ]

1 голос
/ 29 мая 2019

Ваш класс USER имеет первичный ключ с типом int, и в вашем репозитории вы расширили класс USER с long, который должен быть целым, как показано ниже

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

 @Repository
 public interface UserRepository extends JpaRepository<User, Integer>{

 }

ОБНОВЛЕНИЕ:

 @Autowired UserRepository userRepository;

         @GetMapping("users")
         public List<User> users(){
              return userRepository.getAllUsers();
         }

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

 @Repository
 public interface UserRepository extends JpaRepository<User, Integer>{
      @Query(value="select * from USER_DETAILS",nativeQuery=true)
      List<User> getAllUsers();
 }

импорт @Query из import org.springframework.data.jpa.repository.Query;


ОБНОВЛЕНИЕ2: Идельструктура проекта состоит в том, чтобы иметь различные пакеты в соответствии с поведением класса.

  • Контроллер
  • Сервис
  • Репозиторий
  • Модели или сущности
  • DTOs, DAOs
  • Безопасность, Конфигурация и т. Д. Согласно требованиям

     //Controller
     @yourMapping
     public returnType method1()
     {
         myService.performBusinessLoginonMethod1(...) //if you are using services
         myReposiroty.DBOpertaion(...) //as per above case
     }

     //Service: myService
     returnType  performBusinessLoginonMethod1(...) 
     {
         myRepository.DBOpertaion(...)
     }

     //Repository: myRepository     
     @Modifying // import org.springframework.data.jpa.repository.Modifying;
     @Query(...)
     returnType DBOpertaion(...)
0 голосов
/ 29 мая 2019

Вы не отвечаете должным образом.Попробуйте это.

    @GetMapping("users")
public ResponseEntity<List<Article>> users(){
        return new ResponseEntity<List<Article>>(this.userRepository.findAll(), HttpStatus.OK);
}
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...