[스프링 부트 쇼핑몰 프로젝트 with JPA] 14. 장바구니 담기

2023. 10. 16. 20:00·Web & Android/스프링 부트 쇼핑몰 프로젝트 with JPA
목차
  1. 1. CartItemDto
  2. 2. Cart Entity
  3. 3. CartItem Entity
  4. 4. CartRepository
  5. 5. CartItemRepository
  6. 6. CartService 생성
  7. 7. CartController 생성
  8. 8. 제품 상세 페이지 장바구니 담기
이 내용은 스프링 부트 쇼핑몰 프로젝트 with JPA 책을 학습한 내용입니다.

1. CartItemDto

  • 제품 상세 페이지에서 장바구니에 담을 상품 Id 와 수량을 전달 받을 DTO 객체 생성
@Getter
@Setter
public class CartItemDto {
@NotNull(message = "상품 아이디는 필수 입력 값입니다.")
private Long itemId; // 상품 아이디
@Min(value = 1, message = "최소 1개 이상 담아주세요.")
private int count; // 상품 수량
}

2. Cart Entity

  • 회원 한 명당 1개의 장바구니를 갖으므로 처음 장바구니에 상품을 담을 때는 해당 회원의 장바구니를 생성해야함
  • 멤버를 파라미터로 받아서 장바구니를 생성하는 static 메소드 추가
// 회원의 장바구니 생성
public static Cart createCart(Member member) {
Cart cart = new Cart();
cart.setMember(member);
return cart;
}

3. CartItem Entity

  • 장바구니에 담을 CartItem 객체를 생성하는 메소드 추가
  • 장바구니에 담겨 있는 상품을 또 장바구니로 담았을 경우 수량을 증가시키는 메소드 추가
// 장바구니에 담을 상품 엔티티를 생성하는 메소드
public static CartItem createCartItem(Cart cart, Item item, int count) {
CartItem cartItem = new CartItem();
cartItem.setCart(cart);
cartItem.setItem(item);
cartItem.setCount(count);
return cartItem;
}
// 장바구니에 담을 수량을 증가시켜 주는 메소드
public void addCount(int count) {
this.count += count;
}

4. CartRepository

  • 현재 로그인한 유저의 장바구니(Cart)를 찾기 위해서 쿼리 메소드 추가
public interface CartRepository extends JpaRepository<Cart, Long> {
// 현재 로그인한 회원의 Cart 엔티티를 찾기 위한 메소드
Cart findByMemberId(Long memberId);
}

5. CartItemRepository

  • 상품이 장바구니에 들어있는지 조회하는 쿼리 메소드 추가
public interface CartItemRepository extends JpaRepository<CartItem, Long> {
CartItem findByCartIdAndItemId(Long cartId, Long itemId);
}

6. CartService 생성

  • 유저의 장바구니가 존재하지 않다면 생성
  • 장바구니 안에 해당 상품이 존재한다면 수량을 증가시키고, 그렇지 않다면 추가
@Service
@RequiredArgsConstructor
@Transactional
public class CartService {
private final ItemRepository itemRepository;
private final MemberRepository memberRepository;
private final CartRepository cartRepository;
private final CartItemRepository cartItemRepository;
private final OrderService orderService;
public Long addCart(CartItemDto cartItemDto, String email) {
Item item = itemRepository.findById(cartItemDto.getItemId()).orElseThrow(EntityNotFoundException::new);
Member member = memberRepository.findByEmail(email);
Cart cart = cartRepository.findByMemberId(member.getId());
if(cart == null) {
cart = Cart.createCart(member);
cartRepository.save(cart);
}
CartItem savedCartItem = cartItemRepository.findByCartIdAndItemId(cart.getId(), item.getId());
if(savedCartItem != null) {
savedCartItem.addCount(cartItemDto.getCount());
return savedCartItem.getId();
} else {
CartItem cartItem = CartItem.createCartItem(cart, item, cartItemDto.getCount());
cartItemRepository.save(cartItem);
return cartItem.getId();
}
}

7. CartController 생성

  • 제품 상세 페이지에서 넘어온 CartItemDto 객체와 email 을 파라미터로 CartService.addCart() 메소드를 수행
@Controller
@RequiredArgsConstructor
public class CartController {
private final CartService cartService;
@PostMapping("/cart")
public @ResponseBody ResponseEntity order(@RequestBody @Valid CartItemDto cartItemDto, BindingResult bindingResult, Principal principal) {
if(bindingResult.hasErrors()) {
StringBuilder sb = new StringBuilder();
List<FieldError> fieldErrors = bindingResult.getFieldErrors();
for(FieldError fieldError : fieldErrors) {
sb.append(fieldError.getDefaultMessage());
}
return new ResponseEntity<String> (sb.toString(), HttpStatus.BAD_REQUEST);
}
String email = principal.getName();
Long cartItemId;
try {
cartItemId = cartService.addCart(cartItemDto, email);
} catch (Exception e) {
return new ResponseEntity<String>(e.getMessage(), HttpStatus.BAD_REQUEST);
}
return new ResponseEntity<Long>(cartItemId, HttpStatus.OK);
}

8. 제품 상세 페이지 장바구니 담기

