支付宝小程序唤起独立签约

目录

获取签约字符串

唤起支付宝周期扣款签约页面


支付宝小程序唤起独立签约,需要通过alipay.user.agreement.page.sign接口获取签约字符串signStr,然后调用my.paySignCenter API在支付宝小程序内唤起周期扣款签约页面。

获取签约字符串

调用接口alipay.user.agreement.page.sign获取签约字符串,所需参数如下:

公共请求参数

参数必填描述示例值
app_id支付宝分配给开发者的应用ID2014072300007148
method接口名称alipay.user.agreement.page.sign
format仅支持JSONJSON
return_urlHTTP/HTTPS开头字符串https://m.alipay.com/Gk8NF23
charset请求使用的编码格式,如utf-8,gbk,gb2312等utf-8
sign_type商户生成签名字符串所使用的签名算法类型,目前支持RSA2和RSA,推荐使用RSA2RSA2
sign商户请求参数的签名串,详见签名详见示例
timestamp发送请求的时间,格式"yyyy-MM-dd HH:mm:ss"2014-07-24 03:07:50
version调用的接口版本,固定为:1.01.0
notify_url支付宝服务器主动通知商户服务器里指定的页面http/https路径。http://api.test.alipay.net/atinterface/receive_notify.htm
app_auth_token详见应用授权概述
biz_content请求参数的集合,最大长度不限,除公共参数外所有请求参数都必须放在这个参数中传递,具体参照各产品快速接入文档

请求参数

参数必填描述示例值
product_code可选销售产品码,商户签约的支付宝合同所对应的产品码。
周期扣款场景固定为 CYCLE_PAY_AUTH。
CYCLE_PAY_AUTH
personal_product_code必选个人签约产品码,商户和支付宝签约时确定,商户可咨询技术支持。
周期扣款个人签约产品码固定为 CYCLE_PAY_AUTH_P
CYCLE_PAY_AUTH_P
sign_scene可选协议签约场景,商户可根据 代扣产品常见场景值 选择符合自身的行业场景。
说明:当传入商户签约号 external_agreement_no 时,本参数必填,不能为默认值 DEFAULT|DEFAULT。
INDUSTRY|CARRENTAL
external_agreement_no可选商户签约号,代扣协议中标示用户的唯一签约号(确保在商户系统中唯一)。
格式规则:支持大写小写字母和数字,最长32位。
商户系统按需自定义传入,如果同一用户在同一产品码、同一签约场景下,签订了多份代扣协议,那么需要指定并传入该值。
test
access_params必选请按当前接入的方式进行填充,且输入值必须为文档中的参数取值范围。
扫码或者短信页面签约需要拼装http的请求地址访问中间页面,钱包h5页面签约可直接拼接scheme的请求地址
└channel必选目前支持以下值:
1. ALIPAYAPP (钱包h5页面签约)
2. QRCODE(扫码签约)
3. QRCODEORSMS(扫码签约或者短信签约)
ALIPAYAPP
period_rule_params必选周期管控规则参数period_rule_params,在签约周期扣款产品(如CYCLE_PAY_AUTH_P)时必传,在签约其他产品时无需传入。 周期扣款产品,会按照这里传入的参数提示用户,并对发起扣款的时间、金额、次数等做相应限制。
└period_type必选周期类型period_type是周期扣款产品必填,枚举值为DAY和MONTH。
DAY即扣款周期按天计,MONTH代表扣款周期按自然月。
与另一参数period组合使用确定扣款周期,例如period_type为DAY,period=30,则扣款周期为30天;period_type为MONTH,period=3,则扣款周期为3个自然月。
自然月是指,不论这个月有多少天,周期都计算到月份中的同一日期。例如1月3日到2月3日为一个自然月,1月3日到4月3日为三个自然月。注意周期类型使用MONTH的时候,计划扣款时间execute_time不允许传28日之后的日期(可以传28日),以此避免有些月份可能不存在对应日期的情况。
DAY
└period必选周期数period是周期扣款产品必填。与另一参数period_type组合使用确定扣款周期,例如period_type为DAY,period=90,则扣款周期为90天。7
└execute_time必选首次执行时间execute_time是周期扣款产品必填,即商户发起首次扣款的时间。精确到日,格式为yyyy-MM-dd
结合其他必填的扣款周期参数,会确定商户以后的扣款计划。发起扣款的时间需符合这里的扣款计划。
2019-01-23
└single_amount必选单次扣款最大金额single_amount是周期扣款产品必填,即每次发起扣款时限制的最大金额,单位为元。商户每次发起扣款都不允许大于此金额。10.99
└total_amount可选总金额限制,单位为元。如果传入此参数,商户多次扣款的累计金额不允许超过此金额。600
└total_payments可选总扣款次数。如果传入此参数,则商户成功扣款的次数不能超过此次数限制(扣款失败不计入)。12
const signObj = {
    app_id: '2014072300007148',
    biz_content: '{"access_params":{"channel":"ALIPAYAPP"},"external_agreement_no":"2019_06_0910","personal_product_code":"CYCLE_PAY_AUTH_P","period_rule_params":{"period_type":"DAY","period":"30","execute_time":"2021-10-29","single_amount":"10","total_amount":"600","total_payments":"12"},"sign_scene":"INDUSTRY|DIGITAL_MEDIA"}',
    charset: 'UTF-8',
    method: 'alipay.user.agreement.page.sign',
    sign_type: 'RSA2',
    timestamp: '2021-10-29 17:18:02',
    version: '1.0',    
sign:'Y+Sx4WPF4tIzTnQ+FqYds+xLBfi9wflmD+GPs2LN0qSo6431moZqM3TCouc/tEjzh3/GUFc75yHNEXVBTQ0iL+nSM4PlNgP3yPCql12c38PmChAcfj0C/1+engUkqXtCtWs0lXVKXn2ze3aHLE+64dG87h8I1ngl/2LqSAD8mhH4RmWDIrxFcxNEzlT+GJp+7Ae+OpbT284iOuZ5l5DUya47K7LVI3+/t1sXsHPGAD1d1wDQ+NfcfE+jAAw2XQ1G/EcnNkZCHlplIU1tAFTKDMPKIlOHUV1F1LkqCcH3AK5w+C0RNLcDW8SbN4q79gRGDWXX7C6FjURAjn8Tw8/Zgw=='
};

