iOS集成Apple Pay

2023-10-29 19:20
文章标签 ios 集成 apple pay

本文主要是介绍iOS集成Apple Pay,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Apple Pay是什么?

Apple Pay目前在国内上线已有一段时间,这意味着消费者可通过 苹果手机、苹果手表等智能设备来进行支付,它的功能类似一个“卡包”,讲实体银行卡虚拟到手机里,用户可以绑定储蓄卡或信用卡实现刷卡支付。


为什么使用Apple Pay

从理论上看微信支付也好、支付宝也好,均属于“结算平台”,他们会透过银联,从你的银行里提出现金代为托管;直至你把金钱放回银行之前,都只能在微信/支付宝上使用。但 Apple Pay 只是一张电子信用卡,你的钱仍然在银行里,付款时直接从银联向银行提取。而从技上术上,微信支付也好、支付宝也好,在付款时都要透过相机或条码机,读取一次性的二维码;而 Apple Pay 则透过近场通信 (NFC) 的方式,读取 iPhone 上的 Token 令牌。

从实际上看目前微信支付及支付宝的优势在于低入场门槛:商店只要有台智能手机,就毋须为移动支付购入/租用新设备,而消费者也不需要很高端的旗舰级设备。而 Apple Pay 优势是良好的用户体验,使用 Apple Pay 付费,既安全、又快捷、隐私度也比较高。


设备支持有哪些要求?

Apple Pay需要支持NFC功能,需要是iPhone6s以上设备,同时,用户需将手机操作系统版本升级到iOS 9.2以上,Apple Watch则需要Watch OS 2.1版本以上。


Apple Pay如何使用?

iPhone上,先打开系统自带的Wallet应用,后点右上角的符号,这时你有两个选择,可以用摄像头拍卡就能识别,也可以手动输入,或者通过iTunes绑定,至于Apple Watch怎么使用,应该操作差不多,具体情况本人未去实践,还望谅解。


Apple Pay环境配置

  • 配置Bundle ID
    14671699608022.jpg

  • 添加商户的ID
    14671702234549.jpg

  • 把工程中对应的Bundle ID添加进去
    14671703281837.jpg

  • 点击创建好的商户ID
    14671705166905.jpg

  • 编辑商户ID
    14671711439975.jpg

  • 添加CSR文件
    14671714784874.jpg

  • 下载配置好的商户ID
    14671715087391.jpg
    14671715713657.jpg

  • 创建对应的App IDs
    14671716587260.jpg

  • 勾选Apple Pay
    14671717034194.jpg

  • 配置支付环境
    14671720852032.jpg

  • Clean一下工程,如果工程自动添加此文件则以上步骤正确
    14671720005926.jpg


App项目内部集成方式

Apple Pay使用了PassKit框架,所以需要导入相应头文件

#import <PassKit/PassKit.h>

接收Apple Pay处理信息的回调,需要遵守协议,实现相应的代理方法

@interface ViewController ()<PKPaymentAuthorizationViewControllerDelegate>
@end

为了方便测试,触发支付操作时间写在touchBegan:方法中

- (void)touchesBegan:(NSSet<UITouch *> *)touches withEvent:(UIEvent *)event {// code...
}

具体代码实现如下:

  • 判断设备是否支持Apple Pay快捷支付功能
