>  기사  >  백엔드 개발  >  브라우저는 Golang 백엔드에서 보낸 쿠키를 저장하지 않습니다.

브라우저는 Golang 백엔드에서 보낸 쿠키를 저장하지 않습니다.

PHPz
PHPz앞으로
2024-02-14 23:30:091098검색

브라우저는 Golang 백엔드에서 보낸 쿠키를 저장하지 않습니다.

php 편집기 Strawberry는 브라우저가 쿠키를 저장하는 것과 관련된 문제를 소개하기 위해 왔습니다. 때때로 Golang 백엔드를 사용하여 쿠키를 보낼 때 브라우저가 쿠키를 저장하지 않는 경우가 있습니다. 이는 브라우저 개인 정보 보호 설정이나 코드의 일부 문제 등 여러 가지 이유 때문일 수 있습니다. 이 기사에서는 이 문제를 자세히 살펴보고 브라우저가 Golang 백엔드에서 보낸 쿠키를 올바르게 저장하도록 보장하는 몇 가지 솔루션을 제공할 것입니다. 시작하자!

질문 내용

이 질문을 여러 번 받았지만 대부분의 답변을 시도했지만 여전히 작동하지 않는다는 것을 알고 있습니다.

net/http 패키지와 js 프론트엔드가 포함된 golang API가 있습니다. 기능이 있어요

으아악

이 함수는 사용자가 로그인할 때 호출되며 다른 모든 엔드포인트로 전송되기를 원합니다. 이는 우편 배달부의 기대와 일치합니다. 그러나 브라우저의 경우 쿠키를 기억하거나 다른 엔드포인트로 보내도록 할 수 없는 것 같습니다.

엔드포인트를 사용한 js 예시

으아악

golang 및 기타 답변에서 samesite 属性,或在 js 中使用 credential: "include" 설정을 시도했지만 성공하지 못했습니다.

해결 방법

댓글의 토론 덕분에 이 문제에 대한 몇 가지 팁을 찾았습니다.

쿠키 저장(API와 프런트엔드가 동일한 호스트에 있음)

저는 document.cookie来保存cookie。我手动设置选项,因为在 api fetch 的响应上调用 res.cookie 仅返回值。一个例子是 document.cookie = `gocookie=${res.cookie};路径=/;域=localhost;를 사용합니다.

쿠키 보내기

이 질문은 이전 질문과 댓글에서 다시 답변되었습니다. 문제는 credential:'include' 而不是正确的 credentials:'include'(복수)를 사용했다는 것입니다.

코르 앤 쿠키

API와 프런트엔드가 동일한 호스트에 있지 않으면 API와 프런트엔드를 모두 수정해야 합니다.

프런트엔드

쿠키가 필요한 것은 프런트엔드가 아니라 API이므로 쿠키에는 API의 도메인이 있어야 합니다. 따라서 보안상의 이유로 다른 도메인(프런트엔드)의 도메인(api)에 대해서는 쿠키를 설정할 수 없습니다. 해결책은 응답 헤더에 set-cookie 헤더를 반환하는 API 엔드포인트로 사용자를 리디렉션하는 것입니다. 이 솔루션은 추가 도메인(API가 보낸 이후의 API 도메인)에 쿠키를 등록하도록 브라우저에 지시합니다.

또한 프런트엔드에 credentials:'include'를 포함해야 합니다.

api

몇 가지 헤더를 설정해야 합니다. 내가 설정한 것은

으아악

프런트엔드가 사용자를 리디렉션하고 응답에 쿠키를 설정하는 엔드포인트를 노출해야 합니다. 이를 생략할 수 있으며 API의 도메인을 수동으로 설정하는 대신 브라우저가 자동으로 도메인을 채웁니다.

cors를 처리하고 js가 쿠키를 성공적으로 보내도록 하려면 쿠키에 samesite=nonesecure 속성을 설정하고 https를 통해 API를 제공해야 합니다(단순화를 위해 ngrok를 사용했습니다).

이렇게

으아악

사용 시의 차이점도 읽어 보시기 바랍니다. localstoragedocument.cookie이것은 제가 겪었던 문제 중 하나입니다.

도움이 되기를 바랍니다.

위 내용은 브라우저는 Golang 백엔드에서 보낸 쿠키를 저장하지 않습니다.의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
이 기사는 stackoverflow.com에서 복제됩니다. 침해가 있는 경우 admin@php.cn으로 문의하시기 바랍니다. 삭제