let signStr = '';

for (let key in signObj) {
    signStr += key + '=' + encodeURIComponent(signObj[key]) + '&';
}
signStr = signStr.substring(0, signStr.length - 1);
signStr = encodeURIComponent(signStr);

唤起支付宝周期扣款签约页面

调用my.paySignCenter API,使用上一步得到的signStr作为API的参数来唤起支付宝周期扣款签约页面。

my.paySignCenter({
      signStr: signStr,
      success: (res) => {
        my.alert({
          title: 'success', // alert 框的标题
          content: JSON.stringify(res)
        });
      },
      fail: (res) => {
        my.alert({
          title: 'fail', // alert 框的标题
          content: JSON.stringify(res)
        });
      }
    });

### 在 UniApp 中实现支付宝小程序唤起文件选择器的功能 支付宝小程序提供了丰富的 API 接口,其中 `my.chooseImage` 和 `my.chooseFile` 是用于文件选择的核心方法。在 UniApp 的跨平台框架下,可以通过调用这些特定的小程序 API 来实现文件选择器的唤起功能。 --- #### 使用 `my.chooseImage` 或 `my.chooseFile` 实现文件选择 支付宝小程序支持通过 `my.chooseImage` 选择图片文件,而 `my.chooseFile` 则能够选择其他类型的文件(如 PDF、DOC 等)。以下是两种方式的具体实现: ##### 方法一:使用 `my.chooseImage` 选择图片文件 此方法适用于仅需选择图片文件的场景。 代码示例: ```javascript function chooseImage() { my.chooseImage({ count: 9, // 最大可选文件数 sizeType: ['original', 'compressed'], // 可选原图或压缩后的图片 sourceType: ['album', 'camera'], // 图片来源,可以选择相册或拍照 success(res) { const tempFilePaths = res.apFilePaths; // 获取临时路径数组 console.log('已选择的图片路径:', tempFilePaths); // 进一步处理文件上传逻辑... }, fail(err) { console.error('选择图片失败:', err); } }); } ``` 注意:该方法仅限于图片文件的选择[^1]。 --- ##### 方法二:使用 `my.chooseFile` 选择任意类型文件 如果需要支持多种文件类型(如文档、音频、视频等),应优先考虑使用 `my.chooseFile` 方法。 代码示例: ```javascript function chooseFile() { my.chooseFile({ count: 1, // 最大可选文件数 type: 'all', // 文件类型,'image': 图片, 'video': 视频, 'audio': 音频, 'file': 文档, 'all': 所有类型 extension: ['.jpg', '.png', '.pdf', '.docx'], // 指定允许的文件扩展名 success(res) { const tempFiles = res.files; // 获取文件对象列表 console.log('已选择的文件信息:', tempFiles); // 提取第一个文件的相关属性 const file = tempFiles[0]; console.log(`文件名称: ${file.name}, 大小: ${file.size} 字节`); // 进一步处理文件上传逻辑... }, fail(err) { console.error('选择文件失败:', err); } }); } ``` 在此方法中,开发者可通过配置 `type` 参数来限定用户可选择的文件范围,同时还可以通过 `extension` 参数进一步筛选具体的文件扩展名[^2]。 --- #### 注意事项 1. **权限声明**:在使用上述方法前,请确保已在项目的 `manifest.json` 文件中正确配置了所需的权限。 - 对于访问相册或摄像头的操作,可能需要申请相应的敏感权限。 2. **兼容性测试**:由于不同版本的支付宝客户端可能存在行为差异,建议在多个版本上进行全面测试以验证功能稳定性。 3. **错误处理机制**:务必为每种可能出现的情况提供清晰的反馈提示,以便提升用户体验。 --- ### 总结说明 以上介绍了如何基于 UniApp 平台,在支付宝小程序环境中分别采用 `my.chooseImage` 和 `my.chooseFile` 方法实现文件选择器的唤起功能。前者专注于图片资源获取,后者则具备更强的泛用性和灵活性,可根据实际需求自由选用。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值