APP实现苹果内购支付IOS内购接入流程步奏

1. 在 App Store Connect 填写 协议、税务和银行业务

2. 在 App Store Connect 添加 沙箱技术测试员(一个假的Apple ID,任意邮箱 + 不低于8位的大小写字母数字组合的密码)

3. 在测试APP的苹果手机 – 设置 – iTunes Store 与 App Store 页面,拉到最底部管理沙盒账户;

4. 在 App Store Connect 点进已经创建好的APP – 功能 – App 内购买项目,增删改查内购商品;

5. 参考 js SDK 文档 接入内购,基本流程如下:

5.1 引导用户购买的时候调用 canMakePayments 检查用户是否支持内购(一般都支持,想简单处理也可以省掉这一步);

5.2 执行 setTransanctionListener 设置交易监听器,在监听回调里面处理所有支付交易流程;

5.3 用户点购买的时候执行 purchase 发起付款,订单号可以放在 applicationUsername 字段,这个会在上一步的监听回调里面原样返回;

6. 重点在于处理 5.2 步 setTransanctionListener 的回调,js 拿到支付凭证(receipt 字段,此时 state 为 1) 后就发到服务器,在服务器上调用苹果提供的接口验证凭证,验证成功就表示苹果已经真的帮你收到钱了,给用户开通相应服务即可;

7. 在调用 finishTransaction 完成交易之前,交易信息会一直存在,所以在确认不再需这个交易信息时(比如 state == 2 交易失败,state == 1 并且已在服务器端确认)应调用 finishTransaction 把他结束掉,以后就不会在 setTransanctionListener 的回调中再次收到这笔交易了;

cancelDownloads 取消下载 APP开发接入苹果内购IOS内购开发教程

用做网页的技术做APP
一门提供标准化的jsbridge-mini.js库,您只需要在页面引用执行JS即可实现各种原生APP、原生PC的功能能力。

==================APP端==================
【APP端】(安卓版&苹果版)目前提供200+原生功能,2000+JS映射接口,用做网站的技术即可实现各种原生APP能力、APP demo地址https://www.yimenapp.com/doc/demo.cshtml下载教程:
♦ JS-SDK 引用方式:
♦ 普通网页 script 方式加载:下载最新版,请在页面上调用 jsBridge 接口之前引用 jsbridge-mini.js 库;
♦ js module 方式引用:npm install ym-jsbridge 具体请参考 npm package
一门APP开发平台通用JS

cancelDownloads 取消下载 APP开发接入苹果内购IOS内购开发教程

请在 setDownloadListener 中接收下载信息

核心代码示例,详情参阅demo

jsBridge.iap.cancelDownloads({
  //下载内容ID组成的数组
  contentIds: [
    "contentId1",
    "contentId2",
    "..."
  ]
});

A标签执行JS示例代码

<a href="javascript:void(0)" onclick="zhixing()">执行</a> 
<!-- 写入一个A标签href值为"javascript:void(0)",定义点击事件onclick;-->
<script src="您的服务器URL/jsbridge-mini.js"></script>
<!-- 在您的服务器引入一门JS地址,请下载jsbridge-mini.js上传您自己的服务器获取链接;-->
<script type="text/javascript">
function zhixing() {


<!--这里可以直接复制JS核心代码到此{}括号内-->
jsBridge.iap.cancelDownloads({
  //下载内容ID组成的数组
  contentIds: [
    "contentId1",
    "contentId2",
    "..."
  ]
});

}
</script>
<!--执行核心代码;
//如果需要进入页面就执行,去掉点击事件即可;-->

按钮执行JS示例代码

<button onclick="zhixing()" >执行</button>
<!-- //写一个按钮,定义点击执行事件; -->
<script src="您的服务器URL/jsbridge-mini.js"></script>
<!-- //在您的服务器引入一门JS地址,请下载jsbridge-mini.js上传您自己的服务器获取链接; -->
<script type="text/javascript">
function zhixing() {


<!--这里可以直接复制JS核心代码到此{}括号内-->
jsBridge.iap.cancelDownloads({
  //下载内容ID组成的数组
  contentIds: [
    "contentId1",
    "contentId2",
    "..."
  ]
});

}
</script>
<!-- //执行核心代码;
//如果需要进入页面就执行,去掉点击事件即可; -->

resumeDownloads 恢复下载 APP开发接入苹果内购IOS内购开发教程

用做网页的技术做APP
一门提供标准化的jsbridge-mini.js库,您只需要在页面引用执行JS即可实现各种原生APP、原生PC的功能能力。

==================APP端==================
【APP端】(安卓版&苹果版)目前提供200+原生功能,2000+JS映射接口,用做网站的技术即可实现各种原生APP能力、APP demo地址https://www.yimenapp.com/doc/demo.cshtml下载教程:
♦ JS-SDK 引用方式:
♦ 普通网页 script 方式加载:下载最新版,请在页面上调用 jsBridge 接口之前引用 jsbridge-mini.js 库;
♦ js module 方式引用:npm install ym-jsbridge 具体请参考 npm package
一门APP开发平台通用JS

resumeDownloads 恢复下载 APP开发接入苹果内购IOS内购开发教程

请在 setDownloadListener 中接收下载信息

核心代码示例,详情参阅demo

jsBridge.iap.resumeDownloads({
  //下载内容ID组成的数组
  contentIds: [
    "contentId1",
    "contentId2",
    "..."
  ]
});

A标签执行JS示例代码

<a href="javascript:void(0)" onclick="zhixing()">执行</a> 
<!-- 写入一个A标签href值为"javascript:void(0)",定义点击事件onclick;-->
<script src="您的服务器URL/jsbridge-mini.js"></script>
<!-- 在您的服务器引入一门JS地址,请下载jsbridge-mini.js上传您自己的服务器获取链接;-->
<script type="text/javascript">
function zhixing() {


<!--这里可以直接复制JS核心代码到此{}括号内-->
jsBridge.iap.resumeDownloads({
  //下载内容ID组成的数组
  contentIds: [
    "contentId1",
    "contentId2",
    "..."
  ]
});

}
</script>
<!--执行核心代码;
//如果需要进入页面就执行,去掉点击事件即可;-->

按钮执行JS示例代码

<button onclick="zhixing()" >执行</button>
<!-- //写一个按钮,定义点击执行事件; -->
<script src="您的服务器URL/jsbridge-mini.js"></script>
<!-- //在您的服务器引入一门JS地址,请下载jsbridge-mini.js上传您自己的服务器获取链接; -->
<script type="text/javascript">
function zhixing() {


<!--这里可以直接复制JS核心代码到此{}括号内-->
jsBridge.iap.resumeDownloads({
  //下载内容ID组成的数组
  contentIds: [
    "contentId1",
    "contentId2",
    "..."
  ]
});

}
</script>
<!-- //执行核心代码;
//如果需要进入页面就执行,去掉点击事件即可; -->

