inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

스프링 MVC 2편 - 백엔드 웹 개발 활용 기술

쿠키와 보안 문제

안녕하세요 영한님 쿠키 관련 질문이 있습니다. :)

430

백엔드

작성한 질문수 17

1

안녕하세요 영한님 :) 

강의 정말 잘 듣고 있습니다.

 

다름이 아니라 질문이 있는데요 

쿠키를 설정할 때 하위 도메인은 같이 쿠키가 공유 된다고 하셨었는데

 

하위 도메인이 아니라 아예 다른 도메인간에 쿠키를 공유하거나

다른 도메인에 쿠키를 설정할 수 도 있는 것인가요??

 

안된다는 글도 봤었고

SameSite 속성을 None 으로 설정하면 된다는 것도 보았었는데

 

정말 다른 도메인간에 쿠키를 설정 또는 공유할 수 있는 것인지

궁금합니다. :) 

 

ex)

exampleAAA.com

exampleBBB.com

 

이렇게 서로 다른 도메인간 쿠키 공유 or 설정

MVC spring

답변 1

7

나무늘보

안녕하세요, 백엔드 님. 공식 서포터즈 codesweaver 입니다.

 

타 도메인 쿠키에 관하여.

타 도메인에 대한 쿠키는 접근이 불가합니다.

 

SameSite 에 관하여.

우선 퍼스트 파티 쿠키와 서드 파티 쿠키라는 개념을 알 필요가 있습니다. 예를들어 example.com 사이트에서 product.com 의 대표상품 이미지를 사용하고 있는 경우를 생각하겠습니다.

.

클라이언트가 example.com 사이트에 접속합니다. example.com의 대부분의 리소스(CSS, JS파일 등)은 example.com에서 제공하지만, 상품 이미지는 example.com이 아닌 product.com이라는 외부에서 호출하고 있습니다.

.

이 때 클라이언트는 example.com 의 리소스를 요청할떄는 example.com의 쿠키를, product.com의 이미지를 요청할때는 product.com의 쿠키를 전달하게 됩니다. 클라이언트는 example.com 사이트에 접속한것이기에 example.com의 쿠키는 '퍼스트 파티 쿠키', product.com의 쿠키는 '서드 파티 쿠키'라고 구분 합니다.

 

SameSite는 이 중 서드 파티 쿠키에 대한 정책입니다. 이 값은 기본적으로 None입니다. None은 '서드 파티 쿠키를 항상 보낸다'라는 뜻입니다. 그러나 이러한 정책이 CSRF 같은 해킹 공격에 취약하다는 문제가 있기에 이를 해결하기 위해 크롬 같은 브라우저는 SameSite 기본 값이 Lax (예외상황을 제외하고 서드 파티 쿠키를 전송하지 않음) 으로 변경하기도 하였습니다. 

 

SameSite는 이처럼 서드 파티 쿠키에 대한 정책이며 이를 설정한다고 해도 타 도메인의 쿠키에 접근할 수 없습니다.

.
감사합니다.

0

백엔드

넵넵 잘 이해했습니다.

좋은 답변에

감사드립니다. :)

이미지 업로드와 db 트랜잭션 묶는법

0

43

1

Could not resolve org.springframework.boot:spring-boot-starter-validation:2.4.4

0

53

2

MessageSourceTest 코드

0

49

1

인터셉터 에러 설정

0

48

1

resolveArgument()메서드 질문

0

57

1

43강 검증1 에서 실패 로직 관련 질문있습니다.

0

58

2

타임리프 3.X 버전 rendering, serializer 에러 해결 방법

2

133

3

스프링 빈에 등록이 안되는거 같은데 어떻게 하면 좋을까요?ㅠㅠ

0

90

3

pdf 오타 문의

0

57

1

ItemUpdateForm 검증 관련 질문입니다.

0

49

1

22page 링크 주소 변경

0

59

2

특정 데이터와 파일을 함께 저장 시, 테이블 구조 질문

0

53

1

섹션3번 수업에 대한 질문입니다.

0

80

2

@Autowired 보다 더 좋은 방법이 어떤 걸까요?

0

85

2

타입컨버터 가 람다랑 비슷해 보이는데 저의 생각이 맞는지?.

0

66

1

자바스크립트 인라인에서 객체 직렬화 시 오류가 납니다

0

142

3

스프링부트 - 오류페이지2 에서 500.html 에서 쓰인 객체 질문

0

63

1

톰캣 에러 페이지가 안보입니다.

0

104

2

apiEceptionController에서 센드 에러 호출하면 안되는지?

0

81

1

세션 타임아웃시 쿠키 삭제 방법이 없나요?

0

118

2

ApiExceptionController 질문드립니다.

0

64

1

셀렉박스 챕터에서 option value에 ==배송 방식 선택== 이것을 넣은 이유가 궁금함, 이렇게 구상해도 되는지?

0

66

1

MemberRepository 필드의 fianl 선언 유무

0

85

2

혹시 index.html 에서는 fragment 사용이 안되는건가요

0

58

1