PUT 과제 코드 리뷰 부탁드립니다.
264
작성한 질문수 15
안녕하세요, 과제를 마쳤는데 더 효율이 좋은 코드가 있을 것 같아서 리뷰 좀 부탁드립니다.
name과 joinDate를 바꿔봤습니다.
public User updateUser(int id, User user) {
User updateUser = findOne(id);
if (findOne(id) != null) {
updateUser.setName(user.getName());
updateUser.setJoinDate(new Date());
return updateUser;
}
return null;
}
- UserDaoService.java
@PutMapping("/users/{id}")
private User updateUser(@PathVariable int id, @RequestBody User user) {
User updateUser = service.updateUser(id, user);
if (updateUser == null) {
throw new UserNotFoundException(String.format("ID[%s] not found", id));
}
return updateUser;
}
- UserController.java
| 설명
- Controller : Path와 RequestBody에 있는 id와 user 값을 받는다.
- Controller :UserDaoService에 있는 updateUser()메소드로 id와 user를 파라미터로 넘겨준다
- Service : findOne() 메소드를 통해 id에 대한 정보를 가져온다.
- Service : findOne()에 맞는 정보가 없을 때 null이 뜨게 되면 null이 리턴되게 해주고, null이 아니라면 update 로직을 그대로 이어나간다.
- Controller : 불러온 아이디에 setter를 통해 RequestBody에 있던 user 정보를 담아주고 리턴한다.
- Controller :updateUser() 메소드에서 리턴해 온 정보가 null이면 NotFoundException을 뱉는다.
| 테스트
http://localhost:8088/users/1
- 테스트는 성공
| 의문
- RequestBody에 요청 정보를 다 적어주면 굳이 PathVariable를 사용해야 하나 싶습니다.
- 지금 이 코드를 사용했을 때 RequestBody에 들어간 id 정보가 필요 없다는 것도 찝찝합니다.
코드가 틀렸거나, 설명을 참고하여 제가 잘 못 알고 있는 점이 있다거나, 개선점이 있다면 알려주시면 감사하겠습니다.
다른 과제 글 찾아보니 JPA로 하라는 말씀도 하시는 것 같은데 JPA말고 수업 중 사용한 본연의 코드 정도만 활용해서 해보고 싶습니다.
감사합니다.!
답변 1
1
안녕하세요, 이도원입니다.
올려주신 PUT 예제에서는 DB를 사용하지 않고 있어서, 전체 데이터를 Full scan해서 데이터를 검색해야 할 것 같습니다. 작업하신 내용에 크게 수정할 내용은 없는 것 같습니다.
추가로, PathVariable에 대한 부분은 PUT요청에서 사용자에 대한 수정을 위한 ID는 URI로 전달 받고, 그외 수정할 데이터를 Request Body로 전달 받도록 역할을 구분하였습니다. Request Body에서 모든 데이터를 다 전달 받을 수도 있지만, URI에서 세부적인 ID를 전달 받음으로써 데이터의 검색을 처리하고, 수정이나 추가 작업을 위해 Request Body를 분리하는 것이 RMM(Richardson Maturity Model)에 더 적합한 형태가 될 것 같습니다.
감사합니다.
JPA
0
71
1
jpa dependency를 추가하고 SecurityConfig클래스에서 오류가 납니다.
0
84
1
웹 브라우저 400 bad request
0
87
1
@Size는 되는데 @Past는 안 됩니다.
0
77
1
pdf 자료는 없나요?
0
95
2
locale 정보가 null 이면 무조건 messages_ko.properties이 호출 되는 문제
0
103
2
Swagger 강의, Unable to infer base url 이거 뜨시는 분들 도움되시라고
0
136
1
강의에서나온 화면 피피티
0
169
1
HelloWorldBean 관련 에러
0
194
2
Swagger API 3.x 오류..
0
231
1
java: variable message not initialized in the default constructor 에러는 어찌하면 좋을까요?
1
293
1
현재 GIT에 올리신 소스를 실행해봤습니다.
0
203
2
고양이 소리가 귀엽네요 !!
0
150
2
git에서 소스받고 실습중인데
0
129
1
post가 안되요
0
119
1
한국어 같은 경우 언어코드인 messages_ko.properties 로 생성하는게 더 좋지 않나요?
0
177
2
리턴타입으로서 EntityModel<User> 와 ResponseEntity질문
0
113
1
예외처리쪽 관련 질문있습니다.
0
165
2
엔티티가 바로 응답으로 나가도 되나요??
0
240
2
안녕하세여 Cannot invoke "co.kr.joneconsulting.resfulservice.repository.PostRepository.save(Object)" because "this.postRepository" is null
0
151
2
사용자 등록하고 나서 H2 에서 보면 신규 사용자의 password, ssn 이 null 로 되어 있습니다.
0
146
2
ApplictionContext 질문
0
199
2
롬북이 안먹히는것같아요
0
162
1
인텔리제이에서스프링부트 파일 실행하면
0
244
1