pauseDownloads 暂停下载 APP开发接入苹果内购IOS内购开发教程

用做网页的技术做APP
一门提供标准化的jsbridge-mini.js库,您只需要在页面引用执行JS即可实现各种原生APP、原生PC的功能能力。

==================APP端==================
【APP端】(安卓版&苹果版)目前提供200+原生功能,2000+JS映射接口,用做网站的技术即可实现各种原生APP能力、APP demo地址https://www.yimenapp.com/doc/demo.cshtml下载教程:
♦ JS-SDK 引用方式:
♦ 普通网页 script 方式加载:下载最新版,请在页面上调用 jsBridge 接口之前引用 jsbridge-mini.js 库;
♦ js module 方式引用:npm install ym-jsbridge 具体请参考 npm package
一门APP开发平台通用JS

pauseDownloads 暂停下载 APP开发接入苹果内购IOS内购开发教程

请在 setDownloadListener 中接收下载信息

核心代码示例,详情参阅demo

jsBridge.iap.pauseDownloads({
  //下载内容ID组成的数组
  contentIds: [
    "contentId1",
    "contentId2",
    "..."
  ]
});

A标签执行JS示例代码

<a href="javascript:void(0)" onclick="zhixing()">执行</a> 
<!-- 写入一个A标签href值为"javascript:void(0)",定义点击事件onclick;-->
<script src="您的服务器URL/jsbridge-mini.js"></script>
<!-- 在您的服务器引入一门JS地址,请下载jsbridge-mini.js上传您自己的服务器获取链接;-->
<script type="text/javascript">
function zhixing() {


<!--这里可以直接复制JS核心代码到此{}括号内-->
jsBridge.iap.pauseDownloads({
  //下载内容ID组成的数组
  contentIds: [
    "contentId1",
    "contentId2",
    "..."
  ]
});

}
</script>
<!--执行核心代码;
//如果需要进入页面就执行,去掉点击事件即可;-->

按钮执行JS示例代码

<button onclick="zhixing()" >执行</button>
<!-- //写一个按钮,定义点击执行事件; -->
<script src="您的服务器URL/jsbridge-mini.js"></script>
<!-- //在您的服务器引入一门JS地址,请下载jsbridge-mini.js上传您自己的服务器获取链接; -->
<script type="text/javascript">
function zhixing() {


<!--这里可以直接复制JS核心代码到此{}括号内-->
jsBridge.iap.pauseDownloads({
  //下载内容ID组成的数组
  contentIds: [
    "contentId1",
    "contentId2",
    "..."
  ]
});

}
</script>
<!-- //执行核心代码;
//如果需要进入页面就执行,去掉点击事件即可; -->

startDownloads 开始下载 APP开发实现苹果内购IOS内购开发教程

用做网页的技术做APP
一门提供标准化的jsbridge-mini.js库,您只需要在页面引用执行JS即可实现各种原生APP、原生PC的功能能力。

==================APP端==================
【APP端】(安卓版&苹果版)目前提供200+原生功能,2000+JS映射接口,用做网站的技术即可实现各种原生APP能力、APP demo地址https://www.yimenapp.com/doc/demo.cshtml下载教程:
♦ JS-SDK 引用方式:
♦ 普通网页 script 方式加载:下载最新版,请在页面上调用 jsBridge 接口之前引用 jsbridge-mini.js 库;
♦ js module 方式引用:npm install ym-jsbridge 具体请参考 npm package
一门APP开发平台通用JS

startDownloads 开始下载 APP开发实现苹果内购IOS内购开发教程

请在 setDownloadListener 中接收下载信息

核心代码示例,详情参阅demo

jsBridge.iap.startDownloads({
  //下载内容ID组成的数组
  contentIds: [
    "contentId1",
    "contentId2",
    "..."
  ]
});

A标签执行JS示例代码

<a href="javascript:void(0)" onclick="zhixing()">执行</a> 
<!-- 写入一个A标签href值为"javascript:void(0)",定义点击事件onclick;-->
<script src="您的服务器URL/jsbridge-mini.js"></script>
<!-- 在您的服务器引入一门JS地址,请下载jsbridge-mini.js上传您自己的服务器获取链接;-->
<script type="text/javascript">
function zhixing() {


<!--这里可以直接复制JS核心代码到此{}括号内-->
jsBridge.iap.startDownloads({
  //下载内容ID组成的数组
  contentIds: [
    "contentId1",
    "contentId2",
    "..."
  ]
});

}
</script>
<!--执行核心代码;
//如果需要进入页面就执行,去掉点击事件即可;-->

按钮执行JS示例代码

<button onclick="zhixing()" >执行</button>
<!-- //写一个按钮,定义点击执行事件; -->
<script src="您的服务器URL/jsbridge-mini.js"></script>
<!-- //在您的服务器引入一门JS地址,请下载jsbridge-mini.js上传您自己的服务器获取链接; -->
<script type="text/javascript">
function zhixing() {


<!--这里可以直接复制JS核心代码到此{}括号内-->
jsBridge.iap.startDownloads({
  //下载内容ID组成的数组
  contentIds: [
    "contentId1",
    "contentId2",
    "..."
  ]
});

}
</script>
<!-- //执行核心代码;
//如果需要进入页面就执行,去掉点击事件即可; -->

setDownloadListener 设置下载监听器 APP开发接入苹果内购IOS内购开发教程

用做网页的技术做APP
一门提供标准化的jsbridge-mini.js库,您只需要在页面引用执行JS即可实现各种原生APP、原生PC的功能能力。

==================APP端==================
【APP端】(安卓版&苹果版)目前提供200+原生功能,2000+JS映射接口,用做网站的技术即可实现各种原生APP能力、APP demo地址https://www.yimenapp.com/doc/demo.cshtml下载教程:
♦ JS-SDK 引用方式:
♦ 普通网页 script 方式加载:下载最新版,请在页面上调用 jsBridge 接口之前引用 jsbridge-mini.js 库;
♦ js module 方式引用:npm install ym-jsbridge 具体请参考 npm package
一门APP开发平台通用JS

setDownloadListener 设置下载监听器 APP开发接入苹果内购IOS内购开发教程

• 调用 startDownloads/pauseDownloads/resumeDownloads/cancelDownloads 方法之前应设置本监听器,所有下载状态变更都会通知到此监听器。

