사용자 포인트 제도 등록

사용자는 포인트 제도 등록 및 로그인 기능을 통해 Google 월렛에서 포인트 제도를 검색하고 자신의 계정에 가입하거나 로그인할 수 있습니다. 사용자는 모바일 친화적인 웹사이트로 이동하여 절차를 완료할 수 있으며, 그런 다음 Google 월렛에 카드를 추가할 수 있습니다.

이 가이드에서는 이 기능에 포인트 제도를 사용 설정하는 데 필요한 구현 단계를 간략하게 설명합니다.

개요

시작하려면 프로젝트가 이미 설정되어 있고 Google Wallet API에 액세스할 수 있어야 합니다.

포인트 제도 등록 및 로그인 기능을 구현하려면 다음 네 단계를 따라야 합니다.

  1. Google 월렛에서 등록/로그인 흐름을 테스트하기 위한 테스트 클래스를 설정합니다.
  2. Google 월렛 SharedDataType을 사용하는 등록/로그인 페이지를 개발합니다.
  3. 등록/로그인 후 Google 월렛에 포인트 카드를 푸시백하는 기능을 구현합니다.
  4. 인증 및 활성화를 요청합니다.

Google 월렛에서 테스트 클래스 설정

등록 및 로그인 URL, 프로그램 로고, 선택한 사용자 필드를 결정합니다. 그런 다음 loyaltyclassdiscoverableProgram 중첩 필드를 사용하여 적절한 값을 설정합니다.

discoverableProgram에서 값을 설정하여 등록/로그인이 사용 설정된 포인트 제도의 초안 버전을 만듭니다. 이 정보가 테스터에게 표시되도록 하려면 테스터가 Google Pay 및 월렛 콘솔에 액세스할 수 있는지 확인하세요. Google Pay 및 월렛 콘솔의 액세스 권한을 다른 사용자와 공유하는 방법에 대한 자세한 내용은 사용자 페이지 자세히 알아보기를 참조하세요.

개발 과정에서 구현 기능 확인을 완료하려면 Google Pay 및 월렛 콘솔의 지원팀에 문의 위젯을 사용하여 문의하세요. 콘솔의 주제에서 Google Wallet API를 선택하고 하위 주제에서 포인트 로그인/등록을 선택합니다.

Google 월렛 사용자 데이터를 사용하는 등록 및 로그인 페이지 개발

사용자가 포인트 제도에 로그인하거나 등록하기로 선택하면 등록 또는 로그인 프로세스를 완료할 수 있도록 웹사이트의 맞춤설정된 페이지로 연결됩니다. 사용자가 등록을 선택하면 Google 월렛은 사용자에게 본인과의 사용자 데이터 공유를 승인하도록 요청합니다.

사용자가 이러한 작업을 완료할 수 있도록 두 페이지 중 하나 또는 둘 다를 제공해야 합니다.

  1. 사용자가 기존 계정에 로그인할 수 있는 로그인 URL
  2. 사용자가 새 계정을 만들 수 있는 등록 URL

로그인 및 등록 페이지는 다음 요구사항을 충족해야 합니다.

  • 모바일 친화적인 사용자 환경을 제공합니다.
  • 등록 과정에서 필수 필드의 수를 최소화합니다.
  • 사용자가 단일 페이지 내에서 로그인 또는 등록을 완료하도록 허용합니다.
  • 사용자 데이터가 안전하게 전송되도록 유효한 인증서와 함께 HTTPS 암호화를 사용합니다.
  • 로그인 및 등록 페이지의 업타임이 99.9% 이상인지 확인합니다.

위의 요구사항 외에도 사용자가 양식을 작성하거나 페이지에서 서비스 약관 동의 단계까지 진행하지 않고도 포인트 제도에 등록할 수 있도록 하는 것이 좋습니다.

  • SharedDataType에 제공된 사용자 데이터를 활용하여 계정을 만들고 즉시 포인트 카드를 푸시백할 수 있습니다.
  • 이후에 사용자에게 비밀번호 및 선택적 계정 세부정보를 구성하기 위한 링크나 일회용 비밀번호를 이메일로 보낼 수 있습니다.
  • 단계가 늘어날 때마다 추가 이탈로 이어질 수 있으므로 이렇게 하면 사용자가 등록 프로세스를 포기할 가능성이 줄어듭니다.

