0

0

PHP怎么处理苹果支付状态变更_苹果支付状态变更PHP处理步骤【指南】

看不見的法師

看不見的法師

发布时间:2025-12-23 12:45:09

|

676人浏览过

|

来源于php中文网

原创

苹果支付状态变更需五步处理:一、用php://input解析JSON;二、验证signingCertURL证书及signature;三、用sharedSecret和IV解密AES-GCM加密的data;四、依status更新订单并保证事务原子性;五、5秒内返回空HTTP 200响应。

php怎么处理苹果支付状态变更_苹果支付状态变更php处理步骤【指南】

苹果支付(Apple Pay)完成交易后,服务器会收到状态变更通知,PHP需要正确验证并处理这些通知。以下是处理苹果支付状态变更的具体步骤:

一、接收并解析苹果支付回调请求

苹果支付通过HTTPS POST方式向您的服务器发送状态变更通知,内容为JSON格式的原始数据,需读取原始输入流并解码。

1、使用php://input获取原始POST数据,避免因Content-Type非application/x-www-form-urlencoded导致$_POST为空。

2、调用json_decode(file_get_contents('php://input'), true)将JSON字符串转为关联数组。

立即学习PHP免费学习笔记(深入)”;

3、检查是否成功解码,若返回null则说明JSON格式错误或为空,此时应立即返回HTTP 400状态码

二、验证苹果签名与证书链

苹果在通知中附带signingCertURL、signature、notificationType和data字段,需下载证书、验证签名以确保通知真实来自Apple服务器。

1、从signingCertURL下载证书内容,使用file_get_contents获取PEM格式证书字符串。

2、使用openssl_x509_read()加载证书,并用openssl_x509_parse()提取公钥信息。

3、拼接data字段与notificationType字段(按字典序排序后拼接),使用openssl_verify()验证signature是否匹配该数据与证书公钥。

4、若签名验证失败,必须拒绝该通知并返回HTTP 401状态码

三、解密加密的data字段

苹果将敏感业务数据(如transactionId、status等)使用AES-GCM加密后放入data字段,需使用通知中提供的sharedSecret及IV进行解密。

1、从通知中提取data、version、transactionId、bundleId字段,并确认version为"EC_v1"。

2、从环境配置中读取与App ID绑定的sharedSecret(即App Store Connect中配置的密钥)。

3、对data字段进行Base64解码,分离出nonce(前12字节)、authTag(后16字节)和ciphertext(中间部分)。

一点PPT
一点PPT

一句话生成专业PPT,AI自动排版配图

下载

4、使用openssl_decrypt()配合aes-128-gcm算法、sharedSecret作为key、nonce作为iv进行解密,传入authTag用于完整性校验。

5、解密失败时不得记录任何敏感字段,且必须返回HTTP 400

四、解析解密后的业务数据并更新订单状态

解密后获得标准JSON结构,包含transactionId、originalTransactionId、productId、status、purchaseDate等关键字段,用于匹配本地订单并更新状态。

1、根据transactionId或originalTransactionId查询本地订单记录,优先使用originalTransactionId匹配订阅续订场景

2、校验productId是否与订单预期一致,防止越权篡改商品标识。

3、依据status字段值执行对应操作:状态为0表示购买成功,1表示取消,2表示退款,3表示退款已恢复,5表示订阅过期。

4、对status为0的订单,更新数据库中订单状态为“已支付”,并记录purchaseDate与expiresDate(若存在)。

5、所有状态变更操作必须在数据库事务中完成,确保原子性

五、向苹果服务器返回确认响应

苹果要求在收到通知后5秒内返回HTTP 200响应,且响应体必须为空,否则视为未确认,将在后续重发通知。

1、在完成全部验证与业务处理逻辑后,调用http_response_code(200)设置状态码。

2、清除所有输出缓冲区,使用ob_end_clean()防止意外输出干扰响应。

3、直接调用exit或return终止脚本执行,禁止输出任何字符(包括空格、BOM、换行)

4、记录日志时仅写入文件或远程服务,不得使用echo、print、var_dump等输出函数。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
json数据格式
json数据格式

JSON是一种轻量级的数据交换格式。本专题为大家带来json数据格式相关文章,帮助大家解决问题。

457

2023.08.07

json是什么
json是什么

JSON是一种轻量级的数据交换格式,具有简洁、易读、跨平台和语言的特点,JSON数据是通过键值对的方式进行组织,其中键是字符串,值可以是字符串、数值、布尔值、数组、对象或者null,在Web开发、数据交换和配置文件等方面得到广泛应用。本专题为大家提供json相关的文章、下载、课程内容,供大家免费下载体验。

549

2023.08.23

jquery怎么操作json
jquery怎么操作json

操作的方法有:1、“$.parseJSON(jsonString)”2、“$.getJSON(url, data, success)”;3、“$.each(obj, callback)”;4、“$.ajax()”。更多jquery怎么操作json的详细内容,可以访问本专题下面的文章。

337

2023.10.13

go语言处理json数据方法
go语言处理json数据方法

本专题整合了go语言中处理json数据方法,阅读专题下面的文章了解更多详细内容。

82

2025.09.10

python中print函数的用法
python中print函数的用法

python中print函数的语法是“print(value1, value2, ..., sep=' ', end=' ', file=sys.stdout, flush=False)”。本专题为大家提供print相关的文章、下载、课程内容,供大家免费下载体验。

193

2023.09.27

python print用法与作用
python print用法与作用

本专题整合了python print的用法、作用、函数功能相关内容,阅读专题下面的文章了解更多详细教程。

19

2026.02.03

c语言中null和NULL的区别
c语言中null和NULL的区别

c语言中null和NULL的区别是:null是C语言中的一个宏定义,通常用来表示一个空指针,可以用于初始化指针变量,或者在条件语句中判断指针是否为空;NULL是C语言中的一个预定义常量,通常用来表示一个空值,用于表示一个空的指针、空的指针数组或者空的结构体指针。

254

2023.09.22

java中null的用法
java中null的用法

在Java中,null表示一个引用类型的变量不指向任何对象。可以将null赋值给任何引用类型的变量,包括类、接口、数组、字符串等。想了解更多null的相关内容,可以阅读本专题下面的文章。

1089

2024.03.01

TypeScript类型系统进阶与大型前端项目实践
TypeScript类型系统进阶与大型前端项目实践

本专题围绕 TypeScript 在大型前端项目中的应用展开,深入讲解类型系统设计与工程化开发方法。内容包括泛型与高级类型、类型推断机制、声明文件编写、模块化结构设计以及代码规范管理。通过真实项目案例分析,帮助开发者构建类型安全、结构清晰、易维护的前端工程体系,提高团队协作效率与代码质量。

26

2026.03.13

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PHP课程
PHP课程

共137课时 | 13.4万人学习

JavaScript ES5基础线上课程教学
JavaScript ES5基础线上课程教学

共6课时 | 11.3万人学习

PHP新手语法线上课程教学
PHP新手语法线上课程教学

共13课时 | 1.0万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号