• 系统以数组形式将下载信息传递给回调参数 downloads

• 如果多次设置监听器,只有最后一个才会收到通知。

核心代码示例,详情参阅demo

jsBridge.iap.setDownloadListener(function(succ, downloads) {
  if (succ) {
    alert(JSON.stringify(downloads));
  } else {
    alert("操作失败\n" + JSON.stringify(downloads));
  }
});
alert("已设置监听器");

/**
downloads 下载信息数组
[{    
  state:         //下载状态,详见setTransanctionListener的下载状态常量说明,数字类型
  transactionId: //下载内容所属交易id,字符串类型
  contentId:     //下载内容id,字符串类型
  progress:      //下载进度,取值范围0~1,数字类型
  contentLength: //文件内容大小,数字类型
  timeRemaining: //下载剩余时间,-1时表示未知,数字类型
  contentVersion://下载内容的版本,字符串类型
  contentURL:    //下载成功后文件路径,字符串类型
  errorCode:     //下载失败时的错误码,数字类型
  errorMsg:      //下载失败时的错误描述,字符串类型
}]

**/

A标签执行JS示例代码

<a href="javascript:void(0)" onclick="zhixing()">执行</a> 
<!-- 写入一个A标签href值为"javascript:void(0)",定义点击事件onclick;-->
<script src="您的服务器URL/jsbridge-mini.js"></script>
<!-- 在您的服务器引入一门JS地址,请下载jsbridge-mini.js上传您自己的服务器获取链接;-->
<script type="text/javascript">
function zhixing() {


<!--这里可以直接复制JS核心代码到此{}括号内-->
jsBridge.iap.setDownloadListener(function(succ, downloads) {
  if (succ) {
    alert(JSON.stringify(downloads));
  } else {
    alert("操作失败\n" + JSON.stringify(downloads));
  }
});
alert("已设置监听器");

/**
downloads 下载信息数组
[{    
  state:         //下载状态,详见setTransanctionListener的下载状态常量说明,数字类型
  transactionId: //下载内容所属交易id,字符串类型
  contentId:     //下载内容id,字符串类型
  progress:      //下载进度,取值范围0~1,数字类型
  contentLength: //文件内容大小,数字类型
  timeRemaining: //下载剩余时间,-1时表示未知,数字类型
  contentVersion://下载内容的版本,字符串类型
  contentURL:    //下载成功后文件路径,字符串类型
  errorCode:     //下载失败时的错误码,数字类型
  errorMsg:      //下载失败时的错误描述,字符串类型
}]

**/

}
</script>
<!--执行核心代码;
//如果需要进入页面就执行,去掉点击事件即可;-->

按钮执行JS示例代码

<button onclick="zhixing()" >执行</button>
<!-- //写一个按钮,定义点击执行事件; -->
<script src="您的服务器URL/jsbridge-mini.js"></script>
<!-- //在您的服务器引入一门JS地址,请下载jsbridge-mini.js上传您自己的服务器获取链接; -->
<script type="text/javascript">
function zhixing() {


<!--这里可以直接复制JS核心代码到此{}括号内-->
jsBridge.iap.setDownloadListener(function(succ, downloads) {
  if (succ) {
    alert(JSON.stringify(downloads));
  } else {
    alert("操作失败\n" + JSON.stringify(downloads));
  }
});
alert("已设置监听器");

/**
downloads 下载信息数组
[{    
  state:         //下载状态,详见setTransanctionListener的下载状态常量说明,数字类型
  transactionId: //下载内容所属交易id,字符串类型
  contentId:     //下载内容id,字符串类型
  progress:      //下载进度,取值范围0~1,数字类型
  contentLength: //文件内容大小,数字类型
  timeRemaining: //下载剩余时间,-1时表示未知,数字类型
  contentVersion://下载内容的版本,字符串类型
  contentURL:    //下载成功后文件路径,字符串类型
  errorCode:     //下载失败时的错误码,数字类型
  errorMsg:      //下载失败时的错误描述,字符串类型
}]

**/

}
</script>
<!-- //执行核心代码;
//如果需要进入页面就执行,去掉点击事件即可; -->

finishTransaction 完成指定交易 APP开发接入苹果内购IOS内购开发教程

用做网页的技术做APP
一门提供标准化的jsbridge-mini.js库,您只需要在页面引用执行JS即可实现各种原生APP、原生PC的功能能力。

==================APP端==================
【APP端】(安卓版&苹果版)目前提供200+原生功能,2000+JS映射接口,用做网站的技术即可实现各种原生APP能力、APP demo地址https://www.yimenapp.com/doc/demo.cshtml下载教程:
♦ JS-SDK 引用方式:
♦ 普通网页 script 方式加载:下载最新版,请在页面上调用 jsBridge 接口之前引用 jsbridge-mini.js 库;
♦ js module 方式引用:npm install ym-jsbridge 具体请参考 npm package
一门APP开发平台通用JS

finishTransaction 完成指定交易 APP开发接入苹果内购IOS内购开发教程

• 在完成购买并提供给用户相关功能后应该完成此次交易;

• finishTransaction 成功后,此交易将从 UnfinishedTransactions 队列中移除;

• 请在 setTransanctionListener 中接收交易数据;

核心代码示例,详情参阅demo

jsBridge.iap.finishTransaction({
  //交易id
  transactionId: "3A266867-8275-4299-9BEF-FF7A8A207D21"
});

A标签执行JS示例代码

<a href="javascript:void(0)" onclick="zhixing()">执行</a> 
<!-- 写入一个A标签href值为"javascript:void(0)",定义点击事件onclick;-->
<script src="您的服务器URL/jsbridge-mini.js"></script>
<!-- 在您的服务器引入一门JS地址,请下载jsbridge-mini.js上传您自己的服务器获取链接;-->
<script type="text/javascript">
function zhixing() {


<!--这里可以直接复制JS核心代码到此{}括号内-->
jsBridge.iap.finishTransaction({
  //交易id
  transactionId: "3A266867-8275-4299-9BEF-FF7A8A207D21"
});

}
</script>
<!--执行核心代码;
//如果需要进入页面就执行,去掉点击事件即可;-->

按钮执行JS示例代码

