BoardRepository
@RequiredArgsConstructor @Repository public class BoardRepository { private final EntityManager em; @Transactional public Board save(Board board) { //순수했던 애가 (우유가) em.persist(board); //어딘가에 잠깐 담겼죠? (초코우유가 됨) return board; //return도 안해도 됨 }
persist는 테스트할 필요는 없을 것 같다!
내가 만든 것도 아니고, 이미 잘 만들어져서 검증된 프레임워크에 들어간 라이브러리니까!
SaveDTO 만들기 - BoardRequest
ORM 인서트할 때, User 객체에 id만 들어가 있어도 된다. (즉, 비영속 객체도 된다)
그러나 추천 안함!!!!!! 없을 수도 있기 때문에 조회해서(영속화 시켜서) 넣어라!
영속화가 되었다 = DB에 있다 = 안전하다 (+세션도 괜찮다)
없는 걸 넣으면 DB가 죄다 망가져 버리기 때문…
public class BoardRequest { @Data public static class SaveDTO { private String title; private String content; //DTO를 클라이언트로부터 받아서, PC에 전달하기 위해 사용! //이거 save하려면 Entity로 바꿔야함! public Board toEntity(User user) { return Board.builder() .title(title) .content(content) .user(user) //세션 유저를 담아줄 곳 .build(); } } }
ORM으로 변경 되었기 때문에 User 객체를 넣어줘야함! User 객체는 세션에 있기 때문에 나중에 여기에 session을 넣어주면 됨
만약 user id를 넣고 싶으면 native쿼리를 직접 작성해야 함!
여기 builder 사용하려면 Board에 @Builder 가 있어야 함~!
이 User 객체에 pk 키만 들어가있어도 됨! 그러나 위험한 코드. 1번이 없을 수도 있잖아.
그러나 세션은 없을 수가 없기 때문에 안전하다! (세션에 있는 유저 객체는 100% 있으니!)
5번으로 한 번 조회를 해서, 영속성 객체로 만들고?? 머지??
5번 넣으면 (5번 유저가 없으니) FK 위배 라고 터짐!
애가 FK 제약 조건도 걸어준다는 것
3번 넣으면 작성자가 3번으로 들어감!
BoardController
@RequiredArgsConstructor @Controller public class BoardController { private final BoardRepository boardRepository; private final HttpSession session; @PostMapping("/board/save") public String save(BoardRequest.SaveDTO requestDTO){ User sessionUser = (User) session.getAttribute("sessionUser"); //권한 체크는 생략 boardRepository.save(requestDTO.toEntity(sessionUser)); return "redirect:/"; }
DTO를 만들었기 때문에 코드도 깔끔해지는 것!
toEntity = insert하는 DTO에서만 만든다!
로그인 안하고 board/save-form 에 들어가서 글을 써보았다.
그럼 이 부분이… User 객체가 null로 들어가겠지?
ORM은 객체가 들어간다 (특이)
그러면 봐라!! 로그인 안하고 게시글을 쓴 귀신이 있음 !!!
→ 개인 정보법 위반 → 신고 당하고 → 잡혀가고 → 집유 살고 → 인생 망하고
→ 오어스를 써라
만약 이런 데이터가 들어오면 아무도 모르게… 바로 DB에 들어가서 delete를 하고, 내가 delete를 했다는 로그 또한 싹 지워버리기
제대로 로그인 후 글쓰기
shift + enter 치면 줄 밑으로 내려옴
Share article