Sprzedawcy mogą korzystać z potwierdzenia bezpiecznych płatności (SPC) w ramach silnego uwierzytelniania klienta (SCA) w przypadku danej karty kredytowej lub konta bankowego. WebAuthn przeprowadza uwierzytelnianie (często za pomocą danych biometrycznych). WebAuthn musi być zarejestrowany z wyprzedzeniem. Więcej informacji znajdziesz w artykule Rejestracja potwierdzenia bezpiecznej płatności.
Jak działa typowa implementacja
Najczęściej używa się SPC, gdy klient dokonuje zakupu na witryny, więc wystawca karty kredytowej lub bank wymaga uwierzytelniania płatnika.
Przyjrzyjmy się procesowi uwierzytelniania:
- Klient podaje swoje dane uwierzytelniające płatność (np. kartę kredytową) informacje) sprzedawcy.
- Sprzedawca pyta odpowiedniego wystawcę lub bank danych uwierzytelniających płatność.
(strona uzależniona lub RP), jeśli płatnik wymaga osobnego uwierzytelniania. Ten
może odbywać się na przykład z
EMV® 3-D Secure.
- Jeśli RP chce, aby sprzedawca używał SPC, a użytkownik wcześniej zarejestrowanych, w odpowiedzi przesyłana jest lista identyfikatorów danych logowania zarejestrowanych przez z płatnikiem i z wyzwaniem.
- Jeśli uwierzytelnienie nie jest potrzebne, sprzedawca może przejść do sfinalizować transakcję.
- Jeśli wymagane jest uwierzytelnianie, sprzedawca określa, czy przeglądarka obsługuje SPC.
- Jeśli przeglądarka nie obsługuje SPC, skorzystaj z dotychczasowej wersji proces uwierzytelniania.
- Sprzedawca wywołuje SPC. Przeglądarka wyświetli okno potwierdzenia.
- Jeśli z grupy objętej ograniczeniami nie zostały przekazane żadne identyfikatory danych logowania, użyj interfejsu z dotychczasowego procesu uwierzytelniania. Po pomyślnym uwierzytelnieniu zastanów się nad użyciem rejestracji SPC. aby usprawnić proces uwierzytelniania w przyszłości.
- Użytkownik potwierdza i uwierzytelnia kwotę oraz miejsce docelowe płatności po odblokowaniu urządzenia.
- Sprzedawca otrzymuje dane logowania z uwierzytelnienia.
- RP otrzymuje dane uwierzytelniające od sprzedawcy i weryfikuje swój autentyczności.
- RP wysyła wyniki weryfikacji do sprzedawcy.
- Sprzedawca wyświetla użytkownikowi komunikat informujący o tym, czy płatność została dokonana udanej lub nieudanej.
Wykrywanie cech
Aby sprawdzić, czy przeglądarka obsługuje SPC, możesz wysłać fałszywe połączenie do
canMakePayment()
Skopiuj i wklej ten kod, aby włączyć wykrywanie SPC w witrynie sprzedawcy.
const isSecurePaymentConfirmationSupported = async () => {
if (!'PaymentRequest' in window) {
return [false, 'Payment Request API is not supported'];
}
try {
// The data below is the minimum required to create the request and
// check if a payment can be made.
const supportedInstruments = [
{
supportedMethods: "secure-payment-confirmation",
data: {
// RP's hostname as its ID
rpId: 'rp.example',
// A dummy credential ID
credentialIds: [new Uint8Array(1)],
// A dummy challenge
challenge: new Uint8Array(1),
instrument: {
// Non-empty display name string
displayName: ' ',
// Transparent-black pixel.
icon: '',
},
// A dummy merchant origin
payeeOrigin: 'https://non-existent.example',
}
}
];
const details = {
// Dummy shopping details
total: {label: 'Total', amount: {currency: 'USD', value: '0'}},
};
const request = new PaymentRequest(supportedInstruments, details);
const canMakePayment = await request.canMakePayment();
return [canMakePayment, canMakePayment ? '' : 'SPC is not available'];
} catch (error) {
console.error(error);
return [false, error.message];
}
};
isSecurePaymentConfirmationSupported().then(result => {
const [isSecurePaymentConfirmationSupported, reason] = result;
if (isSecurePaymentConfirmationSupported) {
// Display the payment button that invokes SPC.
} else {
// Fallback to the legacy authentication method.
}
});
Uwierzytelnienie użytkownika
Aby uwierzytelnić użytkownika, wywołaj metodę PaymentRequest.show()
z
Parametry secure-payment-confirmation
i WebAuthn:
PublicKeyCredentialRequestOptions
- innych parametrów związanych z płatnościami na platformie sprzedawcy.
Oto parametry, które należy podać we właściwości SecurePaymentConfirmationRequest
formy płatności: data
.
Zapoznaj się z tym przykładowym kodem:
// After confirming SPC is available on this browser via a feature detection,
// fetch the request options cross-origin from the RP server.
const options = fetchFromServer('https://rp.example/spc-auth-request');
const { credentialIds, challenge } = options;
const request = new PaymentRequest([{
// Specify `secure-payment-confirmation` as payment method.
supportedMethods: "secure-payment-confirmation",
data: {
// The RP ID
rpId: 'rp.example',
// List of credential IDs obtained from the RP server.
credentialIds,
// The challenge is also obtained from the RP server.
challenge,
// A display name and an icon that represent the payment instrument.
instrument: {
displayName: "Fancy Card ****1234",
icon: "https://rp.example/card-art.png",
iconMustBeShown: false
},
// The origin of the payee (merchant)
payeeOrigin: "https://merchant.example",
// The number of milliseconds to timeout.
timeout: 360000, // 6 minutes
}
}], {
// Payment details.
total: {
label: "Total",
amount: {
currency: "USD",
value: "5.00",
},
},
});
try {
const response = await request.show();
// response.details is a PublicKeyCredential, with a clientDataJSON that
// contains the transaction data for verification by the issuing bank.
// Make sure to serialize the binary part of the credential before
// transferring to the server.
const result = fetchFromServer('https://rp.example/spc-auth-response', response.details);
if (result.success) {
await response.complete('success');
} else {
await response.complete('fail');
}
} catch (err) {
// SPC cannot be used; merchant should fallback to traditional flows
console.error(err);
}
Funkcja .show()
daje wynik
PaymentResponse
.
oprócz obiektu details
, który zawiera dane logowania klucza publicznego z
clientDataJSON
, który zawiera dane transakcji
(payment
)
do weryfikacji przez RP.
Otrzymane dane logowania muszą zostać przeniesione z innych domen do RP. zweryfikowane.
Jak RP weryfikuje transakcję
Weryfikacja danych transakcji na serwerze RP jest najważniejszym etapem proces płatności.
Aby zweryfikować dane transakcji, w RPA może przejść proces weryfikacji potwierdzenia uwierzytelniania WebAuthn.
Muszą także:
zweryfikować payment
.
Przykładowy ładunek elementu clientDataJSON
:
{
"type":"payment.get",
"challenge":"SAxYy64IvwWpoqpr8JV1CVLHDNLKXlxbtPv4Xg3cnoc",
"origin":"https://spc-merchant.glitch.me",
"crossOrigin":false,
"payment":{
"rp":"spc-rp.glitch.me",
"topOrigin":"https://spc-merchant.glitch.me",
"payeeOrigin":"https://spc-merchant.glitch.me",
"total":{
"value":"15.00",
"currency":"USD"
},
"instrument":{
"icon":"https://cdn.glitch.me/94838ffe-241b-4a67-a9e0-290bfe34c351%2Fbank.png?v=1639111444422",
"displayName":"Fancy Card 825809751248"
}
}
}
rp
odpowiada punktowi pochodzenia grupy objętej ograniczeniami.- Element
topOrigin
jest zgodny z punktem początkowym najwyższego poziomu oczekiwanego przez grupę objętą ograniczeniami (parametr sprzedawcy w powyższym przykładzie). - Znak
payeeOrigin
jest zgodny z adresem pochodzenia odbiorcy płatności, który powinien być wyświetlanych użytkownikowi. - Wartość
total
odpowiada kwocie transakcji, która powinna zostać wyświetlona po stronie użytkownika. - Parametr
instrument
jest zgodny ze szczegółami instrumentu płatności, które powinny mieć które zostały wyświetlone użytkownikowi.
const clientData = base64url.decode(response.clientDataJSON);
const clientDataJSON = JSON.parse(clientData);
if (!clientDataJSON.payment) {
throw 'The credential does not contain payment payload.';
}
const payment = clientDataJSON.payment;
if (payment.rp !== expectedRPID ||
payment.topOrigin !== expectedOrigin ||
payment.payeeOrigin !== expectedOrigin ||
payment.total.value !== '15.00' ||
payment.total.currency !== 'USD') {
throw 'Malformed payment information.';
}
Gdy spełnią wszystkie kryteria weryfikacji, RP może stwierdzić, że transakcja się udała.
Dalsze kroki
- Przeczytaj omówienie potwierdzenia bezpiecznych płatności.
- Dowiedz się więcej o rejestracji z potwierdzeniem bezpiecznych płatności.