<button onclick="zhixing()" >执行</button>
<!-- //写一个按钮,定义点击执行事件; -->
<script src="您的服务器URL/jsbridge-mini.js"></script>
<!-- //在您的服务器引入一门JS地址,请下载jsbridge-mini.js上传您自己的服务器获取链接; -->
<script type="text/javascript">
function zhixing() {


<!--这里可以直接复制JS核心代码到此{}括号内-->
jsBridge.iap.finishTransaction({
  //交易id
  transactionId: "3A266867-8275-4299-9BEF-FF7A8A207D21"
});

}
</script>
<!-- //执行核心代码;
//如果需要进入页面就执行,去掉点击事件即可; -->

restoreTransactions 恢复用户以前购买过的所有商品交易 APP开发实现苹果内购IOS内购开发教程

用做网页的技术做APP
一门提供标准化的jsbridge-mini.js库,您只需要在页面引用执行JS即可实现各种原生APP、原生PC的功能能力。

==================APP端==================
【APP端】(安卓版&苹果版)目前提供200+原生功能,2000+JS映射接口,用做网站的技术即可实现各种原生APP能力、APP demo地址https://www.yimenapp.com/doc/demo.cshtml下载教程:
♦ JS-SDK 引用方式:
♦ 普通网页 script 方式加载:下载最新版,请在页面上调用 jsBridge 接口之前引用 jsbridge-mini.js 库;
♦ js module 方式引用:npm install ym-jsbridge 具体请参考 npm package
一门APP开发平台通用JS

restoreTransactions 恢复用户以前购买过的所有商品交易 APP开发实现苹果内购IOS内购开发教程

请在 setTransanctionListener 中接收交易数据

核心代码示例,详情参阅demo

jsBridge.iap.restoreTransactions();

A标签执行JS示例代码

<a href="javascript:void(0)" onclick="zhixing()">执行</a> 
<!-- 写入一个A标签href值为"javascript:void(0)",定义点击事件onclick;-->
<script src="您的服务器URL/jsbridge-mini.js"></script>
<!-- 在您的服务器引入一门JS地址,请下载jsbridge-mini.js上传您自己的服务器获取链接;-->
<script type="text/javascript">
function zhixing() {


<!--这里可以直接复制JS核心代码到此{}括号内-->
jsBridge.iap.restoreTransactions();

}
</script>
<!--执行核心代码;
//如果需要进入页面就执行,去掉点击事件即可;-->

按钮执行JS示例代码

<button onclick="zhixing()" >执行</button>
<!-- //写一个按钮,定义点击执行事件; -->
<script src="您的服务器URL/jsbridge-mini.js"></script>
<!-- //在您的服务器引入一门JS地址,请下载jsbridge-mini.js上传您自己的服务器获取链接; -->
<script type="text/javascript">
function zhixing() {


<!--这里可以直接复制JS核心代码到此{}括号内-->
jsBridge.iap.restoreTransactions();

}
</script>
<!-- //执行核心代码;
//如果需要进入页面就执行,去掉点击事件即可; -->

purchase 购买产品 APP开发接入苹果内购IOS内购开发教程

用做网页的技术做APP
一门提供标准化的jsbridge-mini.js库,您只需要在页面引用执行JS即可实现各种原生APP、原生PC的功能能力。

==================APP端==================
【APP端】(安卓版&苹果版)目前提供200+原生功能,2000+JS映射接口,用做网站的技术即可实现各种原生APP能力、APP demo地址https://www.yimenapp.com/doc/demo.cshtml下载教程:
♦ JS-SDK 引用方式:
♦ 普通网页 script 方式加载:下载最新版,请在页面上调用 jsBridge 接口之前引用 jsbridge-mini.js 库;
♦ js module 方式引用:npm install ym-jsbridge 具体请参考 npm package
一门APP开发平台通用JS

purchase 购买产品 APP开发接入苹果内购IOS内购开发教程

请在 setTransanctionListener 中接收交易数据

核心代码示例,详情参阅demo

jsBridge.iap.purchase({
  //你在 https://appstoreconnect.apple.com/ 创建的产品ID
  productId : "com.yidiantongqa.app.vip60",
  //可选,购买数量,不小于1的整数,默认1
  quantity  : 1,
  //可选,用户信息,交易回调里面原样返回,默认空
  applicationUsername: "myString"
});

A标签执行JS示例代码

<a href="javascript:void(0)" onclick="zhixing()">执行</a> 
<!-- 写入一个A标签href值为"javascript:void(0)",定义点击事件onclick;-->
<script src="您的服务器URL/jsbridge-mini.js"></script>
<!-- 在您的服务器引入一门JS地址,请下载jsbridge-mini.js上传您自己的服务器获取链接;-->
<script type="text/javascript">
function zhixing() {


<!--这里可以直接复制JS核心代码到此{}括号内-->
jsBridge.iap.purchase({
  //你在 https://appstoreconnect.apple.com/ 创建的产品ID
  productId : "com.yidiantongqa.app.vip60",
  //可选,购买数量,不小于1的整数,默认1
  quantity  : 1,
  //可选,用户信息,交易回调里面原样返回,默认空
  applicationUsername: "myString"
});

}
</script>
<!--执行核心代码;
//如果需要进入页面就执行,去掉点击事件即可;-->

按钮执行JS示例代码

<button onclick="zhixing()" >执行</button>
<!-- //写一个按钮,定义点击执行事件; -->
<script src="您的服务器URL/jsbridge-mini.js"></script>
<!-- //在您的服务器引入一门JS地址,请下载jsbridge-mini.js上传您自己的服务器获取链接; -->
<script type="text/javascript">
function zhixing() {


<!--这里可以直接复制JS核心代码到此{}括号内-->
jsBridge.iap.purchase({
  //你在 https://appstoreconnect.apple.com/ 创建的产品ID
  productId : "com.yidiantongqa.app.vip60",
  //可选,购买数量,不小于1的整数,默认1
  quantity  : 1,
  //可选,用户信息,交易回调里面原样返回,默认空
  applicationUsername: "myString"
});

}
</script>
<!-- //执行核心代码;
//如果需要进入页面就执行,去掉点击事件即可; -->

getUnfinishedTransactions 获取未完成的交易 APP开发接入苹果内购IOS内购开发教程

用做网页的技术做APP
一门提供标准化的jsbridge-mini.js库,您只需要在页面引用执行JS即可实现各种原生APP、原生PC的功能能力。

==================APP端==================
【APP端】(安卓版&苹果版)目前提供200+原生功能,2000+JS映射接口,用做网站的技术即可实现各种原生APP能力、APP demo地址https://www.yimenapp.com/doc/demo.cshtml下载教程:
♦ JS-SDK 引用方式:
♦ 普通网页 script 方式加载:下载最新版,请在页面上调用 jsBridge 接口之前引用 jsbridge-mini.js 库;
♦ js module 方式引用:npm install ym-jsbridge 具体请参考 npm package
一门APP开发平台通用JS

