高效解析iOS收据:ProtonLabs/ios-receipt-parser 库的使用指南

发布时间 - 2025-03-09 00:00:00    点击率:

在开发ios应用内购功能时,我们需要验证用户的购买行为。通常的做法是将收据数据发送到苹果服务器进行验证。然而,在使用xcode的测试功能进行内购流程测试时,生成的收据是由本地特殊用途证书签名的,无法通过苹果服务器验证。这就需要一种能够在本地解析和验证收据的方法。

我最初尝试自己编写解析代码,但苹果收据的格式(PKCS#7容器)比较复杂,涉及到证书验证和ASN.1数据的解析,实现起来非常耗时且容易出错。这时,我找到了ProtonLabs/ios-receipt-parser这个库。它是一个轻量级的PHP库,专门用于解析苹果iOS应用的收据数据,无需调用苹果服务器。

使用Composer安装这个库非常简单:

composer require protonlabs/ios-receipt-parser

安装完成后,就可以开始使用这个库了。以下是一个简单的例子,演示如何解析一个未经验证的收据:

DIR . '/vendor/autoload.php';const RECEIPT = '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';$receipt = (new Parser())->parseUnverified(RECEIPT);// Just for documentation purposeassert($receipt instanceof Receipt);var_dump($receipt->getBundleId());foreach ($receipt->getInApp() as $inApp) {    // Just for documentation purpose    assert($inApp instanceof InApp);    var_dump("{$inApp->getQuantity()} x {$inApp->getProductIdentifier()}");}

这段代码首先引入必要的类,然后创建一个Parser实例,并调用parseUnverified()方法解析收据。 parseUnverified() 方法解析收据但不验证签名。 最后,代码打印出收据的Bundle ID和应用内购项目信息。

对于需要验证签名的场景,库也提供了parseUsingOnlyTrustedCerts()方法,但需要安装symfony/process,并确保系统安装了openssl并且PHP配置允许执行shell脚本。 这个方法允许你提供可信证书来验证收据签名。 记住,只传递可信证书到这个方法。

通过使用ProtonLabs/ios-receipt-parser库,我能够快速、高效地解析和(可选)验证iOS收据,极大地简化了应用内购功能的开发流程,并解决了本地测试收据无法验证的问题。 这个库的简洁易用性,以及对不同场景的良好支持,使其成为处理iOS收据的理想选择。


# composer  # 苹果  # 苹果ios  # php  # symfony  # ios  # xcode  # 是一个  # 是由  # 它是  # 这段  # 这就  # 使其  # 可选  # 发送到  # 涉及到  # 我找 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: 北京专业网站制作设计师招聘,北京白云观官方网站?  Microsoft Edge如何解决网页加载问题 Edge浏览器加载问题修复  uc浏览器二维码扫描入口_uc浏览器扫码功能使用地址  Laravel Octane如何提升性能_使用Laravel Octane加速你的应用  详解免费开源的.NET多类型文件解压缩组件SharpZipLib(.NET组件介绍之七)  详解Nginx + Tomcat 反向代理 如何在高效的在一台服务器部署多个站点  Edge浏览器提示“由你的组织管理”怎么解决_去除浏览器托管提示【修复】  Laravel怎么集成Log日志记录_Laravel单文件与每日日志配置及自定义通道【详解】  如何使用 Go 正则表达式精准提取括号内首个纯字母标识符(忽略数字与嵌套)  宙斯浏览器视频悬浮窗怎么开启 边看视频边操作其他应用教程  如何快速搭建虚拟主机网站?新手必看指南  Laravel如何实现全文搜索功能?(Scout和Algolia示例)  详解jQuery中基本的动画方法  新三国志曹操传主线渭水交兵攻略  成都网站制作公司哪家好,四川省职工服务网是做什么用?  常州企业网站制作公司,全国继续教育网怎么登录?  详解免费开源的DotNet二维码操作组件ThoughtWorks.QRCode(.NET组件介绍之四)  Laravel如何配置和使用缓存?(Redis代码示例)  logo在线制作免费网站在线制作好吗,DW网页制作时,如何在网页标题前加上logo?  Android中AutoCompleteTextView自动提示  Win10如何卸载预装Edge扩展_Win10卸载Edge扩展教程【方法】  Linux虚拟化技术教程_KVMQEMU虚拟机安装与调优  网站设计制作书签怎么做,怎样将网页添加到书签/主页书签/桌面?  Laravel如何监控和管理失败的队列任务_Laravel失败任务处理与监控  如何用腾讯建站主机快速创建免费网站?  C#如何调用原生C++ COM对象详解  如何在香港免费服务器上快速搭建网站?  重庆市网站制作公司,重庆招聘网站哪个好?  如何在宝塔面板创建新站点?  Laravel中间件起什么作用_Laravel Middleware请求生命周期与自定义详解  如何利用DOS批处理实现定时关机操作详解  ChatGPT常用指令模板大全 新手快速上手的万能Prompt合集  Laravel怎么进行浏览器测试_Laravel Dusk自动化浏览器测试入门  JS中对数组元素进行增删改移的方法总结  如何在景安云服务器上绑定域名并配置虚拟主机?  如何快速搭建高效WAP手机网站?  HTML5打空格有哪些误区_新手常犯的空格使用错误【技巧】  Laravel怎么解决跨域问题_Laravel配置CORS跨域访问  Edge浏览器怎么启用睡眠标签页_节省电脑内存占用优化技巧  软银砸40亿美元收购DigitalBridge 强化AI资料中心布局  如何将凡科建站内容保存为本地文件?  Laravel队列任务超时怎么办_Laravel Queue Timeout设置详解  Laravel如何实现URL美化Slug功能_Laravel使用eloquent-sluggable生成别名【方法】  微博html5版本怎么弄发超话_超话进入入口及发帖格式要求【教程】  jimdo怎样用html5做选项卡_jimdo选项卡html5实现与切换效果【指南】  如何快速生成高效建站系统源代码?  什么是JavaScript解构赋值_解构赋值有哪些实用技巧  详解Android中Activity的四大启动模式实验简述  BootStrap整体框架之基础布局组件  哪家制作企业网站好,开办像阿里巴巴那样的网络公司和网站要怎么做?