小程序发券插件

更新时间:2025.01.03

支持商户在小程序场景内,向指定用户发放指定批次的支付券或商家券。

接口说明

支持商户:普通商户

接口规则: 本接口使用V2版本接口规则,详见V2接口规则内容

小程序接入插件操作

插件版本号:latest

【推荐】如希望每次默认使用最新版本,可在App.json 文件配置"version": "latest";

注意:2.0.2以下插件版本将不再支持发券。请将插件版本号设置为“latest" 或当前最新版本,点击查看版本更新记录

1、添加插件配置(引入插件包)

在小程序配置App.json 文件中加入如下配置:

1{
2  "plugins": {
3    "sendCoupon": {
4      "version": "latest",
5      "provider": "wxf3f436ba9bd4be7b"
6    }
7  }
8}

2、在小程序页面中引入发券插件

1)在小程序页面配置文件中加入如下配置,引入send-coupon组件:

1{
2  "usingComponents": {
3    "send-coupon": "plugin://sendCoupon/send-coupon"
4  }
5}

2)在小程序页面的WXML模板中加入如下代码,并填入相关字段,字段说明参见下方小程序发券插件字段说明表

1//page.wxml
2<send-coupon
3    bind:sendcoupon="getcoupon"
4    bind:userconfirm="redirectuser"
5    send_coupon_params="{{send_coupon_params}}"
6    sign="{{sign}}"
7    send_coupon_merchant="{{send_coupon_merchant}}"
8    suggest_immediate_use="{{suggest_immediate_use}}"
9  >
10    <!-- 内部为自定义代码,按钮点击部分的代码写在这里 -->
11    <!-- [[以下为示例代码 -->
12    <view class="text">领券</view>
13    <!-- 以上为示例代码 ]] -->
14  </send-coupon>

小程序发券插件字段说明表

bind:sendcoupon / bindsendcoupon【原接口为bindcustomevent,建议更新原接口名称】选填 string

插件在用户点击后成功获取到优惠券信息触发的事件函数名称,使用方法可参考《自定义组件文档》的自定义组件触发事件
注意:查询到优惠券信息不代表用户一定能够看到优惠券弹窗或者发券成功,如果参数send_coupon_result中没有券发送成功(券状态码不为SUCCESS),用户会被告知领券失败


bind:userconfirm / binduserconfirm 选填 string

用户点击弹窗中的确认收券按钮后触发的事件函数名称,可用作跳转到优惠券的使用界面


suggest_immediate_use 选填 boolean

提示优惠券是否要立即使用,如果为true,弹窗中的确认按钮内的文字为“立即使用”,如果为false,则显示为“我知道了”,参数默认值为false
注意:此参数对用户是否立即使用没有约束力,需要商家在用户确认领券事件内自行约束。如果此参数设为true,请在binduserconfirm事件中引导用户使用优惠券


send_coupon_params 必填 array

发券参数,一次最多10张

数组

sign 必填 string(64)

签名计算值。
签名方式:HMAC-SHA256。
签名规则:详见《V2 签名规则》
参与签名字段说明


send_coupon_merchant 必填 string(15)

发券商户号

 

参与签名字段说明

注意

1、当存在发放一张或多张券的情况下,参数名使用下标表示,下标从0开始: 发放一张券示例值:out_request_no0=abc123&send_coupon_merchant=10016226&stock_id0=1234567&key=xxxxx

发放多张券示例值:out_request_no0=abc123&out_request_no1=123abc&send_coupon_merchant=10016226&stock_id0=1234567&stock_id1=2345678&key=xxxxx

2、当 批次是发放时指定code的类型的情况下: 发放一张券示例值:coupon_code0=asdsada&out_request_no0=abc123&send_coupon_merchant=10016226&stock_id0=1234567&key=xxxxx

发放多张券示例值:coupon_code0=asdsada&coupon_code1=asdsada&out_request_no0=abc123&out_request_no1=123abc&send_coupon_merchant=10016226&stock_id0=1234567&stock_id1=2345678&key=xxxxx

3、如果遇到签名失败,请按照下面几项进行检查

  1. 签名方式一定要用 HMAC-SHA256

  2. key需要使用APIv2的signkey,设置路径:【微信商户平台-->账户中心-->账户设置-->API安全-->设置API密钥】

  3. 确认key的正确性,例如是否是本商户号下的key

  4. 签名源串请按照示例参数格式进行拼接,参数顺序按照字典序排列

  5. 参数名严格区分大小写

  6. 更多规则详见《V2签名规则

send_coupon_merchant 必填 string(15)

发券商户号


stock_id{n} 必填 string(20)

微信支付券批次ID,{n}为下标,从0开始,例如stock_id0


out_request_no{n} 必填 string(64)