getUnfinishedTransactions 获取未完成的交易 APP开发接入苹果内购IOS内购开发教程

请在 setTransanctionListener 中接收交易数据

核心代码示例,详情参阅demo

jsBridge.iap.getUnfinishedTransactions();

A标签执行JS示例代码

<a href="javascript:void(0)" onclick="zhixing()">执行</a> 
<!-- 写入一个A标签href值为"javascript:void(0)",定义点击事件onclick;-->
<script src="您的服务器URL/jsbridge-mini.js"></script>
<!-- 在您的服务器引入一门JS地址,请下载jsbridge-mini.js上传您自己的服务器获取链接;-->
<script type="text/javascript">
function zhixing() {


<!--这里可以直接复制JS核心代码到此{}括号内-->
jsBridge.iap.getUnfinishedTransactions();

}
</script>
<!--执行核心代码;
//如果需要进入页面就执行,去掉点击事件即可;-->

按钮执行JS示例代码

<button onclick="zhixing()" >执行</button>
<!-- //写一个按钮,定义点击执行事件; -->
<script src="您的服务器URL/jsbridge-mini.js"></script>
<!-- //在您的服务器引入一门JS地址,请下载jsbridge-mini.js上传您自己的服务器获取链接; -->
<script type="text/javascript">
function zhixing() {


<!--这里可以直接复制JS核心代码到此{}括号内-->
jsBridge.iap.getUnfinishedTransactions();

}
</script>
<!-- //执行核心代码;
//如果需要进入页面就执行,去掉点击事件即可; -->

setTransanctionListener 设置交易监听器 APP开发接入苹果内购IOS内购开发教程

用做网页的技术做APP
一门提供标准化的jsbridge-mini.js库,您只需要在页面引用执行JS即可实现各种原生APP、原生PC的功能能力。

==================APP端==================
【APP端】(安卓版&苹果版)目前提供200+原生功能,2000+JS映射接口,用做网站的技术即可实现各种原生APP能力、APP demo地址https://www.yimenapp.com/doc/demo.cshtml下载教程:
♦ JS-SDK 引用方式:
♦ 普通网页 script 方式加载:下载最新版,请在页面上调用 jsBridge 接口之前引用 jsbridge-mini.js 库;
♦ js module 方式引用:npm install ym-jsbridge 具体请参考 npm package
一门APP开发平台通用JS

setTransanctionListener 设置交易监听器 APP开发接入苹果内购IOS内购开发教程

• 调用 getUnfinishedTransactions/purchase/restoreTransactions/finishTransaction 方法之前应设置本监听器,所有交易状态变更都会通知到此监听器。

• 系统以数组形式将交易信息传递给回调参数 transactions

• 如果多次设置监听器,只有最后一个才会收到通知。

核心代码示例,详情参阅demo

jsBridge.iap.setTransanctionListener(function(succ, transactions) {
  if (succ) {
    var json = JSON.stringify(transactions);
    jsBridge.setClipboardText(json);
    //transactions.forEach(function(x){jsBridge.iap.finishTransaction({transactionId: x.transactionId});})
    alert(json);
  } else {
    alert("操作失败\n" + JSON.stringify(transactions));
  }
});
alert("已设置监听器");

/**
transactions 返回交易信息数组
[{
  state:                 //交易状态,详见交易状态常量,数字类型    
  transactionId:         //交易id,字符串类型    
  originalTransactionId: //原始交易id,只在state为恢复购买时有效,字符串类型
  transactionDate:       //交易时间,UNIX 时间戳(秒)
  receipt:               //交易凭证,经过base64编码,用于验证交易是否合法和有效,避免因越狱破解内购后造成损失,只在state为购买成功时有效,字符串类型
  errorCode:             //交易失败时的错误码,数字类型    
  errorMsg:              //交易失败时的说明,字符串类型    
  payment:               //商品购买信息
  {
    productId:           //商品ID,字符串类型
    quantity:            //购买数量,数字类型
    applicationUsername: //用户信息,字符串类型
  },
  downloads:             //有下载内容时的下载信息列表
  [{    
    state:               //下载状态,详见下载状态常量,数字类型
    transactionId:       //下载内容所属交易id,字符串类型
    contentId:           //下载内容id,字符串类型
    progress:            //下载进度,取值范围0~1,数字类型
    contentLength:       //文件内容大小,数字类型
    timeRemaining:       //下载剩余时间,-1时表示未知,数字类型
    contentVersion:      //下载内容的版本,字符串类型
    contentURL:          //下载成功后文件路径,字符串类型
    errorCode:           //下载失败时的错误码,数字类型
    errorMsg:            //下载失败时的错误描述,字符串类型
  }]
}]

state(transaction) 交易状态常量说明
0: 已加入交易队列(Transaction is being added to the server queue.)
1: 交易完成(Transaction is in queue, user has been charged.  Client should complete the transaction.)
2: 交易失败(Transaction was cancelled or failed before being added to the server queue.)
3: 恢复购买(Transaction was restored from user's purchase history.  Client should complete the transaction.)
4: 交易等待被确认(The transaction is in the queue, but its final status is pending external action.)
    
state(download) 下载状态常量说明
0: 等待下载(Download is inactive, waiting to be downloaded)
1: 正在下载(Download is actively downloading)
2: 暂停下载(Download was paused by the user)
3: 下载完成(Download is finished, content is available)
4: 下载失败(Download failed)
5: 取消下载(Download was cancelled)

**/

A标签执行JS示例代码

