Braintree iOS Drop-in SDK - 一站式支付解决方案

Braintree iOS Drop-in SDK

Braintree iOS Drop-in SDK 是一个功能强大的支付集成解决方案,为iOS应用提供了一套完整的支付UI组件。它支持多种支付方式,包括信用卡、PayPal、Venmo和Apple Pay,让开发者能够快速集成安全可靠的支付功能。

功能特性

  • 多支付方式支持:集成信用卡、PayPal、Venmo和Apple Pay等多种支付方式
  • UI自定义 :通过BTDropInUICustomization全面自定义UI样式和颜色方案
  • 安全支付处理:支持3D Secure验证和安全的支付信息处理
  • 支付管理:提供支付方式的保存、管理和选择功能
  • 国际化支持:包含多语言本地化和RTL布局支持
  • 无障碍访问:默认支持动态字体大小和无障碍功能
  • 现代技术栈:要求Xcode 15.0+和Swift 5.9+,支持iOS 12.0+

安装指南

Swift Package Manager

swift 复制代码
dependencies: [
    .package(url: "https://github.com/braintree/braintree-ios-drop-in", from: "9.14.0")
]

CocoaPods

ruby 复制代码
pod 'BraintreeDropIn'

系统要求

  • iOS 12.0+
  • Xcode 15.0+
  • Swift 5.9+

使用说明

基本集成

swift 复制代码
import BraintreeDropIn

// 初始化Drop-in控制器
let dropInRequest = BTDropInRequest()
dropInRequest.cardholderNameSetting = .required
dropInRequest.vaultCard = true

let dropIn = BTDropInController(authorization: "your_client_token", 
                               request: dropInRequest) 
{ (controller, result, error) in
    if let error = error {
        print("Error: \(error.localizedDescription)")
    } else if let result = result {
        // 处理支付结果
        print("Payment method type: \(result.paymentMethodType)")
        print("Payment description: \(result.paymentDescription)")
    }
    controller.dismiss(animated: true)
}

// 呈现Drop-in界面
present(dropIn!, animated: true)

UI自定义示例

swift 复制代码
let uiCustomization = BTDropInUICustomization(colorScheme: .light)
uiCustomization.fontFamily = "Helvetica"
uiCustomization.boldFontFamily = "Helvetica-Bold"
uiCustomization.tintColor = .systemBlue

let dropInRequest = BTDropInRequest()
dropInRequest.uiCustomization = uiCustomization

获取最近支付方式

swift 复制代码
BTDropInResult.mostRecentPaymentMethod(forClientToken: clientToken) { result, error in
    if let result = result {
        // 显示最近使用的支付方式
        let paymentIcon = result.paymentIcon
        let description = result.paymentDescription
    }
}

核心代码

支付表单控制器

swift 复制代码
// BTCardFormViewController.h
@interface BTCardFormViewController : BTDropInBaseViewController <UITextFieldDelegate>

@property (nonatomic, strong, readonly) BTUIKCardNumberFormField *cardNumberField;
@property (nonatomic, strong, readonly) BTUIKCardholderNameFormField *cardholderNameField;
@property (nonatomic, strong, readonly) BTUIKExpiryFormField *expirationDateField;
@property (nonatomic, strong, readonly) BTUIKSecurityCodeFormField *securityCodeField;

// 如果表单有效,返回BTCardRequest
@property (nonatomic, strong, nullable, readonly) BTCardRequest *cardRequest;

@end

UI定制配置

swift 复制代码
// BTDropInUICustomization.m
- (instancetype)initWithColorScheme:(BTDropInColorScheme)colorScheme {
    if (self = [super init]) {
        _useBlurs = YES;
        _postalCodeFormFieldKeyboardType = UIKeyboardTypeDefault;

        switch(colorScheme) {
            case BTDropInColorSchemeLight:
                _barBackgroundColor = UIColor.whiteColor;
                _formBackgroundColor = [UIColor btuik_colorFromHex:@"EFEFF4" alpha:1.0];
                _primaryTextColor = UIColor.blackColor;
                _secondaryTextColor = [UIColor btuik_colorFromHex:@"3C3C43" alpha:1.0];
                break;
            case BTDropInColorSchemeDark:
                _barBackgroundColor = [UIColor btuik_colorFromHex:@"222222" alpha:1.0];
                _formBackgroundColor = [UIColor btuik_colorFromHex:@"222222" alpha:1.0];
                _primaryTextColor = UIColor.whiteColor;
                _secondaryTextColor = [UIColor btuik_colorFromHex:@"EBEBF5" alpha:1.0];
                break;
            default: // dynamic
                if (@available(iOS 13, *)) {
                    _barBackgroundColor = UIColor.systemBackgroundColor;
                    _formBackgroundColor = UIColor.systemGroupedBackgroundColor;
                    _primaryTextColor = UIColor.labelColor;
                    _secondaryTextColor = UIColor.secondaryLabelColor;
                }
        }
    }
    return self;
}

支付方式处理

swift 复制代码
// BTPaymentMethodNonce+DropIn.m
- (NSString *)paymentDescription {
    if ([self isKindOfClass:[BTCardNonce class]]) {
        return ((BTCardNonce *)self).lastFour;
    } else if ([self isKindOfClass:[BTPayPalAccountNonce class]]) {
        return ((BTPayPalAccountNonce *)self).email;
    } else if ([self isKindOfClass:[BTVenmoAccountNonce class]]) {
        return ((BTVenmoAccountNonce *)self).username;
    } else if ([self isKindOfClass:[BTApplePayCardNonce class]]) {
        return @"Apple Pay";
    } else {
        return @"";
    }
}

基础视图控制器

swift 复制代码
// BTDropInBaseViewController.m
- (instancetype)initWithAPIClient:(BTAPIClient *)apiClient request:(BTDropInRequest *)request {
    if (self = [super init]) {
        self.apiClient = apiClient;
        _dropInRequest = request;
    }
    return self;
}

- (void)loadConfiguration {
    [self.apiClient fetchOrReturnRemoteConfiguration:^(BTConfiguration *configuration, NSError *error) {
        self.configuration = configuration;
        [self configurationLoaded:configuration error:error];
    }];
}
相关推荐
NAGNIP3 分钟前
一文搞懂深度学习中的通用逼近定理!
人工智能·算法·面试
冬奇Lab1 小时前
一天一个开源项目(第36篇):EverMemOS - 跨 LLM 与平台的长时记忆 OS,让 Agent 会记忆更会推理
人工智能·开源·资讯
冬奇Lab1 小时前
OpenClaw 源码深度解析(一):Gateway——为什么需要一个"中枢"
人工智能·开源·源码阅读
AngelPP5 小时前
OpenClaw 架构深度解析:如何把 AI 助手搬到你的个人设备上
人工智能
宅小年5 小时前
Claude Code 换成了Kimi K2.5后,我再也回不去了
人工智能·ai编程·claude
小碗细面5 小时前
告别手动喂饭!Skill-Seekers 快速构建你的 AI 专属知识库
aigc·ai编程
九狼5 小时前
Flutter URL Scheme 跨平台跳转
人工智能·flutter·github
ZFSS5 小时前
Kimi Chat Completion API 申请及使用
前端·人工智能
王小酱6 小时前
AI 编程实战指南:核心概念梳理与 Claude Code 高效技巧
aigc·openai·ai编程
天翼云开发者社区7 小时前
春节复工福利就位!天翼云息壤2500万Tokens免费送,全品类大模型一键畅玩!
人工智能·算力服务·息壤