0

0

苹果支付PHP签名怎么生成_苹果支付PHP签名生成方法【教程】

絕刀狂花

絕刀狂花

发布时间:2025-12-23 18:24:08

|

703人浏览过

|

来源于php中文网

原创

必须在Apple IAP验签请求中显式包含password字段(即App Store Connect配置的shared secret),且receipt-data需为原始Base64字符串,不可二次编码或转义;否则将触发status=21004等错误。

苹果支付php签名怎么生成_苹果支付php签名生成方法【教程】

如果您在集成苹果内购(IAP)服务时需要向 Apple 验证服务器提交 receipt-data 并附带签名验证,必须正确构造包含 shared secret 的请求体。以下是生成该签名请求的多种实现方法:

一、使用 password 字段直接构造 JSON 请求体

苹果要求对自动续订订阅类商品进行验签时,必须在请求 payload 中显式传入 password 字段,其值为 App Store Connect 中配置的 shared secret。该字段不可省略,即使验证的是非订阅型商品,只要账户曾创建过自动续订产品,也需携带。

1、从 App Store Connect 后台获取 shared secret:进入“App > 内购项目 > 共享密钥”,复制 32 位十六进制字符串。

2、将 receipt-data 值 Base64 编码后的原始字符串(非 URL 安全编码)与 password 组合成标准 JSON 对象。

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

3、确保 receipt-data 字段值未被二次 Base64 编码或 URL 转义,保持原始 Apple 返回的完整字符串。

4、使用 curl 或 file_get_contents 向对应环境 endpoint 发起 POST 请求,Content-Type 必须设为 application/json。

二、使用 cURL 封装带 password 的验签请求

该方法通过原生 PHP cURL 显式控制请求头与数据格式,避免 JSON 序列化过程中的意外截断或编码错误,适用于生产环境高稳定性要求场景。

1、定义 $receiptData 变量,赋值为客户端传来的原始 receipt-data 字符串(长度通常为 8000+ 字符)。

2、定义 $sharedSecret 变量,赋值为 App Store Connect 获取的 32 字符 shared secret。

3、构建 $postData 数组:array('receipt-data' => $receiptData, 'password' => $sharedSecret)。

4、调用 json_encode($postData, JSON_UNESCAPED_SLASHES | JSON_UNESCAPED_UNICODE) 生成紧凑 JSON 字符串。

5、初始化 cURL 句柄,设置 CURLOPT_URL 为沙盒或生产地址,CURLOPT_POSTFIELDS 为上步 JSON,CURLOPT_HTTPHEADER 为 ['Content-Type: application/json']。

三、封装可复用的验签函数并处理多状态响应

苹果验签接口返回 JSON 包含 status 字段,不同数值代表不同校验结果。签名本身不参与加密运算,但 password 的存在与否直接影响 status=21004 等关键错误是否触发,因此函数需强制校验 password 传入逻辑。

1、声明函数 ifReceiptValid($receipt, $isSandbox = false, $password = ''),其中 $password 参数默认为空但实际调用时必须传入有效值。

Cursor Directory
Cursor Directory

专为Cursor设计的开源资源库、提示词库

下载

2、在函数开头添加判断:若 $password 为空且 $isSandbox 为 false,则抛出 InvalidArgumentException 提示缺失共享密钥

3、根据 $isSandbox 选择 endpoint:沙盒为 https://sandbox.itunes.apple.com/verifyReceipt,生产为 https://buy.itunes.apple.com/verifyReceipt。

4、构造 $postData 时始终包含 'password' 键,即使值为空字符串(防止因键缺失导致 21004)。

5、执行 curl 请求后,对返回内容做 json_decode,检查 status 是否为 0;若为 21004,则确认 $password 与 App Store Connect 中完全一致(区分大小写、无空格、无换行)

四、使用 stream_context_create 替代 cURL 发起请求

在部分受限服务器环境中 cURL 可能被禁用,此时可采用 PHP 原生 stream_context_create + file_get_contents 方式发起 HTTPS POST 请求,同样支持 JSON 数据提交与 header 设置。

1、准备 $options 数组,顶层键为 http,子键包括 method => 'POST', header => "Content-type: application/json\r\n",content => json_encode(...)

2、调用 stream_context_create($options) 创建上下文资源。

3、使用 file_get_contents($endpoint, false, $context) 执行请求,注意捕获 warning 级错误以判断连接失败。