<a href="javascript:void(0)" onclick="zhixing()">执行</a> 
<!-- 写入一个A标签href值为"javascript:void(0)",定义点击事件onclick;-->
<script src="您的服务器URL/jsbridge-mini.js"></script>
<!-- 在您的服务器引入一门JS地址,请下载jsbridge-mini.js上传您自己的服务器获取链接;-->
<script type="text/javascript">
function zhixing() {


<!--这里可以直接复制JS核心代码到此{}括号内-->
jsBridge.iap.setTransanctionListener(function(succ, transactions) {
  if (succ) {
    var json = JSON.stringify(transactions);
    jsBridge.setClipboardText(json);
    //transactions.forEach(function(x){jsBridge.iap.finishTransaction({transactionId: x.transactionId});})
    alert(json);
  } else {
    alert("操作失败\n" + JSON.stringify(transactions));
  }
});
alert("已设置监听器");

/**
transactions 返回交易信息数组
[{
  state:                 //交易状态,详见交易状态常量,数字类型    
  transactionId:         //交易id,字符串类型    
  originalTransactionId: //原始交易id,只在state为恢复购买时有效,字符串类型
  transactionDate:       //交易时间,UNIX 时间戳(秒)
  receipt:               //交易凭证,经过base64编码,用于验证交易是否合法和有效,避免因越狱破解内购后造成损失,只在state为购买成功时有效,字符串类型
  errorCode:             //交易失败时的错误码,数字类型    
  errorMsg:              //交易失败时的说明,字符串类型    
  payment:               //商品购买信息
  {
    productId:           //商品ID,字符串类型
    quantity:            //购买数量,数字类型
    applicationUsername: //用户信息,字符串类型
  },
  downloads:             //有下载内容时的下载信息列表
  [{    
    state:               //下载状态,详见下载状态常量,数字类型
    transactionId:       //下载内容所属交易id,字符串类型
    contentId:           //下载内容id,字符串类型
    progress:            //下载进度,取值范围0~1,数字类型
    contentLength:       //文件内容大小,数字类型
    timeRemaining:       //下载剩余时间,-1时表示未知,数字类型
    contentVersion:      //下载内容的版本,字符串类型
    contentURL:          //下载成功后文件路径,字符串类型
    errorCode:           //下载失败时的错误码,数字类型
    errorMsg:            //下载失败时的错误描述,字符串类型
  }]
}]

state(transaction) 交易状态常量说明
0: 已加入交易队列(Transaction is being added to the server queue.)
1: 交易完成(Transaction is in queue, user has been charged.  Client should complete the transaction.)
2: 交易失败(Transaction was cancelled or failed before being added to the server queue.)
3: 恢复购买(Transaction was restored from user's purchase history.  Client should complete the transaction.)
4: 交易等待被确认(The transaction is in the queue, but its final status is pending external action.)
    
state(download) 下载状态常量说明
0: 等待下载(Download is inactive, waiting to be downloaded)
1: 正在下载(Download is actively downloading)
2: 暂停下载(Download was paused by the user)
3: 下载完成(Download is finished, content is available)
4: 下载失败(Download failed)
5: 取消下载(Download was cancelled)

**/

}
</script>
<!--执行核心代码;
//如果需要进入页面就执行,去掉点击事件即可;-->

按钮执行JS示例代码

<button onclick="zhixing()" >执行</button>
<!-- //写一个按钮,定义点击执行事件; -->
<script src="您的服务器URL/jsbridge-mini.js"></script>
<!-- //在您的服务器引入一门JS地址,请下载jsbridge-mini.js上传您自己的服务器获取链接; -->
<script type="text/javascript">
function zhixing() {


<!--这里可以直接复制JS核心代码到此{}括号内-->
jsBridge.iap.setTransanctionListener(function(succ, transactions) {
  if (succ) {
    var json = JSON.stringify(transactions);
    jsBridge.setClipboardText(json);
    //transactions.forEach(function(x){jsBridge.iap.finishTransaction({transactionId: x.transactionId});})
    alert(json);
  } else {
    alert("操作失败\n" + JSON.stringify(transactions));
  }
});
alert("已设置监听器");

/**
transactions 返回交易信息数组
[{
  state:                 //交易状态,详见交易状态常量,数字类型    
  transactionId:         //交易id,字符串类型    
  originalTransactionId: //原始交易id,只在state为恢复购买时有效,字符串类型
  transactionDate:       //交易时间,UNIX 时间戳(秒)
  receipt:               //交易凭证,经过base64编码,用于验证交易是否合法和有效,避免因越狱破解内购后造成损失,只在state为购买成功时有效,字符串类型
  errorCode:             //交易失败时的错误码,数字类型    
  errorMsg:              //交易失败时的说明,字符串类型    
  payment:               //商品购买信息
  {
    productId:           //商品ID,字符串类型
    quantity:            //购买数量,数字类型
    applicationUsername: //用户信息,字符串类型
  },
  downloads:             //有下载内容时的下载信息列表
  [{    
    state:               //下载状态,详见下载状态常量,数字类型
    transactionId:       //下载内容所属交易id,字符串类型
    contentId:           //下载内容id,字符串类型
    progress:            //下载进度,取值范围0~1,数字类型
    contentLength:       //文件内容大小,数字类型
    timeRemaining:       //下载剩余时间,-1时表示未知,数字类型
    contentVersion:      //下载内容的版本,字符串类型
    contentURL:          //下载成功后文件路径,字符串类型
    errorCode:           //下载失败时的错误码,数字类型
    errorMsg:            //下载失败时的错误描述,字符串类型
  }]
}]

state(transaction) 交易状态常量说明
0: 已加入交易队列(Transaction is being added to the server queue.)
1: 交易完成(Transaction is in queue, user has been charged.  Client should complete the transaction.)
2: 交易失败(Transaction was cancelled or failed before being added to the server queue.)
3: 恢复购买(Transaction was restored from user's purchase history.  Client should complete the transaction.)
4: 交易等待被确认(The transaction is in the queue, but its final status is pending external action.)
    
state(download) 下载状态常量说明
0: 等待下载(Download is inactive, waiting to be downloaded)
1: 正在下载(Download is actively downloading)
2: 暂停下载(Download was paused by the user)
3: 下载完成(Download is finished, content is available)
4: 下载失败(Download failed)
5: 取消下载(Download was cancelled)

**/

}
</script>
<!-- //执行核心代码;
//如果需要进入页面就执行,去掉点击事件即可; -->

getProducts 获取产品列表 APP开发接入苹果内购IOS内购开发

用做网页的技术做APP
一门提供标准化的jsbridge-mini.js库,您只需要在页面引用执行JS即可实现各种原生APP、原生PC的功能能力。

==================APP端==================
【APP端】(安卓版&苹果版)目前提供200+原生功能,2000+JS映射接口,用做网站的技术即可实现各种原生APP能力、APP demo地址https://www.yimenapp.com/doc/demo.cshtml下载教程:
♦ JS-SDK 引用方式:
♦ 普通网页 script 方式加载:下载最新版,请在页面上调用 jsBridge 接口之前引用 jsbridge-mini.js 库;
♦ js module 方式引用:npm install ym-jsbridge 具体请参考 npm package
一门APP开发平台通用JS

getProducts 获取产品列表 APP开发接入苹果内购IOS内购开发

核心代码示例,详情参阅demo

