鸿蒙Next-拉起支付宝的三种方式——教程

打印 上一主题 下一主题

主题 848|帖子 848|积分 2544

鸿蒙Next-拉起支付宝的三种方式——教程

鸿蒙Next系统即将上线,应用市场渐渐丰富、许多APP都准备接入支付宝做支付功能,目前来说有三种方式拉起支付宝:通过支付宝SDK拉起、使用OpenLink拉起、传入支付宝包名使用startAbility拉起。以上的三种拉起方式都是指的Next应用,不包含元服务,元服务有本身的生态限定暂时不支持拉起第三方应用。
一、使用支付宝SDK拉起

OpenHarmony第三方仓库包有支付宝的SDK:
仓库地点:https://ohpm.openharmony.cn/#/cn/detail/@cashier_alipay%2Fcashiersdk
官方Demo地点:
https://alidocs.dingtalk.com/i/nodes/qnYMoO1rWxrkmoj2IOpZR6yaJ47Z3je9?iframeQuery=utm_source%3Dportal%26utm_medium%3Dportal_recent&rnd=0.2928087218087806
官方的Demo必要登录钉钉去请求授权,一般都能进
代码实现:
  1. onAlipay() {
  2.   ///这个支付信息对象的所有值都应该服务器返回
  3.   let obj = new PayInfo(); //支付信息
  4.   obj.appId = "1111111111111";
  5.   obj.orderId = "1111111111"
  6.   obj.productName = "1年VIP"
  7.   obj.amount = 10
  8.   obj.notifyUrl = 'https://www.huawei.com'
  9.   obj.rsaPrivate =
  10.     "MIICXQIBAAKBgQC+L0rfjLl3neHleNMOsYTW8r0QXZ5RVb2p/vvY3fJNNugvJ7lo4+fdBz+LN4mDxTz4MTOhi5e2yeAqx+v3nKpNmPzC5LmDjhHZURhwbqFtIpZD51mOfno2c3MDwlrsVi6mTypbNu4uaQzw/TOpwufSLWF7k6p2pLoVmmqJzQiD0QIDAQABAoGAakB1risquv9D4zX7hCv9MTFwGyKSfpJOYhkIjwKAik7wrNeeqFEbisqv35FpjGq3Q1oJpGkem4pxaLVEyZOHONefZ9MGVChT/MNH5b0FJYWl392RZy8KCdq376Vt4gKVlABvaV1DkapL+nLh7LMo/bENudARsxD55IGObMU19lkCQQDwHmzWPMHfc3kdY6AqiLrOss+MVIAhQqZOHhDe0aW2gZtwiWeYK1wB/fRxJ5esk1sScOWgzvCN/oGJLhU3kipHAkEAysNoSdG2oWADxlIt4W9kUiiiqNgimHGMHPwp4JMxupHMTm7D9XtGUIiDijZxunHv3kvktNfWj3Yji0661zHVJwJBAM8TDf077F4NsVc9AXVs8N0sq3xzqwQD/HPFzfq6hdR8tVY5yRMb4X7+SX4EDPORKKsgnYcur5lk8MUi7r072iUCQQC8xQvUne+fcdpRyrR4StJlQvucogwjTKMbYRBDygXkIlTJOIorgudFlrKP/HwJDoY4uQNl8gQJb/1LdrKwIe7FAkBl0TNtfodGrDXBHwBgtN/t3pyi+sz7OpJdUklKE7zMSBuLd1E3O4JMzvWP9wEE7JDb+brjgK4/cxxUHUTkk592"
  11.   OrderInfoUtil.getOrderInfo(obj).then(orderInfo => {
  12.     // orderInfo 由服务端生成
  13.     // 第二个参数 控制是否展示支付宝loading
  14.     new Pay().pay(orderInfo, true).then((result) => {
  15.       let message =
  16.         `resultStatus: ${result.get('resultStatus')} memo: ${result.get('memo')} result: ${result.get('result')}`;
  17.       console.log("支付结果:" + message);
  18.       if (result.get('resultStatus') == '9000') { //支付成功
  19.         console.log("支付成功");
  20.       } else {
  21.         console.log("支付失败");
  22.       }
  23.     }).catch((error: BusinessError) => {
  24.       LogUtil.e("aLiParSdk:", error)
  25.     });
  26.   })
  27. }
