支付宝小程序向用户发红包的实现方法
程序员文章站
2024-01-18 22:45:16
1. 介绍目的:公司的支付宝小程序向指定用户发送红包。场景:积分兑换、邀请注册。2.开通权限2.1开通服务说明:进入支付宝商家中心 → 营销工具 → 营销活动送红包备注:秘钥选择pkcs8。入口:ht...
1. 介绍
目的:公司的支付宝小程序向指定用户发送红包。
场景:积分兑换、邀请注册。
2.开通权限
2.1开通服务
说明:进入支付宝商家中心 → 营销工具 → 营销活动送红包
备注:秘钥选择pkcs8。
入口:https://b.alipay.com/signing/productsetv2.htm
2.2查看应用
说明:申请通过后,进入app管理界面可找到通过后的应用。
入口:https://openhome.alipay.com/platform/appmanage.htm
2.3设置秘钥
说明:点击应用列表的[查看详情]。进入应用信息,设置加密方式。
备注:在这里我们将使用签名算法类型为'rsa2' 和 'pkcs8' 。(根据自身的sdk进行设置)。
文档:
3.开发操作
创建并配置好应用后,就可以进行开发了,支付宝红包发送到用户手上只需要两步:
①创建现金(红包)活动:比如创建100个1元红包的活动。
②发送红包给用户:根据活动id、用户openid,将红包发送给用户。
3.1创建现金活动
说明:要想把红包发给用户,首先得创建一个现金(红包活动)。
文档:
示例:在这里创建了每个2元金额的红包活动,共20元、10个包。
/** * 创建现金红包 * @param {alipaycashhbentity} en 实体对象 * @see https://docs.open.alipay.com/api_5/alipay.marketing.campaign.cash.create */ async createcashhb(en) { let alipaysdk = this._getalipaysdk(); try { const rs = await alipaysdk.exec('alipay.marketing.campaign.cash.create', { bizcontent: { couponname: en.couponname, prizetype: en.prizetype, totalmoney: en.totalmoney, totalnum: en.totalnum, prizemsg: en.couponname, starttime: en.starttime, endtime: en.endtime, merchantlink: en.merchantlink, sendfreqency: `l${en.sendfreqency}` } }); if (rs.code != '10000') { throw new error(rs.submsg); } else { return rs; } } catch (err) { throw err; } }
3.2发送红包给用户
说明:创建完红包活动后,就可以把红包发送给用户。
文档:
注意:发送的红包金额会转入用户的【余额】里。
/** * 发送现金红包 * @param {string} crowdno 红包编号 * @param {string} alipayuseropenid 支付宝用户openid * @param {string} productexchangeid 兑换记录id * @see https://docs.open.alipay.com/api_5/alipay.marketing.campaign.cash.trigger */ async sendcashhb(crowdno, alipayuseropenid, productexchangeid) { let alipaysdk = this._getalipaysdk(); try { const rs = await alipaysdk.exec('alipay.marketing.campaign.cash.trigger', { bizcontent: { user_id: alipayuseropenid, crowd_no: crowdno, out_biz_no: productexchangeid } }); if (rs.code != '10000') { throw new error(rs.submsg); } else { return rs; } } catch (err) { throw err; } }
到此这篇关于支付宝小程序向用户发红包的实现方法的文章就介绍到这了,更多相关支付宝小程序发红包内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!
上一篇: CSS3 实现倒计时效果