KakaoPay for web
Last updated: March 19, 2025
Accept Kakao Pay payments on your website with Flow, our pre-built, customizable payment user interface.
Flow enables you to accept payments using Checkout.com's global network of payment methods with a single integration.
Set up your client-side and server-side configuration to integrate with Checkout.com's payment gateway and enable payments on your website.
- The customer lands on the checkout page. 
- You perform a server-side request to create a payment session. 
- You use the payment session data on the client-side to mount Flow. 
- Flow displays the Kakao Pay payment method to the customer. 
- When the customer clicks the Pay option, Flow performs a payment request and handles any additional actions. For example, additional actions required for 3D Secure (3DS) authentication, or a third-party payment page redirect. 
- You receive a webhook notifying you of the payment status. 
Make sure you have a test account with Checkout.com.
Create a public key and a secret key from the Dashboard, with the following key scopes:
- Public key – payment-sessions:payandvault-tokenization
- Secret key – payment-sessions
To receive notifications for the payment events that may be triggered throughout the steps, configure your webhook receiver.
If you have a Content Security Policy (CSP) on your website, Checkout.com requires the following directives:
When the customer is ready to pay, you must send a server-side request to securely create a PaymentSession object. The PaymentSession contains the information required to handle all steps of the payment flow.
In your request:
- Set billing.address.countrytoKR
- Set currencytoKRW,HKD, orSGD
- Set payment_typetoRegularorRecurring
- Provide the customer.emailorcustomer.id
- Provide items[]
- For each iteminitems[], provide the:- name
- quantity
- reference
- unit_price
 
Information
For the full API specification, see the API reference.
post
https://api.checkout.com/payment-sessions
You can install the @checkout.com/checkout-web-components package via npm:
Alternatively, you can load the package directly via a script:
Note
To remain PCI compliant, you should only ever load the script directly from https://checkout-web-components.checkout.com. Do not download or host the script yourself, or include it in a bundle.
The client side initializes an instance of CheckoutWebComponents with configuration information and the payment session data retrieved in step 1.
You can use the following configuration options to instantiate an instance of CheckoutWebComponents:
| JavaScript key | Description | 
|---|---|
| 
 | Allows you to customize the visual appearance of the  | 
| 
 | Enables you to customize the options for the individual Flow components. For example, you can change the position of the cardholder field in the  | 
| 
 | Sets the environment that the library should point, and send requests to. This can be one of: 
 | 
| 
 | Sets the customer's locale. Explicitly setting this value overrides the  | 
| 
 | The response from the  This field is required. | 
| 
 | Your public API key. Your key is prefixed with  This field is required. | 
| 
 | Allows you to provide custom text translations for natively supported languages, or add custom text for locales and languages not natively supported by Flow. To learn how to add translations, refer to the Add localization to your Flow integration documentation. | 
Use CheckoutWebComponents to create a kakaopay object.
Mount Flow to the website using the mount() method. The method takes an Element selector or an Element as an argument. For example, #flow-container or document.getElementById(#flow-container), respectively.
Note
Embedding Flow within an iframe or onto a Shadow DOM is not supported.
The customer is redirected to a success or failure URL on your website depending on the payment outcome and the result of any additional payment authentication. For example, 3DS authentication.
You can retrieve the payment result using the Get payment details endpoint. Use the cko-payment-id value from the success or failure URL as the {id} path parameter. For example:
If you've set up your webhook receiver, we send a Gateway webhook to your server. The webhook we send depends on the status of the payment. Wait for the webhook callback before you trigger your order fulfillment process.
The PaymentSession ID is returned in the webhook payload's data.metadata.cko_payment_session_id field.
Use our test cards to simulate different payment flows, to ensure your integration is set up correctly and behaving as expected.
To check the status of a payment:
- Sign in to the Dashboard.
- Go to Payments > Processing > All payments.
- Select the test payment to view its details.