jsBridge.iap.getProducts({
  //你在 https://appstoreconnect.apple.com/ 创建的产品ID数组
  productIds: [
    "com.yidiantongqa.app.vip30",
    "com.yidiantongqa.app.vip60",
    "com.yidiantongqa.app.vip360"
  ]
}, function(succ, products) {
  if (succ) {
    alert(JSON.stringify(products));
  } else {
    alert("操作失败\n" + JSON.stringify(products));
  }
});

/**
products 返回产品信息
{   
  invalidProductIds:[]      //无效的产品ID,如果你提供了无效的产品ID,会在这里返回,数组类型
  products:                 //有效的产品信息,数组类型
  [{
    productId:              //产品id,字符串类型
    title:                  //产品标题,字符串类型
    description:            //产品描述,字符串类型
    price:                  //产品价格,数字类型
    formattedPrice:         //产品格式化后的价格,如¥6.00,字符串类型
    downloadable:           //是否有下载内容,布尔类型
    downloadContentLengths: //下载内容长度,数字组成的数组
    downloadContentVersion: //下载内容的版本,字符串类型
  }]
}

**/

A标签执行JS示例代码

<a href="javascript:void(0)" onclick="zhixing()">执行</a> 
<!-- 写入一个A标签href值为"javascript:void(0)",定义点击事件onclick;-->
<script src="您的服务器URL/jsbridge-mini.js"></script>
<!-- 在您的服务器引入一门JS地址,请下载jsbridge-mini.js上传您自己的服务器获取链接;-->
<script type="text/javascript">
function zhixing() {


<!--这里可以直接复制JS核心代码到此{}括号内-->
jsBridge.iap.getProducts({
  //你在 https://appstoreconnect.apple.com/ 创建的产品ID数组
  productIds: [
    "com.yidiantongqa.app.vip30",
    "com.yidiantongqa.app.vip60",
    "com.yidiantongqa.app.vip360"
  ]
}, function(succ, products) {
  if (succ) {
    alert(JSON.stringify(products));
  } else {
    alert("操作失败\n" + JSON.stringify(products));
  }
});

/**
products 返回产品信息
{   
  invalidProductIds:[]      //无效的产品ID,如果你提供了无效的产品ID,会在这里返回,数组类型
  products:                 //有效的产品信息,数组类型
  [{
    productId:              //产品id,字符串类型
    title:                  //产品标题,字符串类型
    description:            //产品描述,字符串类型
    price:                  //产品价格,数字类型
    formattedPrice:         //产品格式化后的价格,如¥6.00,字符串类型
    downloadable:           //是否有下载内容,布尔类型
    downloadContentLengths: //下载内容长度,数字组成的数组
    downloadContentVersion: //下载内容的版本,字符串类型
  }]
}

**/
}
</script>
<!--执行核心代码;
//如果需要进入页面就执行,去掉点击事件即可;-->

按钮执行JS示例代码

<button onclick="zhixing()" >执行</button>
<!-- //写一个按钮,定义点击执行事件; -->
<script src="您的服务器URL/jsbridge-mini.js"></script>
<!-- //在您的服务器引入一门JS地址,请下载jsbridge-mini.js上传您自己的服务器获取链接; -->
<script type="text/javascript">
function zhixing() {


<!--这里可以直接复制JS核心代码到此{}括号内-->
jsBridge.iap.getProducts({
  //你在 https://appstoreconnect.apple.com/ 创建的产品ID数组
  productIds: [
    "com.yidiantongqa.app.vip30",
    "com.yidiantongqa.app.vip60",
    "com.yidiantongqa.app.vip360"
  ]
}, function(succ, products) {
  if (succ) {
    alert(JSON.stringify(products));
  } else {
    alert("操作失败\n" + JSON.stringify(products));
  }
});

/**
products 返回产品信息
{   
  invalidProductIds:[]      //无效的产品ID,如果你提供了无效的产品ID,会在这里返回,数组类型
  products:                 //有效的产品信息,数组类型
  [{
    productId:              //产品id,字符串类型
    title:                  //产品标题,字符串类型
    description:            //产品描述,字符串类型
    price:                  //产品价格,数字类型
    formattedPrice:         //产品格式化后的价格,如¥6.00,字符串类型
    downloadable:           //是否有下载内容,布尔类型
    downloadContentLengths: //下载内容长度,数字组成的数组
    downloadContentVersion: //下载内容的版本,字符串类型
  }]
}

**/

}
</script>
<!-- //执行核心代码;
//如果需要进入页面就执行,去掉点击事件即可; -->

canMakePayments 检查当前设备是否支持内购 APP开发接入苹果内购教程

♦ 苹果官方文档 https://developer.apple.com/documentation/appstorereceipts/verifyreceipt

♦ 沙盒凭证验证接口 https://sandbox.itunes.apple.com/verifyReceipt

♦ 生产环境凭证验证接口 https://buy.itunes.apple.com/verifyReceipt

♦ 注意,APP上架审核时苹果审核员用的是沙盒账户;

♦ 识别沙盒环境下收据的方法有两种:
1.根据凭证验证返回的字段 environment = sandbox。
2.根据凭证验证返回的状态码,如果 status = 21007,则表示当前的收据为沙盒环境下凭证;

♦ 构造JSON { “receipt-data” : “(receipt 支付凭证)” } POST 到苹果的验证接口,处理返回结果即可。

用做网页的技术做APP
一门提供标准化的jsbridge-mini.js库,您只需要在页面引用执行JS即可实现各种原生APP、原生PC的功能能力。

==================APP端==================
【APP端】(安卓版&苹果版)目前提供200+原生功能,2000+JS映射接口,用做网站的技术即可实现各种原生APP能力、APP demo地址https://www.yimenapp.com/doc/demo.cshtml下载教程:
♦ JS-SDK 引用方式:
♦ 普通网页 script 方式加载:下载最新版,请在页面上调用 jsBridge 接口之前引用 jsbridge-mini.js 库;
♦ js module 方式引用:npm install ym-jsbridge 具体请参考 npm package
一门APP开发平台通用JS

canMakePayments 检查当前设备是否支持内购 APP开发接入苹果内购教程

可能由于家长控制等原因,当前设备不支持APP内购买,在发起内购前可以先判断是否支持。

核心代码示例,详情参阅demo

jsBridge.iap.canMakePayments(function(yes) {
  alert(yes ? "支持内购" : "不支持内购");
});

A标签执行JS示例代码