发券凭证,{n}为下标,从0开始,例如out_request_no0。可包含英文字母,数字,|,_,*,-等内容,不允许出现其他不合法符号,需在单个批次单个用户下确保唯一性


coupon_code{n} 选填 string(128)

券code,如果批次是发放时指定code的类型,则发券时必填coupon_code{n}为下标,从0开始,例如stock_id0


customize_send_time 选填 string(32)

商家券在商户业务系统里的实际领取时间,仅针对有设置相对领取时间的批次生效(即批次有设置“生效后N天内有效”或“领取后N天开始生效”时间字段)。传入后,将使用传入的时间点,做为商家券领取时间来计算有效期,而非用户在微信支付系统中点击领取的时间 。
遵循rfc3339标准格式,格式为yyyy-MM-DDTHH:mm:ss+TIMEZONE,yyyy-MM-DD表示年月日,T出现在字符串中,表示time元素的开头,HH:mm:ss表示时分秒,TIMEZONE表示时区(+08:00表示东八区时间,领先UTC 8小时,即北京时间)。例如:2015-05-20T13:29:35.+08:00表示,北京时间2015年5月20日 13点29分35秒。
目前只支持商家券、支付券暂不支持


create_coupon_merchant{n} 选填 string(15)

创建支付券的商户号; {n}为下标,从0开始,例如create_coupon_merchant0。 如果是支付券,则是必填项; 商家券无需填写

 

3、在小程序页面对应的JS逻辑中,获取插件实例并执行初始化操作

1javascript
2//page.js
3Page({
4  // 此函数名称可以自定义,跟bindcustomevent绑定的保持一致
5  getcoupon: function(params) {
6    // 插件返回信息在params.detail
7    console.log('getcoupon', params)
8  }
9})

如果事件绑定正确,在用户点击领券后,会触发领券事件,得到返回之后会调用getcoupon函数。

返回处理

从回调函数参数detail中,获取参数。

errcode 必填 string(32)

返回整体错误码


msg 必填 string(128)

返回整体错误信息


send_coupon_result 必填 object

发券结果,包含需要发放的每张券的结果信息,是否成功或失败原因

属性

 

返回示例

1javascript
2//获取代码示例
3Page({
4  data: {
5    // ...
6  },
7  onLoad: function() {
8    // ...
9  },
10  getcoupon: function(params) {
11    console.log('getcoupon', params)
12    console.log('detail', params.detail)
13  }
14})

错误码

Detail中errcode返回错误码

错误码

描述

解决方案

OK

调用成功

接口调用成功,具体发券结果(是否发券成功)需查看发券结果(send_coupon_result)中的参数

PARAM_ERROR

参数错误

参数错误,请开发者查看msg中具体的错误信息并进行修复处理

USER_NOT_EXISTS

登录态获取失效

引导用户重试

USER_GET_FAILED

登录态获取失败

报错,提示用户稍后操作

SIGN_ERROR

签名错误

请开发者检查签名正确性

SYSTEMERROR

发券超时

提示报错,提示用户稍后操作

FREQUENCY_LIMITED

发券频率过高

提示报错,引导用户稍后操作。例如“活动太过火爆,请稍后再领取

SYSTEMERROR

插件版本过低

当前小程序发券插件版本过低,请更新至2.0.2以上版本

发券结果(send_coupon_result)中的错误码

错误码

描述

解决方案

SUCCESS

该张券发券成功

提示用户领取成功/改变前端领券按钮状态

FAILED

该张券发券失败,查看message中的具体错误信息

提示用户领券失败,请开发者查看message中具体的错误信息并进行修复处理

NOTENOUGH

总预算用完

提示用户领券失败,请增加批次预算

DAYLIMIT

用户达到单天限领

提示用户领券失败,如需继续发放,可调整该批次单天发放上限

NATURELIMIT

用户自然人限领

提示用户领券失败,可提示用户检查其所有微信号领券情况,并请商户留意刷单风险

MAXQUOTA

用户领取张数达到上限

提示用户领券失败,该用户领取数量已达上限

DUPREQUEST

已通过该发券凭证给用户发券

提示用户领取成功/改变前端领券按钮状态

NOTRUNNING

批次状态非运营中

提示用户领券失败,并检查批次状态
如果批次是暂停状态,需重启后方可发放
如果批次已过期,请更换批次

EXPIRED

该批次已过期

请更换在有效期内的批次,再进行发放

NOTMONEY

账户余额不足

请检查批次号是否正确

USERLIMIT

用户已超限领额度

提示用户已超限领额度

FREQUENCYLIMIT

超过频率限制

可稍后重试

USERREJECT

用户主动拒绝领取

根据用户领取结果改变前端领券按钮状态