Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
DCloud
unidocs-zh
提交
7595fb3d
unidocs-zh
项目概览
DCloud
/
unidocs-zh
通知
3200
Star
106
Fork
813
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
94
列表
看板
标记
里程碑
合并请求
70
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
unidocs-zh
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
94
Issue
94
列表
看板
标记
里程碑
合并请求
70
合并请求
70
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
未验证
提交
7595fb3d
编写于
1月 11, 2022
作者:
DCloud-yyl
提交者:
Gitee
1月 11, 2022
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
update docs/app-payment-google.md.
上级
c74cc239
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
62 addition
and
47 deletion
+62
-47
docs/app-payment-google.md
docs/app-payment-google.md
+62
-47
未找到文件。
docs/app-payment-google.md
浏览文件 @
7595fb3d
#### 申请开通Google支付
1.
注册谷歌账号。
1.
注册谷歌账号。
2.
打开
[
Google Pay | Google Developers
](
https://developers.google.com/pay
)
并登录谷歌账号。
2.
打开
[
Google Pay | Google Developers
](
https://developers.google.com/pay
)
并登录谷歌账号。
3.
进入控制台
[
Sign up: Google Pay's Business Console
](
https://pay.google.com/business/console/?pli=1
)
并设置商家名称。如图:
3.
进入控制台
[
Sign up: Google Pay's Business Console
](
https://pay.google.com/business/console/?pli=1
)
并设置商家名称。如图:
![
image-20220110010505156
](
https://native-res.dcloud.net.cn/images/uniapp/payment/googlepay_register_business.png
)
!
[
image-20220110010505156
](
https://gitee.com/duoguang/md-image/raw/master/image-20220110010505156.png
)
4.
设置完成后进入控制台页面,并设置对应的商家资料。
!
[
image-20220110011030589
](
https://gitee.com/duoguang/md-image/raw/master/image-20220110011030589.png
)
4.
设置完成后进入控制台页面,并设置对应的商家资料。
![
image-20220110011030589
](
https://native-res.dcloud.net.cn/images/uniapp/payment/googlepay_merchants_setup.png
)
5.
当需要上线正式版的时候,app的签名秘钥指纹需要确保与
`Google Play`
注册的发布秘钥指纹一致。
------
#### 使用Google支付
#### 使用Google支付
**环境要求**
**环境要求**
1.
海外网络环境。
2.
确保您的 Android 设备装有 18.0.0 或更高版本的 Google Play 服务。
**支付参数**
由于谷歌支付参数较多,并且区分付款方式,且不同付款方式配置并不相同,所以需要开发者在
`公共配置`
的基础上根据不同的支付方式追加对应的配置。
具体字段请参照
[
谷歌支付官方字段说明
](
https://developers.google.com/pay/api/android/reference/request-objects?authuser=1#PaymentMethod
)
**支付参数**
谷歌支付分为两种:
`CARD`
、
`PAYPAL`
付款方式,且不同付款方式配置并不相同,
具体字段请参照
[
谷歌支付官方字段说明
](
https://developers.google.com/pay/api/android/reference/request-objects?authuser=1#PaymentMethod
)
###### 公共配置
1.
`CARD`
支付
| 参数名称 | 参数说明 | 必须 |
|-------------|-------|-----|
|environment|环境(1:生产 3:测试)|是|
...
...
@@ -43,19 +41,11 @@
|shippingAddressRequired|是否需要地址|否|
|shippingPhoneNumberRequired|送货地址是否需要电话号码|否|
|allowedCountryCodes|允许的国家code。|否|
###### 付款方式配置
付款方式分为两种:
`CARD`
、
`PAYPAL`
,所以参数列表所以根据
`paymentMethodType`
参数区分为以下两种。
1.
`CARD`
支付
| 参数名称 | 参数说明 | 必须 |
|-------------|-------|-----|
|allowedAuthMethods|支持的身份校验|是|
|allowedCardNetworks|支持的卡类型(AMEX、DISCOVER、INTERAC、JCB、MASTERCARD、VISA)|是|
|allowPrepaidCards|是否支持预付卡|否|
|allowCreditCards|是否支持信用卡|否|
|assuranceDetailsRequired||否|
|assuranceDetailsRequired|
是否需要付款凭据
|否|
|billingAddressRequired|是否需要账单地址|否|
|billingAddressParametersFormat|账单地址格式(MIN、FULL)|否|
|phoneNumberRequired|处理交易是否需要电话号码|否|
...
...
@@ -69,11 +59,28 @@
2.
`PAYPAL`
支付
| 参数名称 | 参数说明 | 必须 |
|-------------|-------|-----|
|environment|环境(1:生产 3:测试)|是|
|paymentMethodType|付款方式(CARD、PAYPAL)|是|
|existingPaymentMethodRequired|如果设置为true,isReadyToPay方法就会返回true。|否|
|currencyCode|货币单位( ISO 4217)|是|
|countryCode|在欧洲经济区使用的货币单位|在欧洲经济区必填|
|transactionId|交易id|当想要接收googlepay回调的时候必填|
|totalPriceStatus|价格状态(NOT_CURRENTLY_KNOWN、ESTIMATED、FINAL)|是|
|totalPrice|总价|是|
|totalPriceLabel|显示的价格|否|
|checkoutOption|影响支付按钮显示的配置(DEFAULT、COMPLETE_IMMEDIATE_PURCHASE)|否|
|merchantName|商户名称|否|
|emailRequired|是否需要email|否|
|shippingAddressRequired|是否需要地址|否|
|shippingPhoneNumberRequired|送货地址是否需要电话号码|否|
|allowedCountryCodes|允许的国家code。|否|
|merchant|PayPal的商户id|是|
#### 示例
```
js
plus
.
payment
.
getChannels
((
providers
)
=>
{
let
provider
=
providers
.
find
(
function
(
e
)
{
return
e
.
id
===
"
google-pay
"
;
...
...
@@ -81,9 +88,9 @@ plus.payment.getChannels((providers) => {
let
paymentMethodType
=
"
CARD
"
;
let
statement
=
{
let
cardPaymentMethodConfig
=
{
environment
:
3
,
// 必填 1 是product 3是test
paymentMethodType
:
paymentMethodType
,
//必填 CARD、PAYPAL
paymentMethodType
:
paymentMethodType
,
//必填 CARD、PAYPAL
existingPaymentMethodRequired
:
false
,
//可选 如果设置为true同时已经准备好了支付allowedPaymentMethods中的付款方式,isReadyToPay就会返回true。
currencyCode
:
"
USD
"
,
//必填
...
...
@@ -99,17 +106,6 @@ plus.payment.getChannels((providers) => {
shippingAddressRequired
:
true
,
//可选
shippingPhoneNumberRequired
:
false
,
//可选
allowedCountryCodes
:
[
"
US
"
,
"
GB
"
],
//可选
};
let
paymentMethodConfig
=
{};
let
paypalPaymentMethodConfig
=
{
merchantId
:
""
,
//必填
};
let
cardPaymentMethodConfig
=
{
allowedAuthMethods
:
[
"
PAN_ONLY
"
,
"
CRYPTOGRAM_3DS
"
],
//必填
allowedCardNetworks
:
[
"
AMEX
"
,
"
DISCOVER
"
,
"
JCB
"
,
"
MASTERCARD
"
,
"
VISA
"
],
//必填
allowPrepaidCards
:
false
,
//可选
...
...
@@ -124,25 +120,41 @@ plus.payment.getChannels((providers) => {
protocolVersion
:
""
,
//DIRECT时必填
publicKey
:
""
,
//DIRECT时必填
};
let
paypalPaymentMethodConfig
=
{
environment
:
3
,
// 必填 1 是product 3是test
paymentMethodType
:
paymentMethodType
,
//必填 CARD、PAYPAL
existingPaymentMethodRequired
:
false
,
//可选 如果设置为true同时已经准备好了支付allowedPaymentMethods中的付款方式,isReadyToPay就会返回true。
if
(
paymentMethodType
===
"
PAYPAL
"
)
{
paymentMethodConfig
=
{
...
paypalPaymentMethodConfig
currencyCode
:
"
USD
"
,
//必填
countryCode
:
"
US
"
,
//在欧洲经济区必填
transactionId
:
""
,
//当你想要接收googlepay回调的时候必填
totalPriceStatus
:
"
FINAL
"
,
//必填 NOT_CURRENTLY_KNOWN、ESTIMATED、FINAL
totalPrice
:
"
111.00
"
,
//必填 满足正则格式^[0-9]+(\.[0-9][0-9])?$
totalPriceLabel
:
"
100heelo
"
,
//可选
checkoutOption
:
"
DEFAULT
"
,
//可选 DEFAULT、COMPLETE_IMMEDIATE_PURCHASE
merchantName
:
"
Example Merchant
"
,
//可选
emailRequired
:
true
,
//可选
shippingAddressRequired
:
true
,
//可选
shippingPhoneNumberRequired
:
false
,
//可选
allowedCountryCodes
:
[
"
US
"
,
"
GB
"
],
//可选
merchantId
:
"
MVHSBANAS6KSE
"
,
//必填
};
let
statement
;
if
(
paymentMethodType
===
"
CARD
"
)
{
statement
=
{
...
cardPaymentMethodConfig
};
}
else
{
paymentMethodConfig
=
{
...
card
PaymentMethodConfig
statement
=
{
...
paypal
PaymentMethodConfig
};
}
statement
=
{
...
statement
,
...
paymentMethodConfig
};
console
.
log
(
JSON
.
stringify
(
statement
));
plus
.
payment
.
request
(
provider
,
statement
,
(
result
)
=>
{
...
...
@@ -151,5 +163,8 @@ plus.payment.getChannels((providers) => {
console
.
log
(
"
支付失败:
"
+
JSON
.
stringify
(
e
));
})
});
```
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录