<a href="javascript:void(0)" onclick="zhixing()">执行</a> 
<!-- 写入一个A标签href值为"javascript:void(0)",定义点击事件onclick;-->
<script src="您的服务器URL/jsbridge-mini.js"></script>
<!-- 在您的服务器引入一门JS地址,请下载jsbridge-mini.js上传您自己的服务器获取链接;-->
<script type="text/javascript">
function zhixing() {


<!--这里可以直接复制JS核心代码到此{}括号内-->
jsBridge.iap.canMakePayments(function(yes) {
  alert(yes ? "支持内购" : "不支持内购");
});

}
</script>
<!--执行核心代码;
//如果需要进入页面就执行,去掉点击事件即可;-->

按钮执行JS示例代码

<button onclick="zhixing()" >执行</button>
<!-- //写一个按钮,定义点击执行事件; -->
<script src="您的服务器URL/jsbridge-mini.js"></script>
<!-- //在您的服务器引入一门JS地址,请下载jsbridge-mini.js上传您自己的服务器获取链接; -->
<script type="text/javascript">
function zhixing() {


<!--这里可以直接复制JS核心代码到此{}括号内-->
jsBridge.iap.canMakePayments(function(yes) {
  alert(yes ? "支持内购" : "不支持内购");
});

}
</script>
<!-- //执行核心代码;
//如果需要进入页面就执行,去掉点击事件即可; -->

苹果的售后真的有传说中的那么好吗?

前几个月AirPods pro刚好坏了,过了保修期快一年了,但是在苹果售后中心免费换了一个新的。

我这边感觉苹果的售后还是很不错的,可以通过电话联系苹果客服,也可以在手机的支持软件上联系客服。

电话联系比较常规,虽然也需要不停地按数字按钮跳转,但是整体的指引流程是比较明确的,可以轻松找到自己想要的人工服务,人工的服务态度非常好,说话的语气很温和,会疯狂的帮你寻找解决办法,如果实在无法解决,会帮你查找最近的售后点,全程下来等待的时间都会给你播放音乐。

像这一次我的AirPods pro坏了,抱着花钱维修的目的去联系售后,结果人工在一系列的问题以后告知我,我的AirPods pro符合某个召回计划,可以免费换新,随后帮我预约了离我最近的苹果售后点。

不仅仅是电话客服做得好,去到苹果的售后点依旧服务态度非常好,我去的是广州天环广场的售后点,店员先是为我递了一杯水,然后告知我需要稍等一下,然后把我带到了一个装有iPad和手机的桌子前,告诉我可以在这里玩一会游戏或者看一会视频,如果不想呆在这里的话,还可以去底下参加苹果之家活动,具体就是教你如何使用iPad的一个分享会~

等了差不多10分钟,售后的小哥就来联系我了,询问了我的AirPods pro序列号,然后就将我的整个AirPods pro拿走了,其实我就两只耳机坏了,充电盒没问题 ,但是还是整个换新了,并且告知了我这一次换新是完全免费的,来回的快递费都不用出,要我保留好相关凭证就行。

补充一下,耳机是人为进水,原则上是不参与保修的,但是苹果还是给我保修了~

后面还有一点小插曲……

因为耳机维修需要寄到上海检测,刚好就赶上了疫情,上海的快递也封了,我的耳机修好后滞留在了上海,滞留了差不多一个星期,苹果也有客服给我打电话告知目前的情况,后面还给我升级了专员处理这件事,每一段时间就回来告知我耳机维修的最新情况,虽然快递还是寄不出来,但是真的能够感受到苹果很用心。

还有就是一般苹果产品寄出使用的都是顺丰快递,不过那段时间顺丰收到疫情影响配送时效可能比较慢,或者说是还没有恢复正常运营,所以苹果更换了一个快递商,具体什么名字我忘记了,但是配送速度还是很快的,两天就到了~

拿到手的产品完全就是和全新的一样,而且还有3个月的保修时间

所以关于我这一次AirPods pro的维修体验来说让我觉得真的非常舒服,苹果的工作人员全程都是想着如何帮我解决问题,全程下来没有花费一分钱,就得到了一整套全新的AirPods pro,所以我对apple的售后还是比较肯定的。

除此之外,iPhone上面有一款软件叫作“支持”,也挺实用的。

无论是硬件坏了还是软件上遇到什么问题,都可以去问里面的客服,排队时间短,也不用输入烦人的号码,可以直接可视化的寻找到自己需要的客服~

3步获取苹果设备(手机/平板)UDID值

1.打开获取链接,安装获取描述文件

https://yizhanapp.com/udidpc.html

在平板或手机里面使用safari浏览器打开

设备相机直接扫码

也可以设备相机直接扫码,使用safari浏览器打开

设备相机直接扫码

打开之后,点击页面获取UDID

点击获取UDID

点击之后会弹出安装描述文件,点击允许

点击允许

点击允许之后,页面提示去设备“设置”里面安装

2.手机或平板设置里面,点击【已下载描述文件】

设置选项点击已下载描述文件

之后点击安装描述文件

安装获取UDID描述文件

点击安装之后没需要输入设备开机密码,请放心输入授权

点击安装

输入密码

输入密码安装描述文件

3.安装完成之后,页面会自动跳转

获取UDID,直接复制

AppStore上架推送证书制作教程 Apple Push Services 推送证书制作教程IOS推送证书制作P12

苹果APP开发好之后上架appstore我们都需要配置好推送证书,以便给APP发送推送消息,这会对后期的运营起到非常重要的助力作用。

那么怎么来制作苹果上架版本的推送证书呢?

为了方便开发者制作IOS推送证书,一门推出了一键证书工具;

登录一门App开发者后台,在开发者中心找到【苹果IOS证书工具】

图:ios推送证书制作

在IOS证书工具里面添加我们的苹果开发者账号,之后点击【进入管理】

图:IOS推送证书制作

点击之后会进入到证书制作系统

在弹出的操作界面,直接点击【新增证书】

图:IOS推送证书制作教程

点击右下角【新增证书】

图:IOS推送证书制作教程

核心操作:

1.选择推送证书类型,选择APPstore上架推送证书;

2.选择需要绑定的苹果包名,即为哪一个APP做上架推送证书

点击之后,系统会自动制作推送证书,耐心等待几十秒,之后会自动跳转到列表

图:苹果上架推送证书制作教程

这样我们就完成了对应包名的推送证书制作,我们可以直接点击列表进行下载

图:IOS上架推送证书制作教程

直接点击下载按钮,即可将P12的推送证书下载到本地电脑

下载下来是一个ZIP压缩包,我们直接解压,即可获得P12的推送证书

图:IOS推送证书制作教程

如图,我们就获得了.p12结尾的推送证书,推送证书密码请查阅readme.txt

以上就是苹果推送证书制作的教程,您可以通过一门提供的苹果IOS证书工具快捷的一键在线制作上架appstore的推送证书。