Trust Payments host een openbaar toegankelijke JavaScript Library die u kunt opnemen in uw kassa om uw web-app-oplossing betalingen te laten accepteren met Google Pay.
Om uw integratie te beginnen moet u de volgende gegevens bevestigen/opvragen bij ons Support Team:
- Controleer of uw acquiring bank Google Pay ondersteunt als betalingsoptie.
- Vraag een test en live site referentie aan, met Google Pay toegevoegd als ingeschakelde functie en schakel 3-D Secure in voor zowel test- als liveaccounts.
- Vraag een JWT gebruikersnaam & geheime sleutel gekoppeld aan uw test site referentie.
Uw Google-account instellen om te testen
Om te beginnen met het testen van Google Pay in een testomgeving, hebt u een Google-account nodig en moet u lid worden van een groep die Google ter beschikking stelt en waarmee u een set API-testkaarten kunt gebruiken voor het testen van uw Google Pay -oplossing.
- Zodra u een Google-account hebt geregistreerd, meldt u zich aan bij het account in uw browser en navigeert u naar de volgende pagina:
https://groups.google.com/g/googlepay-test-mode-stub-data
-
Klik dan op "Lid worden van groep".
-
Zodra u uw voorkeuren hebt ingesteld, klikt u op "Lid worden van groep".
-
U krijgt een pagina te zien die bevestigt dat u toegang hebt gekregen tot de Google-testsuite:
-
Om te controleren of dit werkt, biedt Google een demopagina waarop je op een knop Google Pay kunt klikken om het betalingsformulier te bekijken.
Klik hier om dit in een nieuw tabblad te openen (link naar externe site).Als alles werkt zoals verwacht, kunt u een van de voorbeeldbetalingsmethoden selecteren en op "VERDER" klikken. Dit zal een testbetaling verwerken.
Uw betalingskassa configureren
Zorg ervoor dat je alle bovenstaande stappen hebt uitgevoerd voordat je verder gaat.
-
Neem een link naar onze v3 JS library op in uw webpagina
<script src="https://cdn.eu.trustpayments.com/js/latest/st.js"></script>
-
Om de knop Google Pay op het scherm te laten verschijnen bij het initialiseren, moet je een div opnemen in je html-bron met een id die wordt geconfigureerd in de volgende stappen van deze handleiding <div id="st-google-pay"></div>
-
De st.js library vereist een formulier met het volgende id. <form id="st-form"/> - De naam van het id kan worden gewijzigd door de eigenschap stform in de SecureTrading config.
-
Het meldingskader is een optionele div die aan uw pagina kan worden toegevoegd om een succes-, fout- of annuleringsbericht aan de klant te tonen als de betaling is voltooid. Als u de melding nuttig vindt, kunt u de tekst misschien aanpassen. Dit kan met behulp van de translations eigenschap ingesteld in de SecureTrading config. Klik hier voor meer informatie.
<html>
<head>
</head>
<body>
<div id="st-notification-frame"></div>
<form id="st-form" action="https://www.example.com"/>
<div id="st-google-pay"></div>
<script src="https://cdn.eu.trustpayments.com/js/latest/st.js"></script>
<script>
(function() {
var st = SecureTrading({
<! -- st.js configuration -->
});
st.GooglePay({
<! -- Google Pay configuration -->
});
})();
</script>
</body>
</html>
Initialiseer st.js library
Bij het initialiseren van de st.js library moet u de eigenschap jwt, met een JSON Web Token gegenereerd op uw server.
JSON Web Tokens (JWT) zijn een open, industriestandaard RFC 7519 methode voor het veilig verzenden van gegevens tussen twee partijen. Het beschermt tegen de wijziging van kritieke transactiegegevens (bijv. het af te schrijven bedrag) door onbevoegde partijen tijdens de betaalsessie.
Als u nog geen JWT-gebruikersnaam en geheime sleutel hebt ontvangen, zoals beschreven in de sectie 'Aan de slag', neem dan contact op met ons Support Team.
<html>
<head>
</head>
<body>
<div id="st-notification-frame"></div>
<form id="st-form" action="https://www.example.com"/>
<div id="st-google-pay"></div>
<script src="https://cdn.eu.trustpayments.com/js/latest/st.js"></script>
<script>
(function() {
var st = SecureTrading({
jwt : 'INSERT YOUR JWT HERE'
});
st.GooglePay({
<! -- Google Pay configuration -->
});
})();
</script>
</body>
</html>
De JSON Web Token (JWT) configureren
Je moet onze JSON Web Token richtlijnen raadplegen om de vereiste inhoud voor het JWT te bevestigen.
Klik hier om info in een nieuw tabblad te openen
initialiseren Google Pay
Het volgende voorbeeld toont een basisconfiguratie op Google Pay die de vereiste velden bevat.
st.GooglePay({
"buttonOptions": {
"buttonRootNode": "st-google-pay"
},
"paymentRequest": {
"allowedPaymentMethods": [{
"parameters": {
"allowedAuthMethods": ["PAN_ONLY", "CRYPTOGRAM_3DS"],
"allowedCardNetworks": ["AMEX", "DISCOVER", "JCB", "MASTERCARD", "VISA"]
},
"tokenizationSpecification": {
"parameters": {
"gateway": "trustpayments",
"gatewayMerchantId": "test_site12345"
},
"type": "PAYMENT_GATEWAY"
},
"type": "CARD"
}],
"environment":"TEST",
"apiVersion": 2,
"apiVersionMinor": 0,
"merchantInfo": {
"merchantId": "<e.g. 1234567890>"
},
"transactionInfo": {
"countryCode": "US",
"currencyCode": "USD",
"checkoutOption": "COMPLETE_IMMEDIATE_PURCHASE",
"totalPriceStatus": "FINAL",
"totalPrice": "10.00",
"totalPriceLabel": "Total",
"displayItems": [{
"label": "Example item",
"price": "10.00",
"type": "LINE_ITEM",
"status": "FINAL"
}]
}
}
});
Hieronder volgen aanvullende overwegingen die specifiek zijn voor uw Trust Payments account:
Eigendom | Formaat | Beschrijving | |
allowedCardNetworks | Lijst |
De ondersteunde waarden voor deze eigenschap zijn afhankelijk van de betaalmethoden die worden ondersteund op uw Trust Payments account. |
|
gatewayMerchantId | String |
De Trust Payments site referentie geconfigureerd in de Google Pay manager instance fungeert als je gateway merchant Id. Wanneer u klaar bent om naar de PRODUCTIE-omgeving te gaan, wordt de gatewayMerchantId moet worden ingesteld op uw live site referentie. |
|
gateway | String |
Stel in uw configuratie de eigenschap in met waarde “trustpayments”. |
Een betaling verwerken
Als je de bovenstaande stappen hebt uitgevoerd, zou de opmaak van je afrekenpagina moeten lijken op het volgende voorbeeld, waarmee je een Google Pay betaling kunt voltooien in de TEST-omgeving.
<html>
<head>
</head>
<body>
<div id="st-notification-frame"></div>
<form id="st-form" action="https://www.example.com"/>
<div id="st-google-pay"></div>
<script src="https://cdn.eu.trustpayments.com/js/latest/st.js"></script>
<script>
(function() {
var st = SecureTrading({
jwt: 'INSERT YOUR JWT HERE',
});
st.GooglePay({
"buttonOptions": {
"buttonRootNode": "st-google-pay"
},
"paymentRequest": {
"allowedPaymentMethods": [{
"parameters": {
"allowedAuthMethods": ["PAN_ONLY", "CRYPTOGRAM_3DS"],
"allowedCardNetworks": ["AMEX", "DISCOVER", "JCB", "MASTERCARD", "VISA"]
},
"tokenizationSpecification": {
"parameters": {
"gateway": "trustpayments",
"gatewayMerchantId": "test_site12345"
},
"type": "PAYMENT_GATEWAY"
},
"type": "CARD"
}],
"environment":"TEST",
"apiVersion": 2,
"apiVersionMinor": 0,
"merchantInfo": {
"merchantId": "<e.g. 1234567890>"
},
"transactionInfo": {
"countryCode": "US",
"currencyCode": "USD",
"checkoutOption": "COMPLETE_IMMEDIATE_PURCHASE",
"totalPriceStatus": "FINAL",
"totalPrice": "10.00",
"totalPriceLabel": "Total",
"displayItems": [{
"label": "Example item",
"price": "10.00",
"type": "LINE_ITEM",
"status": "FINAL"
}]
}
}
});
})();
</script>
</body>
</html>
Dynamische prijsupdates
Optioneel kun je dynamisch:
- Werk de transactiegegevens op het betalingsformulier bij op basis van de verzendoptie die je klant heeft gekozen.
- Werk de verzendopties en transactiegegevens op het betalingsblad bij op basis van het door je klant gekozen verzendadres.
Om aan de slag te gaan met dynamische prijsupdates, moet je de configuratie die wordt doorgegeven aan de methode st.js GooglePay wijzigen door:
- De callbackIntents.
- Abonneren op onPaymentDataChanged callback om het betalingsformulier bij te werken wanneer de klant zijn verzendadres of verzendoptie wijzigt.
- Abonneren op onPaymentAuthorized callback om te controleren of het geautoriseerde bedrag overeenkomt met het weergegeven en overeengekomen bedrag op het betalingsformulier Google Pay.
Eigendom | Formaat | Beschrijving | |
callbackIntents | String[] |
De PAYMENT_AUTHORIZATION moet worden opgenomen wanneer SHIPPING_ADDRESS of SHIPPING_OPTION in de lijst met intenties staat. |
|
shippingOptionRequired | Booleaanse |
Moet worden ingesteld op true wanneer SHIPPING_OPTION is ingesteld in de callbackIntents. |
|
shippingAddressRequired | Booleaanse |
Moet worden ingesteld op true wanneer SHIPPING_ADDRESS is ingesteld in de callbackIntents. |
|
|
onPaymentDataChanged |
functie |
De onPaymentDataChanged callback wordt aangeroepen wanneer:
onPaymentDataChanged retourneert een object genaamd intermediatePaymentData. De intermediatePaymentData object omvat welk adres en welke verzendoptie de klant heeft gekozen. Let op: Wanneer het betalingsblad wordt geïnitialiseerd, wordt de INITIALIZE intentie wordt automatisch verzonden in de intermediatePaymentData en hiermee kun je het verzendadres van de klant en de beschikbare verzendopties onmiddellijk valideren en indien nodig het blad bijwerken. oplossen onPaymentDataChanged met een object ( PaymentDataRequestUpdate (externe link)) dat de nieuwe transactie-informatie bevat die aan de klant moet worden getoond op het betalingsformulier Google Pay. Een voorbeeld is wanneer de klant een optie voor expresverzending selecteert en het totaalbedrag moet worden bijgewerkt op het betalingsblad om deze keuze weer te geven. Wanneer er een fout optreedt, wordt de PaymentDataRequestUpdate (externe link) object kan worden geconfigureerd met een fouteigenschap waarmee je de klant op de hoogte kunt stellen van de foutreden op het betalingsformulier, bijv. het verzendadres van de klant is mogelijk niet bruikbaar of de toegepaste promotiecode is verlopen.
Raadpleeg Google's documentatie (externe link) voor alle update-eigenschappen die kunnen worden toegevoegd aan de PaymentDataRequestUpdate object. Voor een volledige referentiegids voor de onPaymentDataChanged callback, Bekijk de documentatie van Google (externe link). |
onPaymentAuthorized | functie |
Wanneer callbackIntents omvat PAYMENT_AUTHORIZATION en de klant op "Betalen" klikt in het betalingsblad Google Pay , wordt de onPaymentAuthorized callback wordt aangeroepen en je moet een belofte retourneren die succesvol zal oplossen en de betalingsfiche zal sluiten, of zal oplossen met een fout en een foutbericht zal weergeven op de betalingsfiche. De transactionState moet "SUCCESS" of "ERROR": SUCCESS
ERROR
|
De callback-implementaties voor onPaymentDataChanged (externe link) en onPaymentAuthorized (externe link) zijn in overeenstemming met de contracten die door Google zijn opgesteld, zoals beschreven in hun officiële documentatie. Hoewel de technische aspecten van deze callbacks consistent blijven, houdt de richtlijn van Google geen rekening met aangepaste integraties via gateways van derden. Houd dit onderscheid in gedachten bij het raadplegen van externe documentatie.
Voorbeeld van dynamische prijsupdate
<html>
<head>
</head>
<body>
<div id="st-notification-frame"></div>
<form id="st-form" action="https://www.example.com"/>
<div id="st-google-pay"></div>
<script src="https://cdn.eu.trustpayments.com/js/latest/st.js"></script>
<script>
(function() {
var st = SecureTrading({
jwt: 'INSERT YOUR JWT HERE',
});
st.GooglePay({
"buttonOptions": {
"buttonRootNode": "st-google-pay"
},
"paymentRequest": {
"allowedPaymentMethods": [{
"parameters": {
"allowedAuthMethods": ["PAN_ONLY", "CRYPTOGRAM_3DS"],
"allowedCardNetworks": ["AMEX", "DISCOVER", "JCB", "MASTERCARD", "VISA"]
},
"tokenizationSpecification": {
"parameters": {
"gateway": "trustpayments",
"gatewayMerchantId": "test_site12345"
},
"type": "PAYMENT_GATEWAY"
},
"type": "CARD"
}],
"environment": "TEST",
"apiVersion": 2,
"apiVersionMinor": 0,
"merchantInfo": {
"merchantId": "<e.g. 1234567890>"
},
"shippingAddressRequired": true,
"shippingAddressParameters": {
"phoneNumberRequired": true,
},
"callbackIntents": [
"SHIPPING_ADDRESS",
"SHIPPING_OPTION",
"PAYMENT_AUTHORIZATION",
],
"paymentDataCallbacks": {
"onPaymentAuthorized": onPaymentAuthorized,
"onPaymentDataChanged": onPaymentDataChanged
},
"shippingOptionRequired": true,
"shippingOptionParameters": {
defaultSelectedOptionId: "shipping-001",
shippingOptions: [
{
"id": "shipping-001",
"label": "$0.00: Free shipping",
"description": "Free Shipping delivered in 5 business days."
},
{
"id": "shipping-002",
"label": "$1.99: Standard shipping",
"description": "Standard shipping delivered in 3 business days."
},
{
"id": "shipping-003",
"label": "$10: Express shipping",
"description": "Express shipping delivered in 1 business day."
}
]
},
"transactionInfo": {
"countryCode": "US",
"currencyCode": "USD",
"totalPriceStatus": "ESTIMATED",
"totalPrice": "10.00",
"totalPriceLabel": "Total",
"displayItems": [{
"label": "Total Goods",
"price": "10.00",
"type": "LINE_ITEM",
"status": "FINAL"
}]
}
}
});
})();
</script>
</body>
</html>
Factureringsgegevens vastleggen van de klant Google Pay Wallet
Om de factureringsgegevens van de Google Pay Wallet van de klant vast te leggen en te gebruiken bij het verwerken van de betaling, zijn de volgende stappen vereist:
- In je ondertekende jwt payload moet je het veld billingcontactdetailsoverride met de waarde 1 opnemen.
- De billingAddressRequired moet worden ingesteld op waar in de configuratie van de GooglePay-methode.
- Om het e-mailadres optioneel vast te leggen, neemt u"emailRequired":true op in de paymentRequest.
-
billingAddressParameters biedt optionele eigenschappen die controle mogelijk maken over de hoeveelheid factureringsgegevens die de portemonnee van de klant nodig heeft voordat hij verder kan gaan met de betaling.
Eigendom Formaat Beschrijving format String Het formaat van het factuuradres is vereist om de transactie te voltooien.
-
MIN: Naam, landcode en postcode (standaard).
-
FULL: Naam, straatadres, plaats, regio, landcode en postcode.
phoneNumberRequired Booleaanse Ingesteld op waar als een telefoonnummer vereist is om de transactie te verwerken.
-
<html>
<head>
</head>
<body>
<div id="st-notification-frame"></div>
<form id="st-form" action="https://www.example.com"/>
<div id="st-google-pay"></div>
<script src="https://cdn.eu.trustpayments.com/js/latest/st.js"></script>
<script>
(function() {
var st = SecureTrading({
jwt: 'INSERT YOUR JWT HERE',
});
st.GooglePay({
"buttonOptions": {
"buttonRootNode": "st-google-pay"
},
"paymentRequest": {
"emailRequired":true,
"allowedPaymentMethods": [{
"parameters": {
"allowedAuthMethods": ["PAN_ONLY", "CRYPTOGRAM_3DS"],
"allowedCardNetworks": ["AMEX", "DISCOVER", "JCB", "MASTERCARD", "VISA"],
"billingAddressRequired":true,
"billingAddressParameters":{
"format":"FULL",
"phoneNumberRequired":true
}
...