iOS 如何加快测试内购功能?

这里每天分享一个 iOS 的新知识,快来关注我吧

前言

在以前,测试内购不是一件容易的事情,需要开沙盒账号,打各种测试包之类的。

从 Xcode 14 开始,苹果推出了一个 StoreKit 配置文件,可以支持在 Xcode 中测试 App 内购买项目。还能够在不连接到 App Store 服务器的情况下购买产品,无需互联网连接,并且还能测试交易失败等各种边缘情况。

今天就来聊聊这个功能。

创建 StoreKit Configuration

要测试内购产品,需要先在 Xcode 中创建一个 StoreKit Configuration 文件,点击快捷键 Command + N,新建文件,搜索 StoreKit,可以看到一个 StoreKit Configuration File

点击下一步,输入名称,如果你的应用在 App Store Connect 上已经创建了一些内购商品,则需要勾选 Sync this file with an app in App Store Connect,勾选后会自动同步已有商品(这种情况貌似只能同步,不能编辑),最后点击下一步,完成创建。

我本次演示的 Demo 中没有勾选同步选项,创建出这个文件后,点击打开,是一个空页面,点击页面的左下角的加号:

这里可以创建用于售卖的 4 种商品类型:

  • Add Consumable In-App Purchase: 消耗品

  • Add Non-Consumable In-App Purchase: 非消耗品

  • Add Non-Renewing Subscription: 非续订订阅商品

  • Add Renewable Subscription: 可续订订阅商品

比如我们点击创建一个消耗品,输入产品名称和 ID,点击完成按钮,屏幕上出现了这个产品的信息,并且可以动态配置产品名、ID、价格、本地化信息等选项:

创建其他产品也是一样的操作,这里就不演示了。

在这个产品的上方还可以看到 Configuration Settings 的选项,点击之后可以看到关于内购的相关配置:

这里可以配置更详细的内容,比如默认的地区、语言,购买选项,以及模拟各种购买过程中的报错信息,可以自己探索一下。

启动 StoreKit 测试

要使用这个配置文件,需要在启动选项中设置,点击运行选项中的项目 -> Edit Scheme...

在 Run 一栏中的 StoreKit Configuration 中选择我们刚刚创建的配置文件,并点击完成。

此时运行项目,就能在项目中使用这个配置文件了。

代码部分

接下来可以在项目中获取刚刚配置的产品了,因为使用的是本地的配置文件,因此即使在无网的情况下也能正常进行获取和购买。

swift 复制代码
import StoreKit

class ViewController: UIViewController, SKProductsRequestDelegate {
    override func viewDidLoad() {
        super.viewDidLoad()
        view.backgroundColor = .white
        // 配置请求
        let req = SKProductsRequest(productIdentifiers: ["ios.product1"])
        req.delegate = self
        
        // 开始请求商品
        req.start()
    }

    func productsRequest(_ request: SKProductsRequest, didReceive response: SKProductsResponse) {
        guard let product = response.products.first else {
            return
        }
        
        // 商品请求成功,渲染出来
        DispatchQueue.main.async {
            let label = UILabel()
            label.text = "商品ID:\(product.productIdentifier)\n商品名:\(product.localizedTitle)\n价格:\(product.price)"
            label.numberOfLines = 0
            label.textAlignment = .center
            self.view.addSubview(label)
            label.sizeToFit()
            label.center = self.view.center
        }
    }
}

我这里只是简单的写了获取商品的代码,关于购买的部分,以后专门写一篇给大家介绍。

最后运行代码,就可以成功的在模拟器上看到商品信息了:

这里每天分享一个 iOS 的新知识,快来关注我吧

本文同步自微信公众号 "iOS新知",每天准时分享一个新知识,这里只是同步,想要及时学到就来关注我吧!

相关推荐
权咚12 小时前
阿权的开发经验小集
git·ios·xcode
用户0912 小时前
TipKit与CloudKit同步完全指南
ios·swift
法的空间18 小时前
Flutter JsonToDart 支持 JsonSchema
android·flutter·ios
2501_9159184119 小时前
iOS 上架全流程指南 iOS 应用发布步骤、App Store 上架流程、uni-app 打包上传 ipa 与审核实战经验分享
android·ios·小程序·uni-app·cocoa·iphone·webview
00后程序员张21 小时前
iOS App 混淆与加固对比 源码混淆与ipa文件混淆的区别、iOS代码保护与应用安全场景最佳实践
android·安全·ios·小程序·uni-app·iphone·webview
东坡肘子21 小时前
完成 Liquid Glass 的适配了吗?| 肘子的 Swift 周报 #0102
swiftui·swift·apple
Magnetic_h1 天前
【iOS】设计模式复习
笔记·学习·ios·设计模式·objective-c·cocoa
00后程序员张1 天前
详细解析苹果iOS应用上架到App Store的完整步骤与指南
android·ios·小程序·https·uni-app·iphone·webview
前端小超超1 天前
capacitor配置ios应用图标不同尺寸
ios·蓝桥杯·cocoa
2501_915106321 天前
Xcode 上传 ipa 全流程详解 App Store 上架流程、uni-app 生成 ipa 文件上传与审核指南
android·macos·ios·小程序·uni-app·iphone·xcode