打造一站式应用内支付体验,助力开发者商业增长

news/2024/10/8 16:33:47/文章来源:https://www.cnblogs.com/HarmonyOSSDK/p/18451910

随着移动互联网的发展,应用内支付已成为数字经济的重要组成部分。用户越来越追求便捷的支付体验,应用内支付服务提供的购买和订阅等能力满足了用户快速、无缝的支付需求,方便用户一站式完成交易,帮助开发者实现收入多元化。

HarmonyOS SDK应用内支付服务(IAP Kit)为用户精心打造了一种流畅且高效的应用内支付体验,同时为开发者提供了便捷快速的接入指南。开发者能够将更多的精力投入到提升应用核心业务的质量和创新上,进而促进商业价值的实现和增长。

通过集成应用内支付服务所提供的系统级API,开发者可以迅速部署一个功能完备的支付平台,无缝地实现应用内购买功能。用户可以在应用内轻松购买一系列虚拟商品,种类丰富,包括但不限于一次性使用的消耗品、长期使用的非消耗品,以及提供持续价值的自动续期订阅服务等等。本文重点带开发者了解如何接入购买消耗型/非消耗型商品。

image

场景介绍

通过应用内支付服务,用户可以在应用内购买各种类型的虚拟商品,包括消耗型商品、非消耗型商品和自动续期订阅商品。

•消耗型商品:使用一次后即消耗掉,随使用减少,需要再次购买的商品。例:游戏货币,游戏道具等。

•非消耗型商品:一次性购买,永久拥有,无需消耗。例:游戏中额外的游戏关卡、应用中无时限的高级会员等。

•自动续期订阅商品:用户购买后在一段时间内允许访问增值功能或内容,周期结束后可以选择自动续期购买下一期的服务。例:视频连续包月会员。

购买消耗型/非消耗型商品接入流程

在接入消耗型/非消耗型商品购买能力前,需在华为AppGallery Connect网站配置商品,录入商品ID和商品价格等信息。用户在开发者应用内发起购买时,应用需要调用createPurchase接口来拉起IAP Kit收银台,收银台会展示商品名称、商品价格等信息,用户可在收银台完成商品购买。

image

开发步骤

1.判断当前登录的华为账号所在的服务地是否支持应用内支付。

在使用应用内支付之前,应用需要向IAP Kit发送queryEnvironmentStatus请求,以此判断用户当前登录的华为账号所在的服务地是否在IAP Kit支持结算的国家/地区中。

