주문 상태 추적 설정하기

사용자에게 아이템을 부여하려면 결제가 성공적으로 완료되었는지 확인해야 합니다.

생성된 주문의 상태를 추적하고 유효성을 검사하려면 애플리케이션의 서버 측에서 웹훅 처리를 구성해야 합니다.

인게임 스토어를 제대로 운영하려면 메인 웹훅 처리를 구현해야 합니다:

PHP SDK
웹훅 처리용으로 준비된 클래스 사용.
웹훅알림 유형설명
사용자 유효성 검사user_validation사용자가 게임에 등록되어 있는지 확인하기 위해 결제를 처리하는 여러 단계에서 전송됩니다.
결제payment주문이 결제되면 전송되며 결제 데이터 및 거래 세부 정보가 포함됩니다.
주문 결제 성공order_paid결제 웹훅이 성공적으로 처리되었을 때 전송되며 여기에는 구매한 아이템 및 거래 ID에 대한 정보를 포함되어 있습니다. 사용자에게 아이템을 추가할 때 웹훅 데이터를 사용할 수 있습니다.
환불refund주문이 취소되면 전송되며 취소된 결제 데이터 및 거래 세부 정보가 포함됩니다.
주문 취소order_canceled환불 웹훅이 성공적으로 처리되었을 때 전송되며, 구매 아이템에 대한 정보와 취소된 거래의 ID가 포함되어 있습니다. 웹훅의 데이터를 사용하여 구매한 아이템을 제거합니다.

웹훅의 전체 목록과 웹훅 작업에 대한 일반적인 정보는 웹훅 문서를 참조해 주세요.

웹훅 전송 설정

엑솔라 측에서 웹훅 구성 방법:

  1. 프로젝트를 관리자 페이지에서 엽니다.
  2. 사이드 메뉴에서 프로젝트 설정을 클릭하고 웹훅 세션으로 이동합니다.
  3. 웹훅 URL 필드에서 엑솔라가 웹훅을 전송하는 URL을 지정합니다.
알림
웹훅을 테스트하기 위해 webhook.site와 같은 전용 사이트나 ngrok과 같은 플랫폼을 선택할 수도 있습니다. 실제 프로젝트의 경우 구매 유효성 검사 논리를 추가해야 합니다.
  1. 웹훅 사용을 클릭합니다.

웹훅 리스너 추가

웹훅 수신기는 지정된 URL 주소에서 들어오는 웹훅을 수신하고 서명을 생성한 후 엑솔라 웹훅 서버로 응답을 전송할 수 있는 프로그램 코드입니다.

서명 생성

웹훅을 수신할 때는 데이터 전송의 보안을 보장해야 합니다. 이를 위해서는 웹훅 데이터에서 서명을 생성하고 생성된 서명이 HTTP 요청 헤더에 전송된 서명과 일치하는지 확인해야 합니다.

서명 생성 방법:

  1. 요청 본문과 프로젝트의 비밀 키의 JSON을 연결합니다.
  2. 첫 번째 단계에서 구한 문자열에 SHA-1 암호화 해시 함수를 적용합니다.

웹훅으로 응답 보내기

웹훅 수신을 확인하려면 서버가 다음을 반환해야 합니다.

  • 성공적인 응답의 경우 200, 201 또는 204 HTTP 코드
  • 지정된 사용자를 찾을 수 없거나 잘못된 서명이 전달된 경우 문제 설명이 포함된 400 HTTP 코드

서버에 일시적인 문제가 발생한 경우 웹훅 핸들러가 5xx 코드를 반환할 수도 있습니다.

주문 결제 성공주문 취소 웹훅에 대한 응답을 받지 못했거나 5xx 코드가 포함된 응답을 받은 경우, 다음 일정에 따라 웹훅이 다시 전송됩니다.

  • 5분 간격으로 2번
  • 15분 간격으로 7번
  • 60분 간격으로 10번

웹훅 전송은 처음 시도 후 12시간 이내에 최대 20번까지 시도할 수 있습니다.

결제 웹훅에 대한 응답이 수신되지 않았거나 5xx 코드가 포함된 응답이 수신된 경우 웹훅도 증가된 시간 간격으로 재전송됩니다. 12시간 동안 최대 12번 시도할 수 있습니다.

사용자 유효성 검사 웹훅에 대한 응답이 수신되지 않았거나 400 또는 5xx 코드가 포함된 응답이 수신된 경우 사용자 유효성 검사 웹훅이 재전송되지 않습니다.

이 경우 사용자에게 오류가 표시되며 결제주문 결제 성공 웹훅은 전송되지 않습니다.

알림
전체 웹훅 목록 및 메커니즘과 상세한 처리 예제는 웹훅 문서에 설명되어 있습니다.
진행률
의견을 보내 주셔서 감사드립니다!
마지막 업데이트: 2024년 7월 18일

오자 또는 기타 텍스트 오류를 찾으셨나요? 텍스트를 선택하고 컨트롤+엔터를 누르세요.

문제 보고
콘텐츠를 항상 검토합니다. 여러분의 피드백은 콘텐츠를 개선에 도움이 됩니다.
후속 조치를 위해 이메일을 제공해 주세요
의견을 보내 주셔서 감사드립니다!