• 카테고리

    질문 & 답변
  • 세부 분야

    웹 개발

  • 해결 여부

    미해결

HTTP 메서드의 안전성을 따지는 목적이 무엇인가요???

22.05.10 13:38 작성 조회수 293

0

학습하는 분들께 도움이 되고, 더 좋은 답변을 드릴 수 있도록 질문전에 다음을 꼭 확인해주세요.

1. 강의 내용과 관련된 질문을 남겨주세요.
2. 인프런의 질문 게시판과 자주 하는 질문(링크)을 먼저 확인해주세요.
(자주 하는 질문 링크: https://bit.ly/3fX6ygx)
3. 질문 잘하기 메뉴얼(링크)을 먼저 읽어주세요.
(질문 잘하기 메뉴얼 링크: https://bit.ly/2UfeqCG)

질문 시에는 위 내용은 삭제하고 다음 내용을 남겨주세요.
=========================================
[질문 템플릿]
1. 강의 내용과 관련된 질문인가요? (예/아니오)
2. 인프런의 질문 게시판과 자주 하는 질문에 없는 내용인가요? (예/아니오)
3. 질문 잘하기 메뉴얼을 읽어보셨나요? (예/아니오)

[질문 내용]

안녕하세요! 매번 좋은 강의 감사드립니다.

강의를 듣다가 안전 속성에 대한 의문점이 생겨서 질문 남깁니다.

메소드가 안전한지 아닌지 자체가 무엇을 위해 제시된 속성인지 잘 모르겠습니다.

멱등과 캐시가능한 속성은 그 특성과 필요성을 잘 알겠습니다.

그러나 안전이라는 속성은 조금 이해가 가지않는것이 있는데,

강의에서는 안전하면 좋은것이다 아니다를 따지는 것이 아닌것같아서요!

안전하지 않다고해서 POST 를 안쓸수도 없고..

개발 과정에서 메소드의 안전성을 고려해야하는 사례가 있나요??

그냥 리소스를 건드리지않는 GET은 안전,  나머지는 리소스를 건드리기때문에 안전하지 못하다 로 "굳이" 나눈 목적이 궁금합니다.

제가 검색한바로는 안전한 메서드의 목적은 서버에 어떤 영향을 줄 수 있는 안전하지 않은 메서드가 사용될 때 사용자들에게 그 사실을 알려줄 수 있도록 하는 것이라고 하더라구요

이 설명 중에서도 "사용자들에게 그 사실을 알려줄 수 있도록 한다"는 것도 어떤 알림을 주는지 잘 와닿지가 않아서 아예 여기다가 질문을 남기게 되었습니다.

늘 좋은 강의 감사합니다! 

답변 2

·

답변을 작성해보세요.

2

David님의 프로필

David

2022.05.10

안녕하세요. duddl6701님, 공식 서포터즈 David입니다.

HTTP 메서드에서 언급된  안전이란 단어의 관점은 리소스의 상태가 변경되냐 안 되냐의 차이입니다.

어떤 글을 읽으셨는지 링크를 달아두지 않으셔서 모르겠지만

추측컨데, '안전하지 않은 메서드가 사용'되면 리소스의 상태가 변경됩니다. 변경된 리소스를 조회할 수 있는 메서드가 Get이므로 사용자들에게 그 사실(리소스가 변경되서 현재 리소스 상태는 이렇다)을 알려줄 수 있다고 말한 것 같네요.

감사합니다.

0

duddl6701님의 프로필

duddl6701

2022.05.10

감사합니다! ㅎㅎ