if (![PKPaymentAuthorizationViewController canMakePayments]) {// 提示用户该设备不支持Apple Pay快捷支付功能// code...return;}
  • 判断设备是否绑定过可支付的银行卡
	/***  若没有可用银行卡,则跳转到设置银行卡界面*  PKPaymentNetworkVisa                Visa国际卡*  PKPaymentNetworkChinaUnionPay       中国银联*  PKPaymentNetworkDiscover            Discover(美国流行的信用卡)*/if (![PKPaymentAuthorizationViewController canMakePaymentsUsingNetworks:@[PKPaymentNetworkVisa, PKPaymentNetworkChinaUnionPay, PKPaymentNetworkDiscover]]) {// 进入设置银行卡界面[[[PKPassLibrary alloc] init] openPaymentSetup];}
  • 设置商品参数
	// 创建商品NSDecimalNumber *firstAmount = [NSDecimalNumber decimalNumberWithString:@"1.11"];NSDecimalNumber *secondAmount = [NSDecimalNumber decimalNumberWithString:@"2.22"];NSDecimalNumber *thirdAmount = [NSDecimalNumber decimalNumberWithString:@"3.33"];NSDecimalNumber *amountSum = [NSDecimalNumber zero];amountSum = [amountSum decimalNumberByAdding:firstAmount];amountSum = [amountSum decimalNumberByAdding:secondAmount];amountSum = [amountSum decimalNumberByAdding:thirdAmount];/***  @param label        商品名称(英文名称默认全部显示大写)*  @param amount       商品价格 - NSDecimalNumber类型*/PKPaymentSummaryItem *firstItem = [PKPaymentSummaryItem summaryItemWithLabel:@"FirstItem" amount:firstAmount];PKPaymentSummaryItem *secondItem = [PKPaymentSummaryItem summaryItemWithLabel:@"SecondItem" amount:secondAmount];PKPaymentSummaryItem *thirdItem = [PKPaymentSummaryItem summaryItemWithLabel:@"ThirdtItem" amount:thirdAmount];PKPaymentSummaryItem *itemsSum = [PKPaymentSummaryItem summaryItemWithLabel:@"PJChao" amount:amountSum];
  • 创建支付请求(基本配置)
	PKPaymentRequest *request = [[PKPaymentRequest alloc] init];// 设置商户ID(merchant IDs)request.merchantIdentifier = @"merchant.com.zpj.ApplePayTest";// 设置国家代码(中国大陆)request.countryCode = @"CN";// 设置支付货币(人民币)request.currencyCode = @"CNY";// 设置商户的支付标准(3DS支付方式必须支持,其他方式可选)request.merchantCapabilities = PKMerchantCapability3DS;request.paymentSummaryItems = @[firstItem, secondItem, thirdItem, itemsSum];/***  以上参数都是必须的*  以下参数不是必须的*/// 设置收据内容request.requiredBillingAddressFields = PKAddressFieldAll;// 设置送货内容request.requiredShippingAddressFields = PKAddressFieldAll;// 设置送货方式PKShippingMethod *method = [PKShippingMethod summaryItemWithLabel:@"阿敏" amount:[NSDecimalNumber decimalNumberWithString:@"10.00"]];method.identifier = @"阿敏物流";method.detail = @"12小时到达";request.shippingMethods = @[method];
  • 显示支付界面
	PKPaymentAuthorizationViewController *paymentVC = [[PKPaymentAuthorizationViewController alloc] initWithPaymentRequest:request];paymentVC.delegate = self;if (paymentVC == nil) return;[self presentViewController:paymentVC animated:YES completion:nil];
  • 代理方法的实现
#pragma mark - <PKPaymentAuthorizationViewControllerDelegate>
- (void)paymentAuthorizationViewController:(PKPaymentAuthorizationViewController *)controllerdidAuthorizePayment:(PKPayment *)paymentcompletion:(void (^)(PKPaymentAuthorizationStatus status))completion
{/***  在这里支付信息应发送给服务器/第三方的SDK(银联SDK/易宝支付SDK/易智付SDK等)*  再根据服务器返回的支付成功与否进行不同处理*  这里直接返回支付成功*/completion(PKPaymentAuthorizationStatusSuccess);
}- (void)paymentAuthorizationViewControllerDidFinish:(PKPaymentAuthorizationViewController *)controller
{// 点击支付/取消按钮隐藏界面[controller dismissViewControllerAnimated:YES completion:nil];
}

附上测试结果

这篇关于iOS集成Apple Pay的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/302819

相关文章

SpringBoot集成LiteFlow实现轻量级工作流引擎的详细过程

《SpringBoot集成LiteFlow实现轻量级工作流引擎的详细过程》LiteFlow是一款专注于逻辑驱动流程编排的轻量级框架,它以组件化方式快速构建和执行业务流程,有效解耦复杂业务逻辑,下面给大... 目录一、基础概念1.1 组件(Component)1.2 规则(Rule)1.3 上下文(Conte

使用vscode搭建pywebview集成vue项目实践

《使用vscode搭建pywebview集成vue项目实践》:本文主要介绍使用vscode搭建pywebview集成vue项目实践,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地... 目录环境准备项目源码下载项目说明调试与生成可执行文件核心代码说明总结本节我们使用pythonpywebv

Maven项目中集成数据库文档生成工具的操作步骤

《Maven项目中集成数据库文档生成工具的操作步骤》在Maven项目中,可以通过集成数据库文档生成工具来自动生成数据库文档,本文为大家整理了使用screw-maven-plugin(推荐)的完... 目录1. 添加插件配置到 pom.XML2. 配置数据库信息3. 执行生成命令4. 高级配置选项5. 注意事

Java集成Onlyoffice的示例代码及场景分析

《Java集成Onlyoffice的示例代码及场景分析》:本文主要介绍Java集成Onlyoffice的示例代码及场景分析,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要... 需求场景:实现文档的在线编辑,团队协作总结:两个接口 + 前端页面 + 配置项接口1:一个接口,将o

Swagger2与Springdoc集成与使用详解

《Swagger2与Springdoc集成与使用详解》:本文主要介绍Swagger2与Springdoc集成与使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录1. 依赖配置2. 基础配置2.1 启用 Springdoc2.2 自定义 OpenAPI 信息3.

Spring Boot 集成 Solr 的详细示例

《SpringBoot集成Solr的详细示例》:本文主要介绍SpringBoot集成Solr的详细示例,本文通过实例代码给大家介绍的非常详细,感兴趣的朋友一起看看吧... 目录环境准备添加依赖配置 Solr 连接定义实体类编写 Repository 接口创建 Service 与 Controller示例运行

Spring Boot集成SLF4j从基础到高级实践(最新推荐)

《SpringBoot集成SLF4j从基础到高级实践(最新推荐)》SLF4j(SimpleLoggingFacadeforJava)是一个日志门面(Facade),不是具体的日志实现,这篇文章主要介... 目录一、日志框架概述与SLF4j简介1.1 为什么需要日志框架1.2 主流日志框架对比1.3 SLF4

Spring Boot集成Logback终极指南之从基础到高级配置实战指南

《SpringBoot集成Logback终极指南之从基础到高级配置实战指南》Logback是一个可靠、通用且快速的Java日志框架,作为Log4j的继承者,由Log4j创始人设计,:本文主要介绍... 目录一、Logback简介与Spring Boot集成基础1.1 Logback是什么?1.2 Sprin

Android与iOS设备MAC地址生成原理及Java实现详解

《Android与iOS设备MAC地址生成原理及Java实现详解》在无线网络通信中,MAC(MediaAccessControl)地址是设备的唯一网络标识符,本文主要介绍了Android与iOS设备M... 目录引言1. MAC地址基础1.1 MAC地址的组成1.2 MAC地址的分类2. android与I

springboot集成Lucene的详细指南

《springboot集成Lucene的详细指南》这篇文章主要为大家详细介绍了springboot集成Lucene的详细指南,文中的示例代码讲解详细,具有一定的借鉴价值,感兴趣的小伙伴可以跟随小编一起... 目录添加依赖创建配置类创建实体类创建索引服务类创建搜索服务类创建控制器类使用示例以下是 Spring