  • "장바구니 담기" 버튼을 누르면 수행되는 Ajax 코드
function addCart(){
var token = $("meta[name='_csrf']").attr("content");
var header = $("meta[name='_csrf_header']").attr("content");
var url = "/cart";
var paramData = {
itemId : $("#itemId").val(),
count : $("#count").val()
};
var param = JSON.stringify(paramData);
$.ajax({
url : url,
type : "POST",
contentType : "application/json",
data : param,
beforeSend : function(xhr){
/* 데이터를 전송하기 전에 헤더에 csrf값을 설정 */
xhr.setRequestHeader(header, token);
},
dataType : "json",
cache : false,
success : function(result, status){
alert("상품을 장바구니에 담았습니다.");
location.href='/';
},
error : function(jqXHR, status, error){
if(jqXHR.status == '401'){
alert('로그인 후 이용해주세요');
location.href='/members/login';
} else{
alert(jqXHR.responseText);
}
}
});
}
  • "장바구니 담기" 버튼을 누르면 Ajax 코드 수행되게 설정
<button type="button" class="btn btn-light border border-primary btn-lg" onclick="addCart()">장바구니 담기</button>
저작자표시 비영리 변경금지 (새창열림)

'Web & Android > 스프링 부트 쇼핑몰 프로젝트 with JPA' 카테고리의 다른 글

[스프링 부트 쇼핑몰 프로젝트 with JPA] 16.장바구니 상품 삭제 & 주문  (0) 2023.10.16
[스프링 부트 쇼핑몰 프로젝트 with JPA] 15. 장바구니 조회  (1) 2023.10.16
[스프링 부트 쇼핑몰 프로젝트 with JPA] 13. 주문 취소  (0) 2023.10.16
[스프링 부트 쇼핑몰 프로젝트 with JPA] 12. 구매 내역 조회  (0) 2023.10.16
[스프링 부트 쇼핑몰 프로젝트 with JPA] 11. 상품 주문  (1) 2023.10.16
  1. 1. CartItemDto
  2. 2. Cart Entity
  3. 3. CartItem Entity
  4. 4. CartRepository
  5. 5. CartItemRepository
  6. 6. CartService 생성
  7. 7. CartController 생성
  8. 8. 제품 상세 페이지 장바구니 담기
'Web & Android/스프링 부트 쇼핑몰 프로젝트 with JPA' 카테고리의 다른 글
  • [스프링 부트 쇼핑몰 프로젝트 with JPA] 16.장바구니 상품 삭제 & 주문
  • [스프링 부트 쇼핑몰 프로젝트 with JPA] 15. 장바구니 조회
  • [스프링 부트 쇼핑몰 프로젝트 with JPA] 13. 주문 취소
  • [스프링 부트 쇼핑몰 프로젝트 with JPA] 12. 구매 내역 조회
woojin._.
woojin._.
여러가지 개발을 해보며 발생하는 이야기들에 대한 블로그입니다:)
  • woojin._.
    Jin's Dev Story
    woojin._.
  • 전체
    오늘
    어제
    • 분류 전체보기 (829)
      • Tools (25)
        • eGovFrame (3)
        • GeoServer (3)
        • QGIS (2)
        • LabelImg (2)
        • Git (6)
        • GitHub (1)
        • Eclipse (7)
        • Visual Studio (1)
      • Web & Android (121)
        • SpringBoot (37)
        • Three.js (2)
        • Spring Data JPA (9)
        • 스프링 부트 쇼핑몰 프로젝트 with JPA (25)
        • Thymeleaf (4)
        • Spring Security (15)
        • Flutter (29)
      • Programming Language (61)
        • JAVA (27)
        • JavaScript (14)
        • Dart (2)
        • Python (15)
        • PHP (3)
      • Database (43)
        • PostgreSQL (32)
        • MYSQL (7)
        • Oracle (3)
        • MSSQL (1)
      • SERVER (17)
        • TCP_IP (3)
        • 리눅스 (7)
        • AWS (7)
      • Coding Test (445)
        • 백준[JAVA] (108)
        • 프로그래머스[JAVA] (260)
        • 알고리즘 고득점 Kit[JAVA] (3)
        • SQL 고득점 Kit[ORACLE] (74)
      • CS 지식 (49)
        • [자료구조] (14)
        • [네트워크] (12)
        • [데이터베이스] (10)
        • [알고리즘] (9)
        • [운영체제] (4)
      • 기타 (6)
      • 자격증 & 공부 (62)
        • 정보처리기사 (2)
        • SQLD (6)
        • 네트워크관리사 2급 (5)
        • 리눅스마스터 1급 (44)
        • 리눅스마스터 2급 (1)
        • ISTQB (3)
        • 시스템보안 (1)
  • 블로그 메뉴

    • 홈
    • 태그
    • 방명록
  • 인기 글

  • 태그

    데이터베이스
    리눅스
    프로그래머스
    Flutter
    python
    programmers
    CS지식
    데이터
    Java
    리눅스마스터
    spring
    springboot
    Linux
    CS
    JPA
    pcce 기출문제
    DB
    스프링부트
    Spring Security
    백준
    시큐리티
    Oracle
    리눅스마스터 1급
    플러터
    스프링 부트 쇼핑몰 프로젝트 with JPA
    자바
    baekjoon
    스프링
    postgresql
    backjoon
  • 최근 글

  • hELLO· Designed By정상우.v4.10.0
woojin._.
[스프링 부트 쇼핑몰 프로젝트 with JPA] 14. 장바구니 담기

개인정보

  • 티스토리 홈
  • 포럼
  • 로그인
상단으로

티스토리툴바

단축키

내 블로그

내 블로그 - 관리자 홈 전환
Q
Q
새 글 쓰기
W
W

블로그 게시글

글 수정 (권한 있는 경우)
E
E
댓글 영역으로 이동
C
C

모든 영역

이 페이지의 URL 복사
S
S
맨 위로 이동
T
T
티스토리 홈 이동
H
H
단축키 안내
Shift + /
⇧ + /

* 단축키는 한글/영문 대소문자로 이용 가능하며, 티스토리 기본 도메인에서만 동작합니다.