复制代码
完备的代码可以参考后面的git仓库,详细的描述在别的一位博主上也有详细的解释:
博主链接:鸿蒙Next-支付宝SDK接入教程_怎么唤起鸿蒙版支付宝-CSDN博客
完备代码仓库地点:https://gitee.com/qq1963861722/AliPayDemo.git
结果图

二、使用OpenLink拉起支付宝

使用OpenLink可以实现应用之间的跳转,详细的支付宝也可以参考拉起游览器的案例进行实现
使用API: UIAbilityContext.openLink 链接:UIAbilityContext-application-接口依赖的元素及界说-ArkTS API-Ability Kit(步伐框架服务)-应用框架 - 华为HarmonyOS开发者 (huawei.com)
API官方参考用法链接: 使用Deep Linking实现应用间跳转-指向性跳转-应用间跳转-Stage模型开发指导-Ability Kit(步伐框架服务)-应用框架 - 华为HarmonyOS开发者 (huawei.com)
拉起支付宝代码参考:
  1. let context = getContext(this) as common.UIAbilityContext;
  2. let link: string = 'alipays://platformapi/startapp' //支付宝拉起的专属链接
  3. let openLinkOptions: OpenLinkOptions = {
  4.   appLinkingOnly: false,
  5.   parameters: { demo_key: 'demo_value' }
  6. };
  7. try {
  8.   context.openLink(
  9.     link,
  10.     openLinkOptions,
  11.     (err, result) => {
  12.       LogUtil.e(TAG, `openLink callback error.code: ${JSON.stringify(err)}`);
  13.       LogUtil.i(TAG, `openLink callback result: ${JSON.stringify(result.resultCode)}`);
  14.       LogUtil.i(TAG, `openLink callback result data: ${JSON.stringify(result.want)}`);
  15.     }
  16.   ).then(() => {
  17.     LogUtil.i(TAG, `open link success.`);
  18.   }).catch((err: BusinessError) => {
  19.     LogUtil.e(TAG, `open link failed, errCode ${JSON.stringify(err.code)}`);
  20.   });
  21. } catch (e) {
  22.   LogUtil.e(TAG, `exception occured, errCode ${JSON.stringify(e.code)}`);
  23. }
复制代码
完备代码仓库地点: https://gitee.com/qq1963861722/AliPayDemo.git
实现结果参考

三、使用startAbility拉起支付宝

在鸿蒙Next系统中知道应用的包名就可以通过startAbility拉起另一个应用,明确了拉起的应用使用显式Want传入包名进行拉起
使用API: UIAbilityContext.startAbility
API官方参考用法链接: https://developer.huawei.com/consumer/cn/doc/harmonyos-references-V5/js-apis-inner-application-uiabilitycontext-V5#uiabilitycontextstartability
支付宝的包名获取方式

1.通过hdc下令进行获取(使用下令行进行获取)

  1. hdc shell aa dump -l
复制代码
hdc下令的使用链接:hdc-调试工具-开发 - 华为HarmonyOS开发者 (huawei.com)
2.通过毗连真机在编译器中的Device File Browser获取包名

路径:/data/app/el2/100/database/com.alipay.mobile.client
外链图片转存失败,源站可能有防盗链机制,建议将图片生存下来直接上传
代码实现:
  1. const context: common.UIAbilityContext = getContext(this) as common.UIAbilityContext;
  2. let want: Want = {
  3.   deviceId: '',
  4.   bundleName: 'com.alipay.mobile.client',
  5.   abilityName: 'EntryAbility',
  6.   flags: wantConstant.Flags.FLAG_INSTALL_ON_DEMAND, //如果未安装指定的功能,请安装该功能,
  7.   parameters: {
  8.     //自定义参数传递页面信息
  9.   }
  10. }
  11. context.startAbility(want)
复制代码
完备代码仓库地点: https://gitee.com/qq1963861722/AliPayDemo.git
结果实现:

以上是支付宝在鸿蒙Next中常见的三种拉起方式,希望对其他开发职员有所帮助、若文中有不足之处望读者体贴并指出。

免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有账号?立即注册

x
回复

使用道具 举报

0 个回复

倒序浏览

快速回复

您需要登录后才可以回帖 登录 or 立即注册

本版积分规则

北冰洋以北

金牌会员
这个人很懒什么都没写!

标签云

快速回复 返回顶部 返回列表