@@ -3,10 +3,11 @@ react-native-uiwjs-alipay
基于 React Native 的宝支付插件。适用于商家在 App 应用中集成支付宝支付功能,商家 APP 调用支付宝提供的 SDK, SDK 再调用支付宝 APP 内的支付模块。如果用户已安装支付宝APP, 商家APP会跳转到支付宝中完成支付, 支付完后跳回到商家 APP 内,最后展示支付结果。如果用户没有安装支付宝 APP, 商家 APP 内会调起支付宝网页支付收银台,用户登录支付宝账户,支付完后展示支付结果。完整实例 [Example ](./example )
1. Android: 支持2.3及以上的系统版本运行
2. iOS: iOS 6.0以上(包含iOS 6.0)
3. 支持手机系统: iOS( 苹果) 、Android( 安卓)
4. 调试请注意 支付宝接入应用必须 `已审核通过`
1. Android: 支持2.3及以上的系统版本运行。
2. iOS: iOS 6.0以上(包含iOS 6.0)。
3. 支持手机系统: iOS( 苹果) 、Android( 安卓) 。
4. 调试请注意 支付宝接入应用必须 `已审核通过` 。
5. 适用于 `react-native >= 0.60+` 低版本未测试。
## Getting started
@@ -14,8 +15,6 @@ react-native-uiwjs-alipay
yarn add react-native-uiwjs-alipay
# react-native version >= 0.60+
$ cd ios && pod install
# or
$ react-native link react-native-uiwjs-alipay
```
## Usage
@@ -26,11 +25,11 @@ $ react-native link react-native-uiwjs-alipay
```javascript
import Alipay from 'react-native-uiwjs-alipay' ;
// 设置 支付宝 URL Schemes, `APPID` 为支付宝分配给开发者的应用ID
// scheme = `ap ` + `APPID`
// 设置 支付宝 URL Schemes, 要表述他是宇宙唯一性,可以使用 `bundle Identifier`
// scheme = `alipay ` + `APPID`, `APPID` 为支付宝分配给开发者的应用ID
Alipay . setAlipayScheme ( scheme );
// 设置支付宝沙箱环境,仅 Android 支持
Alipay. setAlipaySandbox( isSandbox );
// ⚠️ 目前不可用, 设置支付宝沙箱环境,仅 Android 支持
// Alipay. setAlipaySandbox( isSandbox);
// 支付宝端支付
// payInfo 是后台拼接好的支付参数
Alipay . alipay ( payInfo , ( res )=> console . log ( res ))
@@ -39,13 +38,13 @@ Alipay.alipay(payInfo, (res)=>console.log(res))
订单详情 [`payInfo` ](https://opendocs.alipay.com/open/204/105295#%E5%BF%AB%E6%8D%B7%E8%AE%A2%E5%8D%95%E6%94%AF%E4%BB%98%20iOS ) 编码前的数据
```bash
alipay_sdk = alipay-sdk-java-dynamicVersionNo& app_id = xxxxxxxxxxxxxxxx & biz_content ={ "out_trade_no" :"1111144444 " , "total_amount" :"0.01" , "subject" :"12321313655555555 " , "product_code" :"QUICK_MSECURITY_PAY" } & charset = UTF-8& format = json& method = alipay.trade.app.pay& notify_url = http://ane.boshu.ltd/owner/pay/api/ownerPay/callback& return_url = http://domain.com/CallBack/return_url.jsp& sign = FP5fLb/l2LoijO7k0BrmEvWKfuG7oIbYA/4VVL9mI0/SWAEzt27Zp09LK2xsDKaW0oGJ38aGhtDxGIHqZDMvbhTooB6jeRH+2m1wM5hyDq1vbc8CzfL+OSfRoQ3RQ4j50gbO0oABOUvaSb/xK8Tzix7HfDpMfjtqhN+81fiET2Q19dxcOmu22GAWE4/ZPrbASsVfi1r/OXLdeDjkqdUTy9lOGJqg2bgTKy6BaYcelc/nEpuaF0mDXbHJX1vmra7vd8rhczy11rEVaHofMnPVZr3hucMuBH/fxOXQZuZcAmyaWr+NT8hVetxZaTgyhK9fqxjGcxPijc+pWWTwMxt4YA == & sign_type = RSA2& timestamp = 2020-07-08 17:07:36 & version = 1.0
alipay_sdk = alipay-sdk-java-dynamicVersionNo& app_id = xxxxxxxxxxxxx& biz_content ={ "out_trade_no" :"123123123123123 " , "total_amount" :"0.01" , "subject" :"1234 " , "product_code" :"QUICK_MSECURITY_PAY" } & charset = UTF-8& format = json& method = alipay.trade.app.pay& notify_url = http://ane.boshu.ltd/owner/pay/api/ownerPay/callback& return_url = uiwjspay://& sign = re/+2SICQggOUjfxl7MtP/qzir2e+LdH4m+02gDcw0fkByO5MqXW/9bmXw+c4RMqo835OAjMZs7s966ZuDx2PB+hO0tJ/bzdHLLqYlBeCcETkrfwRx+AFZNgzsCn75eRCA7GONH35BpfSeGkQUZ+vNXftqd6hWaa7m/MhQYrjQcV98IVJM+UR67Gj68c+LM586cnk0+rbj8zoos6tCvN8c3xx5UaCobzw4Ogf0PWZ7PZROTU9w2gtoxFfOC5d5slN3laaAXVjAxSf9JCNs8q95fDbzpbmstQOuPgGHkASkd/beH0F8eqTVv8gW1ZTo5v/d/E2wSDGV1DciaEnCroTw == & sign_type = RSA2& timestamp = 2020-07-09 09:50:41 & version = 1.0
```
订单详情 `payInfo` 编码的数据
```bash
alipay_sdk = alipay-sdk-java-dynamicVersionNo& app_id = xxxxxxxxxxxxxxxx & biz_content = %7B+%22out_trade_no%22%3A%221111144444 %22%2C+%22total_amount%22%3A%220.01%22%2C+%22subject%22%3A%2212321313655555555 %22%2C+%22product_code%22%3A%22QUICK_MSECURITY_PAY%22+%7D& charset = UTF-8& format = json& method = alipay.trade.app.pay& notify_url = http%3A%2F%2Fane.boshu.ltd%2Fowner%2Fpay%2Fapi%2FownerPay%2Fcallback& return_url = http %3A%2F%2Fdomain.com%2FCallBack%2Freturn_url.jsp& sign = FP5fLb%2Fl2LoijO7k0BrmEvWKfuG7oIbYA%2F4VVL9mI0%2FSWAEzt27Zp09LK2xsDKaW0oGJ38aGhtDxGIHqZDMvbhTooB6jeRH%2B2m1wM5hyDq1vbc8CzfL%2BOSfRoQ3RQ4j50gbO0oABOUvaSb%2FxK8Tzix7HfDpMfjtqhN%2B81fiET2Q19dxcOmu22GAWE4%2FZPrbASsVfi1r%2FOXLdeDjkqdUTy9lOGJqg2bgTKy6BaYcelc%2FnEpuaF0mDXbHJX1vmra7vd8rhczy11rEVaHofMnPVZr3hucMuBH%2FfxOXQZuZcAmyaWr%2BNT8hVetxZaTgyhK9fqxjGcxPijc%2BpWWTwMxt4YA %3D%3D& sign_type = RSA2& timestamp = 2020-07-08+17 %3A07 %3A36 & version = 1.0
alipay_sdk = alipay-sdk-java-dynamicVersionNo& app_id = xxxxxxxxxxxxx& biz_content = %7B+%22out_trade_no%22%3A%22123123123123123 %22%2C+%22total_amount%22%3A%220.01%22%2C+%22subject%22%3A%221234 %22%2C+%22product_code%22%3A%22QUICK_MSECURITY_PAY%22+%7D& charset = UTF-8& format = json& method = alipay.trade.app.pay& notify_url = http%3A%2F%2Fane.boshu.ltd%2Fowner%2Fpay%2Fapi%2FownerPay%2Fcallback& return_url = uiwjspay %3A%2F%2F& sign = re%2F%2B2SICQggOUjfxl7MtP%2Fqzir2e%2BLdH4m%2B02gDcw0fkByO5MqXW%2F9bmXw%2Bc4RMqo835OAjMZs7s966ZuDx2PB%2BhO0tJ%2FbzdHLLqYlBeCcETkrfwRx%2BAFZNgzsCn75eRCA7GONH35BpfSeGkQUZ%2BvNXftqd6hWaa7m%2FMhQYrjQcV98IVJM%2BUR67Gj68c%2BLM586cnk0%2Brbj8zoos6tCvN8c3xx5UaCobzw4Ogf0PWZ7PZROTU9w2gtoxFfOC5d5slN3laaAXVjAxSf9JCNs8q95fDbzpbmstQOuPgGHkASkd%2FbeH0F8eqTVv8gW1ZTo5v%2Fd%2FE2wSDGV1DciaEnCroTw %3D%3D& sign_type = RSA2& timestamp = 2020-07-09+09 %3A5 0%3A41 & version = 1.0
```
- ⚠️ 后台 SDK 根据所有数据生成 `sign` ,建议通过 API 拿到这个数据,拼接数据会报错。
@@ -53,23 +52,24 @@ alipay_sdk=alipay-sdk-java-dynamicVersionNo&app_id=xxxxxxxxxxxxxxxx&biz_content=
## 支付宝返回应用 iOS 设置
⚠️ 如果用户从 `支付宝App` 跳转到 `商家APP` ,是通过系统功能切换,而不是通过 `支付宝APP` 功能键返回 `商家APP` ,回调函数是不起作用的,可通过 [`AppState.addEventListener` ](https://github.com/uiwjs/react-native-uiwjs-alipay/blob/b8b5b3e6e53bb23d1503cd9c565ad8f2132e2404/example/App.js#L6-L24 ) 监听事件请求后台 API, 来优化这一用户体验 。
⚠️ Android 端不需要做任何设置 。
1. 在代码中设置支付宝 [`URL Schemes` ](https://github.com/uiwjs/react-native-uiwjs-alipay/blob/1eff1dd94f3ae733db2913400e1aac382d056871/example/App.js#L7 ),下面实例为 `ap2021001172656340` 为定义的 `scheme` = `ap` + `appid` , `appid` 为支付宝分配给开发者的应用ID
⚠️ 如果用户从 `支付宝App` 跳转到 `商家APP` ,是通过系统功能切换,而不是通过 `支付宝APP` 功能键返回 `商家APP` ,回调函数是不起作用的,可通过 [`AppState.addEventListener` ](https://github.com/uiwjs/react-native-uiwjs-alipay/blob/5daea87bf0af05d60d0ae9e4c04e1e2d1a6e4273/example/App.js#L8-L24 ) 监听事件请求后台 API, 来优化这一用户体验。
1. 在代码中设置支付宝 [`URL Schemes` ](https://github.com/uiwjs/react-native-uiwjs-alipay/blob/5daea87bf0af05d60d0ae9e4c04e1e2d1a6e4273/example/App.js#L7 ),下面实例 [`uiwjspay` ](https://github.com/uiwjs/react-native-uiwjs-alipay/commit/f6d21b6b7ec7236b195c56281f971092f3c9bb08 ) 是定义的 `scheme` ,你也可以定义为 `alipay` + `appid` , `appid` 为支付宝分配给开发者的应用ID, 用来表述 `scheme` 唯一性。
```js
// scheme = `ap` + `appid`
Alipay . setAlipayScheme ( 'ap2021001172656340' );
Alipay . setAlipayScheme ( 'uiwjspay' );
```
2. 在请求支付的 [`payInfo` ](https://github.com/uiwjs/react-native-uiwjs-alipay/blob/1eff1dd94f3ae733db2913400e1aac382d056871/example/App.js#L27-L30 ) 中必须包含 [`return_url=ap2021001172656340 ` ](https://github.com/uiwjs/react-native-uiwjs-alipay/blob/1eff1dd94f3ae733db2913400e1aac382d056871 /example/App.js#L27-L30 ), `return_url` 的值为定义的 `scheme` => `ap2021001172656340 ://` ,才会返回[支付宝订单支付状态结果 ](https://opendocs.alipay.com/open/204/105301#%E8%BF%94%E5%9B%9E%E7%BB%93%E6%9E%9C%E7%A4%BA%E4%BE%8B%EF%BC%88iOS%7CAndroid%EF%BC%89 )
2. 在请求支付的 [`payInfo` ](https://github.com/uiwjs/react-native-uiwjs-alipay/blob/1eff1dd94f3ae733db2913400e1aac382d056871/example/App.js#L27-L30 ) 中必须包含 [`return_url=uiwjspay:// ` ](https://github.com/uiwjs/react-native-uiwjs-alipay/blob/5daea87bf0af05d60d0ae9e4c04e1e2d1a6e4273 /example/App.js#L27-L28 ), `return_url` 的值为定义的 `scheme` => `uiwjspay ://` ,才会返回[支付宝订单支付状态结果 ](https://opendocs.alipay.com/open/204/105301#%E8%BF%94%E5%9B%9E%E7%BB%93%E6%9E%9C%E7%A4%BA%E4%BE%8B%EF%BC%88iOS%7CAndroid%EF%BC%89 )
```js
// payInfo 是后台拼接好的支付参数,这个参数必须包含 `return_url=ap2021001172656340 ://`
// payInfo 是后台拼接好的支付参数,这个参数必须包含 `return_url=uiwjspay ://`
Alipay . alipay ( payInfo , ( res )=> console . log ( res ))
```
3. 用的 `URL Schemes` 列为白名单,在 [`ios/<应用名称>/Info.plist` ](https://github.com/uiwjs/react-native-uiwjs-alipay/blob/866888a3ed9f05d06fa9a7ed93922d9ca2dcc56e /example/ios/example/Info.plist#L23-L41 ) 中添加
3. 用的 `URL Schemes` 列为白名单,在 [`ios/<应用名称>/Info.plist` ](https://github.com/uiwjs/react-native-uiwjs-alipay/blob/5daea87bf0af05d60d0ae9e4c04e1e2d1a6e4273 /example/ios/example/Info.plist#L23-L41 ) 中添加
```xml
<key> LSApplicationQueriesSchemes</key>
@@ -85,7 +85,7 @@ Alipay.alipay(payInfo, (res)=>console.log(res))
<string></string>
<key> CFBundleURLSchemes</key>
<array>
<string> ap2021001172656340 </string>
<string> uiwjspay </string>
</array>
</dict>
</array>
@@ -108,7 +108,7 @@ Alipay.alipay(payInfo, (res)=>console.log(res))
}
` ``
命令测试 ` xcrun simctl openurl booted ap2021001172656340 ://`
命令测试 ` xcrun simctl openurl booted uiwjspay ://`
## 错误处理
@@ -130,4 +130,5 @@ npx create-react-native-module --package-identifier com.uiwjs --generate-example
- [支付宝生成秘钥指南 ](https://opendocs.alipay.com/open/291/105971 )
- [支付宝 SDK 下载地址,当前使用的是 AlipaySDK 15.7.7 ](https://opendocs.alipay.com/open/54/104509 )
- [客户端调试工具及使用教程 ](https://openclub.alipay.com/club/history/read/7695 )
- [React-native 0.6版本集成支付宝-Alipay爬坑 ](https://segmentfault.com/a/1190000020758279 )