가이드/결제위젯/ㄴ 결제창형 연동하기
목차

Version 2

새로 나온

링크 복사결제위젯(결제창형) 연동하기

결제위젯(결제창형)을 연동하는 방법이에요. renderPaymentWindow()로 결제창을 렌더링하고, paymentRequest 이벤트에서 결제를 요청해요.

결제위젯 결제창형 연동 흐름

주문서 안에 결제 UI를 직접 렌더링하고 싶다면 결제위젯(주문서형) 연동을 추천드려요.

링크 복사API 키 준비하기

개발자센터의 API 키 메뉴에서 결제위젯 연동 키를 확인하세요. 테스트 키와 라이브 키의 차이점도 함께 확인하세요.

결제위젯 연동 API 키


링크 복사1. 결제위젯 연동하기

먼저 주문서 페이지에 결제창형 결제를 연결할게요. 스크립트 태그 또는 패키지 매니저로 토스페이먼츠 SDK를 설치하고, 아래 순서대로 메서드를 호출하세요.

1️⃣ tossPayments.widgets()로 결제위젯 인스턴스를 생성하세요.

2️⃣ 결제창을 렌더링하기 전에 widgets.setAmount()로 결제 금액을 설정하세요.

3️⃣ widgets.renderPaymentWindow()로 결제창을 렌더링하세요.

4️⃣ 구매자가 결제수단을 선택하면 paymentRequest 이벤트가 발생해요.

5️⃣ 콜백에서 widgets.requestPayment()로 결제를 요청하세요.

위 코드를 실행한 다음에 '결제하기' 버튼을 누르면 결제창이 열려요. 테스트 클라이언트 키를 사용했다면 실제로 결제되지 않으니 안심하세요.

링크 복사2. 리다이렉트 URL로 이동하기

결제창에서 구매자의 결제수단을 하는데요. 인증 결과는 리다이렉트 URL로 확인할 수 있어요. 결제 인증이 성공했다면 성공 리다이렉트 URL(successUrl)의 쿼리 파라미터로 결제 정보를 확인하고 검증해주세요. 인증이 실패했다면 이동한 실패 리다이렉트 URL(failUrl)의 쿼리 파라미터로 에러를 확인해주세요.

링크 복사결제 인증이 성공했어요

성공 리다이렉트 URL에는 아래 쿼리 파라미터가 추가돼요. 쿼리 파라미터의 amount 값과 setAmount()amount 파라미터의 값이 같은지 반드시 확인하세요. 클라이언트에서 결제 금액을 조작하는 행위를 방지할 수 있습니다. 만약 값이 다르다면 결제를 취소하고 구매자에게 알려주세요.

일반결제 및 해외 간편결제의 paymentTypeNORMAL입니다. 브랜드페이 결제의 paymentTypeBRANDPAY입니다.

링크 복사결제 인증이 실패했어요

실패 리다이렉트 URL에는 아래 쿼리 파라미터가 추가돼요.쿼리 파라미터로 돌아오는 에러 코드, 메시지를 확인하고 필요한 로직을 구현해주세요.

링크 복사3. 결제 승인하기

마지막 단계로 결제 승인 API를 호출하세요. API 키 준비하기 단계에서 확인한 결제위젯 연동 키 > 시크릿 키를 사용해요.

시크릿 키와 :을 base64로 인코딩해서 헤더를 아래와 같이 만들어주세요. :을 빠트리지 않도록 주의하세요. 비밀번호가 없다는 것을 알리기 위해 시크릿 키 뒤에 콜론을 추가합니다. 시크릿 키는 클라이언트, GitHub 등 외부에 노출되면 안 됩니다.

결제 승인 API의 헤더에 인코딩한 시크릿 키 인증 헤더를 추가하세요. 요청 본문 파라미터에는 앞 단계에서 리다이렉트 URL로 받은 paymentKey, orderId, amount를 넣어주세요. 아래 예제 코드에는 내 테스트 결제의 paymentKey 값을 넣어 실행해주세요.

링크 복사4. 응답 확인하기

링크 복사결제 승인이 성공했어요

결제 승인 API의 결과로 HTTP 200 OK와 함께 Payment 객체가 돌아오면 결제가 정상적으로 완료됐어요.

Payment 객체에 구매자가 선택한 결제수단 정보가 있는지 확인하세요. 카드를 선택해서 결제했다면 아래와 같이 card 필드에 카드 정보를 확인할 수 있어요. 간편결제를 선택했다면 응답이 조금씩 바뀌는데요. 자세한 내용은 간편결제 응답 확인 가이드를 참고하세요.

링크 복사결제 승인이 실패했어요

결제 승인에 실패하면 HTTP 4XX 또는 5XX 코드와 에러 객체를 받아요. 결제 승인의 전체 오류 목록은 에러 코드를 참고하세요. 테스트 환경에서 결제 승인 실패를 재현해보고 싶다면 토스페이먼츠 API 테스트 헤더를 사용해보세요.


링크 복사더 알아보기

결제 취소하기
  • 더 궁금한 내용이 있나요?
  • 코드 샘플을 참고하세요
  • 기술지원이 필요한가요?
    실시간 문의|이메일 보내기