개발자의 끄적끄적

[PHP no-cache 설정(뒤로 버튼을 누르면 만료된 페이지 띄우기) 본문

개발/php

[PHP no-cache 설정(뒤로 버튼을 누르면 만료된 페이지 띄우기)

효벨 2020. 7. 24. 01:00
728x90
반응형

[PHP no-cache 설정(뒤로 버튼을 누르면 만료된 페이지 띄우기)

 

[PHP no-cache 설정(뒤로 버튼을 누르면 만료된 페이지 띄우기)

페이지의 구성이 아래와 같이 구성되어 있다고 가정하겠습니다.

coupon _form.php -> coupon_update.php -> coupon_result.php

첫번째 페이지인 coupon_form.php 는 쿠폰의 정보를 입력하는 페이지입니다. 쿠폰 정보입력이 완료되면 두번째 페이지인 copon_update.php 로 전송되어져 정보가 데이타베이스에 저장되고 쿠폰에 대한 댓가로 경품이 지급됩니다.
물론 경품지급도 데이타베이스 상에서 하나의 결과 값으로 처리될 것입니다. 경품지급이 사용자에게 성공적으로 이루어
지게 되면 coupon _result.php로 이동후 사용자에게 경품내역을 알려주고 축하 메시지를 띄워줍니다.

이럴경우 경품만 받고 조용히 다른 페이지로 이동하면 상관없는데, 사용자가 뒤로가기 버튼을 클릭했다고 생각해 봅시다. 최악의 경우에는 사용자에게 경품이 계속해서 지급되는 터무니 없는 상황이 연출될 수 있습니다.

가장 좋은 방법은 경품이 지급되면 테이블내의 체크필드 값을 변경하여 같은 사용자에게 반복 지급되는 것을 막는 것이지만 페이지 자체내에서도 캐시된 페이지를 사용하지 못하게 막아줄 필요성도 있습니다.

캐시된 페이지를 사용하지 못하게되면 뒤로 버튼을 클릭했을 경우 "만료된 페이지입니다." 라는 메시지를 보여주게 되고
페이지 실행은 멈추게 됩니다.

HTTP 전송규약에서 캐쉬를 사용못하게 하는 header는 Progma와 Cache-Control 이 있으며 PHP에서는 아래와 같이
사용합니다.

캐쉬에 저장하지 않기

HTTP 1.0에서 캐쉬에 저장하지 않기 header("Progma:no-cache");

HTTP 1.1에서 캐쉬에 저장하지 않기 header("Cache-Control:no-cache,must-revalidate");

브라우저가 지원하는 HTTP 프로토콜 버전을 알수 없을 경우에는 두개를 한꺼번에 지정하여 주시면됩니다.
 header
아래 부분의 HTTP_REFERER 부분은 리퍼러 체크하던 부분이 딸려왔는데 무시하세요^^


 

출처 : http://www.webmadang.net/develop/develop.do?action=read&boardid=1003&page=2&seq=42 

반응형
Comments