로그인 또는 등록 페이지를 표시할 때 Google 월렛에서 Android WebView를 만들고 제공된 URL에 POST 요청이 실행됩니다. 사용자 데이터는 application/x-www-form-urlencoded 콘텐츠 유형과 UTF-8 인코딩을 사용하여 POST 요청에 포함된 SharedDataType 매개변수로 제공됩니다. SharedDataType 매개변수의 값은 Base64로 인코딩된 JSON 객체입니다.

사용자가 선택한 작업과 사용자가 요청하도록 지정한 필드에 따라 JSON 객체에 다음 필드가 포함될 수 있습니다.

필드 등록 로그인
이메일
firstName  
lastName  
addressLine [1-3]  
city  
state  
zipcode  
country  
전화  

SharedDataType에 포함된 디코딩된 샘플 JSON 객체는 아래를 참고하세요.

리소스

{
  "firstName": "Jane",
  "lastName": "Doe",
  "addressLine1": "1600 Amphitheatre Pkwy",
  "addressLine2": "Apt 123",
  "addressLine3": "Attn:Jane",
  "city": "Mountain View",
  "state": "CA",
  "zipcode": "94043",
  "country": "US",
  "email": "jane.doe@example.com",
  "phone": "555-555-5555"
}

Google 월렛에 포인트 카드 즉시 푸시백 구현

인증 (로그인) 또는 계정 생성 (등록) 후에는 페이지에서 즉시 사용자의 포인트 카드를 Google 월렛에 푸시백해야 합니다.

아래의 구조를 따르는 링크로 리디렉션하여 포인트 카드를 Google 월렛으로 푸시백할 수 있습니다.

https://pay.google.com/gp/v/save/{jwt_generated}

URL의 안전한 길이는 2,000자(영문 기준)입니다. 링크를 이 한도 미만으로 유지해야 합니다. JWT로 인코딩된 객체의 크기는 작아야 하며 사용자별 데이터만 포함해야 합니다. JWT를 만들기 전에 객체 클래스에 대부분의 데이터를 보관해 봅니다. 한도에 맞지 않는 큰 객체의 경우 먼저 Google Wallet API에서 객체를 만든 후 객체 ID만 JWT로 보내는 것이 좋습니다.

일반적인 통신 흐름

다음 이미지에는 사용자의 등록 또는 로그인을 완료하기 위한 통신 흐름이 나와 있습니다. '서버' 간의 모든 작업을 구현할 책임은 개발자에게 있습니다.

등록 로그인 흐름

확인 및 활성화 요청

개발 작업을 완료하고 등록/로그인 흐름을 테스트한 후 Google Pay 및 월렛 콘솔 지원 문의 위젯을 통해 요청을 제출합니다.

구현을 전체적으로 검토하여 Google 월렛 앱과 함께 올바르게 작동하는지 확인한 후 포인트 제도의 포인트 제도 등록/로그인 기능이 공개적으로 출시됩니다. 이렇게 하면 모든 사용자가 프로그램을 보고 이 기능을 사용할 수 있습니다.

최적의 사용자 환경을 보장하기 위해 기능 요구사항을 지속적으로 준수하는지 확인하기 위해 등록/로그인 구현을 반복적으로 확인합니다. 불일치가 있는 경우 개발자에게 알림이 전송되며 문제가 해결될 때까지 로그인/등록 기능이 사용 중지될 수 있습니다.

자주 묻는 질문(FAQ)

  • 포인트 제도에 사용되는 이미지에 대한 요구사항이 있나요?
    • 예. 이미지는 HTTPS 위치에서 호스팅되어야 하며, 그러지 않으면 Google 월렛에 표시되지 않습니다.
  • JWT의 구현과 디버깅을 간소화하는 도구가 있나요?
    • 예. www.jwt.io와 같은 플랫폼을 사용하면 개발 과정에서 토큰을 디코딩하고 디버그하여 제출할 콘텐츠를 확인할 수 있습니다. Google은 이러한 서드 파티와 제휴 관계에 있지 않으며 특별히 추천하는 서드 파티 서비스도 없습니다.
  • Base64로 인코딩된 SharedDataType 데이터를 올바르게 처리하려면 어떻게 해야 하나요?
    • 프로세스 전체에서 UTF-8 인코딩을 사용하고 있는지 확인하세요. JSON 문자열은 먼저 UTF-8로 인코딩된 후 NO_WRAP 및 URL_SAFE 옵션을 사용하여 android.util.Base64로 인코딩됩니다. 이는 RFC 3548 4조에 부합합니다.