4、对返回结果做 json_decode,提取 status 与 receipt 字段;若 status ≠ 0,则优先比对 password 是否与 App Store Connect 页面中显示的字符逐字相同

五、签名相关字段的校验与调试要点

苹果验签不涉及客户端本地签名算法,但 password 字段的传输完整性等效于“签名凭证”。其有效性依赖于服务端构造时的精确性,任何格式偏差均会导致 21004 错误。

1、检查 $password 是否从 App Store Connect 复制时混入不可见 Unicode 字符(如零宽空格),建议粘贴至十六进制编辑器验证。

2、确认 receipt-data 字符串未被 trim()、urldecode() 或 htmlspecialchars() 等函数意外处理,应保持原始 Base64 字符序列。

3、在沙盒环境测试时,若收到 status=21007,说明请求发往了生产 endpoint,需强制将 $isSandbox 设为 true 并使用 sandbox.itunes.apple.com 地址

4、若连续返回 status=21005,表明苹果服务器临时不可用,应记录时间戳并延迟重试,而非修改 password 或 receipt-data。

相关专题

更多
php文件怎么打开
php文件怎么打开

打开php文件步骤:1、选择文本编辑器;2、在选择的文本编辑器中,创建一个新的文件,并将其保存为.php文件;3、在创建的PHP文件中,编写PHP代码;4、要在本地计算机上运行PHP文件,需要设置一个服务器环境;5、安装服务器环境后,需要将PHP文件放入服务器目录中;6、一旦将PHP文件放入服务器目录中,就可以通过浏览器来运行它。

2549

2023.09.01

php怎么取出数组的前几个元素
php怎么取出数组的前几个元素

取出php数组的前几个元素的方法有使用array_slice()函数、使用array_splice()函数、使用循环遍历、使用array_slice()函数和array_values()函数等。本专题为大家提供php数组相关的文章、下载、课程内容,供大家免费下载体验。

1614

2023.10.11

php反序列化失败怎么办
php反序列化失败怎么办

php反序列化失败的解决办法检查序列化数据。检查类定义、检查错误日志、更新PHP版本和应用安全措施等。本专题为大家提供php反序列化相关的文章、下载、课程内容,供大家免费下载体验。

1504

2023.10.11

php怎么连接mssql数据库
php怎么连接mssql数据库

连接方法:1、通过mssql_系列函数;2、通过sqlsrv_系列函数;3、通过odbc方式连接;4、通过PDO方式;5、通过COM方式连接。想了解php怎么连接mssql数据库的详细内容,可以访问下面的文章。

952

2023.10.23

php连接mssql数据库的方法
php连接mssql数据库的方法

php连接mssql数据库的方法有使用PHP的MSSQL扩展、使用PDO等。想了解更多php连接mssql数据库相关内容,可以阅读本专题下面的文章。

1417

2023.10.23

html怎么上传
html怎么上传

html通过使用HTML表单、JavaScript和PHP上传。更多关于html的问题详细请看本专题下面的文章。php中文网欢迎大家前来学习。

1234

2023.11.03

PHP出现乱码怎么解决
PHP出现乱码怎么解决

PHP出现乱码可以通过修改PHP文件头部的字符编码设置、检查PHP文件的编码格式、检查数据库连接设置和检查HTML页面的字符编码设置来解决。更多关于php乱码的问题详情请看本专题下面的文章。php中文网欢迎大家前来学习。

1446

2023.11.09

php文件怎么在手机上打开
php文件怎么在手机上打开

php文件在手机上打开需要在手机上搭建一个能够运行php的服务器环境,并将php文件上传到服务器上。再在手机上的浏览器中输入服务器的IP地址或域名,加上php文件的路径,即可打开php文件并查看其内容。更多关于php相关问题,详情请看本专题下面的文章。php中文网欢迎大家前来学习。

1306

2023.11.13

C++ 单元测试与代码质量保障
C++ 单元测试与代码质量保障

本专题系统讲解 C++ 在单元测试与代码质量保障方面的实战方法,包括测试驱动开发理念、Google Test/Google Mock 的使用、测试用例设计、边界条件验证、持续集成中的自动化测试流程,以及常见代码质量问题的发现与修复。通过工程化示例,帮助开发者建立 可测试、可维护、高质量的 C++ 项目体系。

10

2026.01.16

热门下载

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

精品课程

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

共137课时 | 8.7万人学习

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

共6课时 | 7.1万人学习

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

共13课时 | 0.9万人学习

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

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