asp.net开发微信派发现金红包/H5网页抢红包功能(思路详解)
程序员文章站
2022-03-24 08:28:52
临近节日,公司里为了给广大老客户赠福利,以及来一波拉新活动:搞了一个营销活动,大概活动规则如下:1、老客户通过网页抢红包,中奖会派发微信支付的红包;2、新客户只要关注后就可以中奖,持续关注x天后再派发...
临近节日,公司里为了给广大老客户赠福利,以及来一波拉新活动:搞了一个营销活动,大概活动规则如下:
1、老客户通过网页抢红包,中奖会派发微信支付的红包;
2、新客户只要关注后就可以中奖,持续关注x天后再派发红包(防止撸羊毛,关注后立马取关)。
开发的思路分析:
一、网页版抢红包功能,
1、前端先做好抢红包的页面;
3、后台配置微信公众号的appid,appsecret等和 微信支付商户的mch_id,key,证书等;
3、后端使用微信公众号里的网页授权功能,用户在打开h5网页的时候,拿到openid;
4、根据设置的活动时间范围,红包金额等限制,判断是否可以抢红包;
5、抢红包符合规则,则将openid存入数据库;提示用户抢到红包了。
6、根据openid来派发红包;
核心代码如下:
using senparc.weixin.mp.tenpaylibv3; string certpath = httpcontext.current.server.mappath(weixinpaymodel.certinfopath); // @"f:\apiclient_cert.p12"; sendnormalredpackresult = redpackapi.sendnormalredpack( weixinmodel.appid, weixinpaymodel.mch_id, weixinpaymodel.paykey, certpath, //证书物理地址 openid, //接受收红包的用户的openid actmodel.send_name, //红包发送者名称 "147.114.50.74", //ip hbmoney, //付款金额,单位分 actmodel.wishing, //红包祝福语 actmodel.act_name, //活动名称 actmodel.remark, //备注信息 out noncestr, out paysign, null, //场景id(非必填) null, //活动信息(非必填) null //资金授权商户号,服务商替特约商户发放时使用(非必填) );
代码里,我们用到senparc这个第3方开源组件,可以非常方便的开发红包功能。
二、关注红包:
通过关注时候触发的事件,拿到openid,在根据活动限制判断是否中奖;中奖后,提示用户活动红包;
核心代码如下:
using senparc.weixin.mp.entities; using senparc.weixin.mp.helpers; using senparc.weixin.mp.messagehandlers; /// <summary> /// 订阅(关注)事件 /// </summary> /// <returns></returns> public override iresponsemessagebase onevent_subscriberequest(requestmessageevent_subscribe requestmessage) { int apiid = wxcomm.getapiid(); //------印美图接口 begin------ //threeinterface.weipaiinterface wxcf = new threeinterface.weipaiinterface(); //wxcf.weipaisubscribe(requestmessage.fromusername, apiid); //------印美图接口 end------ xjhongbao xjmgr = new xjhongbao(); string gethongbaoret= xjmgr.subscribehongbao(requestmessage.fromusername, apiid); if(string.isnullorwhitespace( gethongbaoret)) { return eventprocess(6, requestmessage); } else { return eventprocess(100, requestmessage, gethongbaoret); } }
也用到了senparc这个开源组件,其实相对比较简单。
到此这篇关于asp.net开发微信派发现金红包/h5网页抢红包功能的文章就介绍到这了,更多相关asp.net 微信派发现金红包内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!