2016-04-27 6 views
2

Ich versuche, ein Braintree Payments-Drop-In in eine Ionic-Mobile-App zu integrieren. Basierend auf der Braintree Dokumentation und einige Code-Beispiele, die ich online finden konnte, ist der folgende Code, was ich habe es geschafft, mit so weit zu kommen, aber es scheint nicht zu funktionieren:Braintree Drop-in-Container in Ionic

controller.js

.controller('CheckoutForm', function($scope, $window) { 
    $scope.clientToken = "<token generated by the server>" 

    $scope.renderCheckout = function() { 
    braintree.setup($scope.clientToken, "dropin", { 
     container: "payment-form" 
     }); 
    } 
}) 

template.html

<div> 
    Payment details: 
    <form id="checkout"> 
    <div id="payment-form" onLoad="renderCheckout()"></div> 
    </form> 
</div> 

ich habe auch die folgende Zeile in der index.html:

<script src="https://js.braintreegateway.com/js/braintree-2.23.0.min.js"></script> 

Ich bin ziemlich neu in Ionic und HTML5/JS Entwicklung im Allgemeinen, so würde jede Hilfe sehr geschätzt werden.

Antwort

3

Vergessen Sie die Onload-Funktion. Tun Sie das einfach in Ihrem Controller.

var clientToken = "eyJ2ZXJzaW9uIjoyLCJhdXRob3JpemF0aW9uRmluZ2VycHJpbnQiOiIyMTUwYzJiOWYyODdlMmZmMzUyZWQxZmMyMDFiNjY3ZDE5OGNhMjEwNjAyYmYzNzI1NmVmNDIzMWY0Yjg3OGNmfGNyZWF0ZWRfYXQ9MjAxNi0wNC0yOFQwNjoyODo1My43NjM0MjY0MzYrMDAwMFx1MDAyNm1lcmNoYW50X2lkPTM0OHBrOWNnZjNiZ3l3MmJcdTAwMjZwdWJsaWNfa2V5PTJuMjQ3ZHY4OWJxOXZtcHIiLCJjb25maWdVcmwiOiJodHRwczovL2FwaS5zYW5kYm94LmJyYWludHJlZWdhdGV3YXkuY29tOjQ0My9tZXJjaGFudHMvMzQ4cGs5Y2dmM2JneXcyYi9jbGllbnRfYXBpL3YxL2NvbmZpZ3VyYXRpb24iLCJjaGFsbGVuZ2VzIjpbXSwiZW52aXJvbm1lbnQiOiJzYW5kYm94IiwiY2xpZW50QXBpVXJsIjoiaHR0cHM6Ly9hcGkuc2FuZGJveC5icmFpbnRyZWVnYXRld2F5LmNvbTo0NDMvbWVyY2hhbnRzLzM0OHBrOWNnZjNiZ3l3MmIvY2xpZW50X2FwaSIsImFzc2V0c1VybCI6Imh0dHBzOi8vYXNzZXRzLmJyYWludHJlZWdhdGV3YXkuY29tIiwiYXV0aFVybCI6Imh0dHBzOi8vYXV0aC52ZW5tby5zYW5kYm94LmJyYWludHJlZWdhdGV3YXkuY29tIiwiYW5hbHl0aWNzIjp7InVybCI6Imh0dHBzOi8vY2xpZW50LWFuYWx5dGljcy5zYW5kYm94LmJyYWludHJlZWdhdGV3YXkuY29tLzM0OHBrOWNnZjNiZ3l3MmIifSwidGhyZWVEU2VjdXJlRW5hYmxlZCI6dHJ1ZSwicGF5cGFsRW5hYmxlZCI6dHJ1ZSwicGF5cGFsIjp7ImRpc3BsYXlOYW1lIjoiQWNtZSBXaWRnZXRzLCBMdGQuIChTYW5kYm94KSIsImNsaWVudElkIjpudWxsLCJwcml2YWN5VXJsIjoiaHR0cDovL2V4YW1wbGUuY29tL3BwIiwidXNlckFncmVlbWVudFVybCI6Imh0dHA6Ly9leGFtcGxlLmNvbS90b3MiLCJiYXNlVXJsIjoiaHR0cHM6Ly9hc3NldHMuYnJhaW50cmVlZ2F0ZXdheS5jb20iLCJhc3NldHNVcmwiOiJodHRwczovL2NoZWNrb3V0LnBheXBhbC5jb20iLCJkaXJlY3RCYXNlVXJsIjpudWxsLCJhbGxvd0h0dHAiOnRydWUsImVudmlyb25tZW50Tm9OZXR3b3JrIjp0cnVlLCJlbnZpcm9ubWVudCI6Im9mZmxpbmUiLCJ1bnZldHRlZE1lcmNoYW50IjpmYWxzZSwiYnJhaW50cmVlQ2xpZW50SWQiOiJtYXN0ZXJjbGllbnQzIiwiYmlsbGluZ0FncmVlbWVudHNFbmFibGVkIjp0cnVlLCJtZXJjaGFudEFjY291bnRJZCI6ImFjbWV3aWRnZXRzbHRkc2FuZGJveCIsImN1cnJlbmN5SXNvQ29kZSI6IlVTRCJ9LCJjb2luYmFzZUVuYWJsZWQiOmZhbHNlLCJtZXJjaGFudElkIjoiMzQ4cGs5Y2dmM2JneXcyYiIsInZlbm1vIjoib2ZmIn0="; 

// Client token above is just for testing and provided by Braintree for testing purposes 

braintree.setup(clientToken, "dropin", { 
    container: "payment-form" 
}); 

Dann in Ihrem html:

<form id="checkout"> 
    <div id="payment-form"></div> 
</form> 

Für mobiles erinnern richtige Inhalt Sicherheitspolitik und weiße Listen mit der cordova-Whitelist-Plugin hinzuzufügen.

Dokumentation für CSP: https://developers.braintreepayments.com/reference/client-reference/javascript/v2/best-practices#using-braintree.js-with-a-content-security-policy

Dokumentation für Cordova Whitelist-Plugin: https://cordova.apache.org/docs/en/latest/guide/appdev/whitelist/index.html

+0

das scheint zu funktionieren! Danke für Ihre Hilfe – whtvr

+0

Vielen Dank für das cordova Whitelist Plugin. Ist das in Ordnung mit einem importierten Braintree Drop-In Modul zu verwenden oder sollte es ausschließlich mit cordova Braintree Plugin verwendet werden? –

1

Was thepio 'ist nur für die Prüfung vorgeschlagen. Der richtige Weg könnte jedoch sein, den Client-Token auf Ihrem Server zu generieren. Dann wird Ihre Ionic App POST und holen Sie das Client-Token von Ihrem Server. Und sobald die Zahlung nonce generiert wurde, können Sie Ihre Zahlungsdaten an Ihren Server senden, um die Zahlung zu verarbeiten.

Überprüfen Sie diese Beispielimplementierung. https://github.com/demianborba/braintree-cordova-angular-node

+0

Ich denke, der Fragesteller ist sich darüber im Klaren, seit er/sie $ $ scope.clientToken = "" in seiner Frage geschrieben hat. Und in meiner Antwort habe ich gerade klargestellt, dass das Token in meiner Antwort nur für Testzwecke ist :) – thepio

+0

Vielen Dank für Ihren Kommentar! Ja, ich erstelle das Token auf meinem Server und von dort wird es von der mobilen App angefordert. – whtvr

Verwandte Themen