Braintree API 向业务对象返回各种内部 ID,包括Subscription
、Plan
、PaymentMethod
等的 ID。与最终用户的应用程序(在用户设备上运行的前端代码)共享这些 ID 是否存在任何安全问题?(最终用户不会看到这些 ID,但它们会通过网络传输。)
详细示例:
用户向应用程序添加付款方式。App 服务器将请求转发给 Braintree,例如:
val result = gateway.paymentMethod.create(
new PaymentMethodRequest()
.customerId(user.billing.get.braintree.customerID)
.paymentMethodNonce(nonce)
.billingAddressId(user.billing.get.braintree.addressID.get)
.options()
.makeDefault(true)
.verifyCard(true)
.failOnDuplicatePaymentMethod(false)
.done()
)
然后对结果进行如下处理:
Option(result.getTarget)
.map {
case card: CreditCard =>
braintreePaymentMethod(
card.getClass.getCanonicalName,
card.getToken,
card.getImageUrl,
card.isDefault,
"ending " + card.getLast4
)
}
.getOrElse(throw Payments.Exception.Braintree(result.getMessage))
card.getToken
返回支付方式的令牌,如接口:
public interface PaymentMethod {
String getToken();
boolean isDefault();
String getImageUrl();
String getCustomerId();
List<Subscription> getSubscriptions();
}
获取到的上述tokengetToken
然后用于检查支付方式的存在,并用于移除、列出和更新支付方式。
在内部,在应用程序中,此令牌也可用于识别付款方式。
回顾:与用户共享此令牌是否存在任何安全问题?