Save card on Payment
Tokenization allows you to store a token in place of a customer’s raw card data. Instead of collecting the full card details for every future payment, you can use the stored token—improving both security and user experience. This is especially useful for recurring or subscription-based billing.
Tokenization flow
- Customer Enters Card Details: During their first purchase, customers can consent to save (tokenize) their card.
- Token Generation: xMoney converts the customer’s card details into a token (cardId) and stores it securely.
- Subsequent Payments: For future orders, simply reference the token instead of requiring the full card details again.
If the card is 3D Secure enabled, xMoney may still require a 3DS challenge for some tokenized transactions, depending on issuer rules and regional regulations. For more information, see our 3D Secure Overview.
Generating a token
To generate a token at checkout, follow these steps:
Add saveCard
to your Pay Form
In your pay form template (HTML), include a “Save Card” option that xMoney can use to determine whether the customer’s card should be tokenized. For example:
<div class="clearfix"></div>
{{ saveCard }}
Visibility: You can choose to make this checkbox or button visible to the customer (so they can opt in or out) or hide it (so the card is always saved).
Mark the order to save card
In your order request data, set saveCard
to true
. Example:
{
"siteId": 10077,
"customer": {
"identifier": "testSaveCard"
},
"order": {
"orderId": "testSaveCard1",
"type": "purchase",
"amount": 21,
"currency": "EUR",
"description": "product description"
},
"cardTransactionMode": "authAndCapture",
"saveCard": true
}
When the customer submits payment with the above parameters and enters their card details, xMoney will generate:
- An orderId
- A transactionId
- A cardId (the actual token)
The cardId
is then tied to the customer’s identifier (e.g., "testSaveCard") in your system.
Handling response
After the payment completes (authorization and capture), xMoney returns a response indicating success or failure. This response is provided via opensslResult
if you have IPN/webhook notifications or direct server responses enabled.
A successful transaction with saveCard
enabled will include a cardId
.
Example of a decrypted response:
{
"transactionStatus": "complete-ok",
"orderId": 1234,
"transactionId": 1234,
"cardId": 98765,
"customerId": 1001,
"amount": 21,
"currency": "EUR",
...
}
Storing the cardId
- Decrypt and parse the
opensslResult
payload to read the JSON data. - Extract the
cardId
field. - Associate the
cardId
with the correctcustomerId
or identifier in your database. - Store it for future transactions (e.g., in your user profile or an internal tokens table).
Keep your tokens secure. While they are not raw card data, tokens can still be misused if exposed.
Using the token in future orders
Once you have a cardId
, you can use it for subsequent orders without requiring the full card number, expiry date, etc.:
{
"siteId": 10077,
"customer": {
"identifier": "testSaveCard"
},
"order": {
"orderId": "testSaveCard11",
"type": "purchase",
"amount": 1,
"currency": "EUR",
"description": "product description"
},
"cardTransactionMode": "authAndCapture",
"cardId": 98765
}
Best practices
- Customer Consent: Clearly explain how their card data is saved.
- Identifier Management: Use unique customer identifiers to avoid mixing tokens between different users.
- Subscription Flow: For recurring charges, consider hiding the “Save Card” option on the initial transaction if you want to guarantee a token is created. You will have to send the
saveCard: true
param when creating the order.
Conclusion
Card Tokenization through xMoney streamlines checkout, enhances security, and supports recurring payments. By including saveCard
in your request, parsing the resulting cardId
from the response, and referencing that token in future purchases, you eliminate the need for repeated card entry—leading to a faster, more user-friendly payment flow.