import { iap } from '@kit.IAPKit';
import { common } from '@kit.AbilityKit';
import { BusinessError } from '@kit.BasicServicesKit';queryEnvironmentStatus() {const context: common.UIAbilityContext = getContext(this) as common.UIAbilityContext;iap.queryEnvironmentStatus(context).then(() => {// 请求成功console.info('Succeeded in querying environment status.');}).catch((err: BusinessError) => {// 请求失败console.error(`Failed to query environment status. Code is ${err.code}, message is ${err.message}`);});
}
}

2.查询商品信息

通过queryProducts来获取在AppGallery Connect上配置的商品信息。发起请求时,需在请求参数QueryProductsParameter中携带相关的商品ID,并根据实际配置指定其productType。

当接口请求成功时,IAP Kit将返回商品信息Product的列表。应用可以使用Product包含的商品价格、名称和描述等信息,向用户展示可供购买的商品列表。

import { iap } from '@kit.IAPKit';
import { BusinessError } from '@kit.BasicServicesKit';queryProducts() {const queryProductParam: iap.QueryProductsParameter = {// iap.ProductType.CONSUMABLE:消耗型商品;// iap.ProductType.NONCONSUMABLE:非消耗型商品;productType: iap.ProductType.CONSUMABLE,// 查询的商品必须是开发者在AppGallery Connect网站配置的商品productIds: ['ohos_consume_001']};const context: common.UIAbilityContext = getContext(this) as common.UIAbilityContext;iap.queryProducts(context, queryProductParam).then((result) => {// 请求成功console.info('Succeeded in querying products.');// 展示商品信息// ...}).catch((err: BusinessError) => {// 请求失败console.error(`Failed to query products. Code is ${err.code}, message is ${err.message}`);});
}

3.发起购买

用户发起购买时,应用可通过向IAP Kit发送createPurchase请求来拉起IAP Kit收银台。发起请求时,需在请求参数PurchaseParameter中携带此前已在华为AppGallery Connect网站上配置并生效的商品ID,并根据实际配置指定其productType。

当用户购买成功时,应用将接收到一个CreatePurchaseResult对象,其purchaseData字段包括了此次购买的结果信息。可参见对返回结果验签对purchaseData.jwsPurchaseOrder进行解码验签,验证成功可得到PurchaseOrderPayload的JSON字符串。

当用户购买失败时,需要针对code为iap.IAPErrorCode.PRODUCT_OWNED和iap.IAPErrorCode.SYSTEM_ERROR的场景,检查是否需要补发货,确保权益发放,具体请参见权益发放。

import { iap } from '@kit.IAPKit';
import { BusinessError } from '@kit.BasicServicesKit';
// JWTUtil为自定义类,可参见Sample Code工程。
import { JWTUtil } from '../commom/JWTUtil';createPurchase() {const createPurchaseParam: iap.PurchaseParameter = {// 购买的商品必须是开发者在AppGallery Connect网站配置的商品productId: 'ohos_consume_001',// iap.ProductType.CONSUMABLE:消耗型商品;// iap.ProductType.NONCONSUMABLE:非消耗型商品;productType: iap.ProductType.CONSUMABLE}const context: common.UIAbilityContext = getContext(this) as common.UIAbilityContext;iap.createPurchase(context, createPurchaseParam).then(async (result) => {console.info('Succeeded in creating purchase.');const jwsPurchaseOrder: string = JSON.parse(result.purchaseData).jwsPurchaseOrder;const purchaseStr = JWTUtil.decodeJwtObj(jwsPurchaseOrder);// 需自定义PurchaseOrderPayload类,包含的信息请参见PurchaseOrderPayloadconst purchaseOrderPayload = JSON.parse(purchaseStr) as PurchaseOrderPayload;// 处理发货// ...// 发货成功后向IAP Kit发送finishPurchase请求,确认发货,完成购买// finishPurchase请求的参数来源于purchaseOrderPayload// ...}).catch((err: BusinessError) => {// 请求失败console.error(`Failed to create purchase. Code is ${err.code}, message is ${err.message}`);if (err.code === iap.IAPErrorCode.PRODUCT_OWNED || err.code === iap.IAPErrorCode.SYSTEM_ERROR) {// 参见权益发放检查是否需要补发货,确保权益发放// ...}})
}

4.完成购买

对PurchaseData.jwsPurchaseOrder解码验签成功后,如果PurchaseOrderPayload.purchaseOrderRevocationReasonCode为空,则代表购买成功,即可发放相关权益。如果开发者同时接入了服务端关键事件通知,为了避免重复发货,建议先检查此笔订单是否已发货,未发货再发放相关权益。发货成功后记录PurchaseOrderPayload等信息,用于后续检查是否已发货。

发货成功后,应用需要发送finishPurchase请求确认发货,以此通知IAP服务器更新商品的发货状态,完成购买流程。发送finishPurchase请求时,需在请求参数FinishPurchaseParameter中携带PurchaseOrderPayload中的productType、purchaseToken、purchaseOrderId。请求成功后,IAP服务器会将相应商品标记为已发货。

对于消耗型商品,应用成功执行finishPurchase之后,IAP服务器会将相应商品重新设置为可购买状态,用户即可再次购买该商品。

import { iap } from '@kit.IAPKit';
import { BusinessError } from '@kit.BasicServicesKit';/*** 确认发货,完成购买** @param purchaseOrder 购买数据,来源于购买请求*/
finishPurchase(purchaseOrder: PurchaseOrderPayload) {const finishPurchaseParam: iap.FinishPurchaseParameter = {productType: purchaseOrder.productType,purchaseToken: purchaseOrder.purchaseToken,purchaseOrderId: purchaseOrder.purchaseOrderId};const context: common.UIAbilityContext = getContext(this) as common.UIAbilityContext;iap.finishPurchase(context, finishPurchaseParam).then((result) => {// 请求成功console.info('Succeeded in finishing purchase.');}).catch((err: BusinessError) => {// 请求失败console.error(`Failed to finish purchase. Code is ${err.code}, message is ${err.message}`);});
}

了解更多详情>>

访问应用内支付服务联盟官网

获取接入购买消耗型/非消耗型商品开发指导文档

获取权益发放开发指导文档

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/810029.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

使用GRUB Multiboot2引导自制操作系统

使用GRUB Multiboot2引导自制操作系统 前言 之前花了一周时间,从头学习了传统 BIOS 的启动流程。惊讶于背后丰富的技术细节的同时,也感叹 x86 架构那厚重的历史包袱。毕竟,谁能想到,一个现代 CPU 竟然需要通过操作“键盘控制器寄存器”来启用一条地址线呢。 最终,出于兼容…

中电金信:源启数据建模平台:建模效率和管理精细度进一步提升

​源启数据建模平台是源启数据资产平台面向数据仓库等大型数据模型构建专门打造的模型设计工具。它以需求牵引模型动态演进,持续变更模型适应业务变化,并以Web和图形化方式,提供正向、逆向建模能力,高效复用模型资产和构建大型数据模型。同时,秉承“建模即治理”的思想,在…

是用python脚本清理reids连接

背景:测试环境的redis不知道咋回事突然无法连接,服务器登录查了一下发现连接数用完了。研发说雨女无瓜,测试环境删了没事,正事要紧赶紧恢复。得嘞!> info clients # Clients connected_clients:9997 # 连接中的数量 client_recent_max_input_buffer:54366 client_rece…

在Cucumber中应用 PicoContainer容器实现组件的实例化

通过 PicoContainer 这个轻量级的DI(Dependency Injection)组件容器进行组件的实例化, 相关介绍参考:http://picocontainer.com/introduction.html step1:定义一个ScenarioContext类 step2:添加jar依赖 implementation io.cucumber:cucumber-picocontainer:7.2.3 step3:…

查看交叉编译器的默认选项

1. 新建C文件mfloat.c#include <stdio.h> int main(void) { double a,b,c;a = 23.5436;b = 323.2348;c = b/a;printf("the result = %f\n", c);printf("hello world !\n");return 0; }2. 是 -v 选项 3. 显示结果如下

Starrocks模型表(一)

主键表优势:支撑实时数据更新的同时,也能保证高效的复杂即席查询性能 主键表中的主键具有唯一非空约束,用于唯一标识数据行,如果新数据的主键值与表中原数据的主键值相同,则存在唯一约束冲突,此时新数据会替代原数据应用场景实时对接事务型数据至StarRocks。事务型数据库…

2024-10-08:用go语言,给定一个字符串 word 和一个整数 k,判断是否可以通过删除最少数量的字符使得该字符串成为 k 特殊字符串。 其中,k 特殊字符串满足字符串中任意两个字符的出现频率

2024-10-08:用go语言,给定一个字符串 word 和一个整数 k,判断是否可以通过删除最少数量的字符使得该字符串成为 k 特殊字符串。 其中,k 特殊字符串满足字符串中任意两个字符的出现频率之差的绝对值均不超过 k。 你可以编写一个算法来计算最少需要删除多少个字符,使得给定的…

IIS 配置跨域_IIS配置Access-Control-Allow-Origin

一、使用IIS 界面操作1、设置Access-Control-Allow-Origin 2、打开IIS,找到“HTTP响应标头”点进去 3、在右侧可以看到添加,然后添加如下标头即可 Access-Control-Allow-Headers:Content-Type, api_key, Authorization Access-Control-Allow-Origin:* 二、修改IIS 配置文件…

extcon驱动及其在USB驱动中的应用

extcon,是External Connector的简称,用于抽象外部连接器,比如说Audio Jack、USB MicroB/TypeC接口等。它的原型是Android的switch-class驱动,经过修改后在kernel 3.4.0版本时被引入内核中。Extcon (external connector): import Androids switch class and modify. Externa…

IIS 配置referer 请求筛选_请求拒绝

一、IIS 配置Referer 拒绝解析: 访问静态内容,拒绝指定的referer,例如:拒绝后,对应的网站引用当前网站的静态资源会被拒绝。更多: iis怎么限制http下载速度_IIS 限制网站带宽使用? IIS 执行此操作时出错。 详细信息:web.config 错误,.net core项目IIS10 隐藏 http serve…

RAG系统评测实践详细版:Coze及相关产品评测对比,以及下一代RAG技术

RAG系统评测实践详细版:Coze及相关产品评测对比,以及下一代RAG技术AI RAG系统评测实践:Coze及相关产品评测对比 RAG(检索增强生成)是一种 AI 框架,它将传统信息检索系统(例如数据库)的优势与生成式大语言模型 (LLM) 的功能结合在一起,通过将这些额外的知识与自己的语言…

深入了解Oracle OCP认证,开启数据库专业之旅

使用Oracle数据库的公司内部,经常有员工们在讨论OCP认证(Oracle Certified Professional,Oracle认证专家),这是甲骨文Oracle公司提供的一种专业认证,认证用于使用者在Oracle技术领域的专业知识和技能。 在这里,有一点需要大家知道,虽然OCP认证一般指的是Oracle数据库管理…