expo-alikit
v0.1.1
Published
React Native Alipay support
Maintainers
Readme
expo-alipay
支付宝支付与授权登录。React Native Alipay support.
⚠️BETA WARNING: 本项目目前处于beta版本,如有任何问题,欢迎issue联系,但目前谨慎在生产项目中使用。⚠️
安装
npx expo install expo-alikit为什么是expo-alikit?因为expo-alipay的名字在npm中已经被占用,但后者看起来只是一个demo项目,目前我正在尝试联系作者,看看是否可以让他删掉那个仓库。
目前为止,用户可能会在alikit和alipay之间产生歧义,只需要记住,alikit只是npm的包名,其他代码相关的地方保持不变。
配置
支付宝支付和授权登录,由于会涉及到唤起支付宝,跳回你的app,为了让支付宝能识别你的app,你需要配置URL Scheme或者 Universal Link。
配置这两项,都需要在app.json中进行:
"ios": {
"scheme": [
"你的url scheme,需要与支付宝后台保持一致。"
],
"associatedDomains": [
"applinks:example.com"
]
}通用连接配置部分可以参考一下苹果官方文档。
使用
注意,不支持在expo go中直接使用,请配合
expo-dev-client一起使用。
import ExpoAlipay from "expo-alikit";支付
/// 安卓Only,防黑产操作,推荐在调用支付前调用此方法。
/// https://opendocs.alipay.com/open/00dn75?pathHash=22ed0058#%E5%95%86%E6%88%B7appId%E6%B3%A8%E5%86%8C
await ExpoAlipay.registerApp(appId)
/// scheme和universalLink需要与app.json中的配置保持一致,仅iOS上需要提供这两个字段。
const result = await ExpoAlipay.pay({
orderInfo: "orderString",
scheme: undefined,
universalLink: undefined,
});获取支付结果有两种办法。对于安卓平台,pay方法会直接返回支付结果,同时也会发布一条onPayResult事件。对于iOS平台,你只能通过onPayResult事件来获取支付结果。
授权登录
/// scheme和universalLink需要与app.json中的配置保持一致,仅iOS上需要提供这两个字段。
const result = await ExpoAlipay.auth({
authInfo: "authString",
scheme: undefined,
universalLink: undefined,
});获取支付结果有两种办法。对于安卓平台,auth方法会直接返回支付结果,同时也会发布一条onAuthResult事件。对于iOS平台,你只能通过onAuthResult事件来获取支付结果。
事件监听
import ExpoAlipay from "expo-alikit";
/// 通过这种方式监听回调结果
const onPayResultPayload = useEvent(ExpoAlipay, 'onPayResult');
console.log(onPayResultPayload);联系我
QQ 群:682911244
Roadmap
- [ ] 给支付宝返回数据添加类型。
