☹.背景-小程序开发的过程中,绝大多数会满足微信支付-那么,作为友好交互的体现,自然就会考虑到支付后的消息通知咯-所以,我的小程序项目也要求完成这个效果,so.分享一下自己的实现步骤,以方便道友们少踩点坑...微信消息通知的区别:1.微信网页版、公众号的消息提醒要求用户必须"关注商家公众号",才支持消息的接收并且还有个奇怪的毛病:如果近期内未与该公众号有所交流,依然收不到消息提醒再者,消息的样式需代码进行自定义(麻烦)2.微信小程序,可支持"服务通知"只需配置好自己的"模板消息",通过获取用户的"openid"即可进行来自微信服务的消息通知的样式,可在小程序的管理后台进行选取,预览(人性化)此处参考京东购物的消息通知如下(也就是在下想要实现的效果):❶前期准备1.①.首先,微信小程序官方文档为我们提供了指导—【发送模板消息】
2.我们可以先对文档进行一遍简单的浏览,以方便自己的流程理解,避免蒙头苍蝇乱撞
3.②.小程序给与了我们最方便的手动模板配置方式
我们可以先去1(模板库)中选取自己需要的模板,自定义标题、排序申请成功之后,进入2(我的模板)中就可以看到自己能够使用的模板,我们后期进行代码编辑时,用到的就是那个模板ID❷实现步骤4.此处,主要以form/组件形式的实现为例,对于prepay_id的实现请参考文末的附录
1.小程序端的要求5.语境:微信支付成功后,对用户发送一条"订单支付成功通知"的模板消息
6.第一步:以我的代码实现为例,首先需要对我的form/组件进行需发模板消息的声明,即设置属性report-submit"true"(【个人建议,请使用真机测试,不排除部分使用开发工具无法获取form_id的情况】)
7.第二步:对应的pages/cart/payment.js代码中,编写的提交代码,以及对event参数打印的结果则为:
8.注意:截图部分只是为了,获取并保存我们需要的formId
-其实,后面的代码还可以有很多的逻辑处理,以我的代码逻辑为例:-我继续进行了表单数据的规范验证-wx.request数据提交-唤醒微信支付-支付结果的回调处理第三步:request调用发送消息通知的方法9.以我的逻辑为例,是在执行完微信支付回调后,判断支付成功才进行调用的
10.此处,直接提供上述截图中pages/cart/payment.js所需要用到的两个核心方法
/***微信支付成功后的消息模板的发送*/sendTemplatePaySuccess:function(){varselfthis;varpostData{sn:self.data.order_sn,form_id:self.data.formId};self.http_post('https://xxx.com/wx/sendTemplatePaySuccess',postData,(data){wx.navigateTo({url:'/pages/cart/results/index?status1typepayorderInfo'+JSON.stringify(self.data.orderInfo),});})},/***封装http函数,默认‘GET’提交*/http_post:function(toUrl,postData,httpCallBack){wx.request({url:toUrl,data:postData,method:'POST',//OPTIONS,GET,HEAD,POST,PUT,DELETE,TRACE,CONNECTheader:{'content-type':'application/x-www-form-urlencoded;charsetutf-8',},success:function(res){//回调处理returntypeofhttpCallBack"function"httpCallBack(res.data);},fail:function(error){console.log(error);}})},2.服务端代码配置11.我对服务端的代码,整合集中在了一个文件中,可从附录中进行下载
12.第一步:替换小程序配置信息
13.第二步:修改方法sendTemplatePaySuccess()
14.提示:
1.此方法是对应于pages/cart/payment.js中的"Https://xxx.com/wx/sendTemplatePaySuccess",应该不会理解错吧!2.一般的设计逻辑,是在用户注册、初次授权登录的时候就将其openid写到数据库中,后期使用时可随时调用3.如果前期没有写入数据库,也可以考虑直接授权获取,参考文章[【微信小程序Ⅴ[获取登录用户信息,重点openID(详解)】]](https://blog.csdn.net/u011415782/article/details/79559639)4.template_id直接在小程序账号后台复制即可,但是请将$rawPost['data']['keyword?']['value']顺序对应正确哦❸运行测试①.首先,要特别注意一点,不可以使用微信开发者工具进行测试,不然会有如下报错:15.可参考道友解释:小程序表单formId为theformIdisamockone
②.并且,如果已经发送过一次模板消息,会有如下提示信息://#这说明,你的formid已经用过了,系统要求只能使用一次!!!{"status":0,"result":"sendTemplatePaySuccessFailed!","data":{"errcode":41029,"errmsg":"formidusedcountreachlimithint:[9mUwja01342277]"}}❹附录A.补充信息开发文档中有这样一句话:值得注意:第一点:使用"form/"组件获得的"formId"只能使用一次相对适合的通知业务——支付成功或失败后,充值成功、续费成功、挂号成功等被动响应的信息...第二点:"prepay_id"只有进行了支付行为才能获得,并且必须支付成功!一个"prepay_id"可以使用三次相对适合的通知业务有——后台发货提醒、审核通知、课程开班提醒、拼团成功通知等主动推送的信息...第三点:prepay_id使用时的报错信息://#如果支付不成功,但是要使用获得的prepay_id,会有如下类似的信息{"data":{"errcode":41028,"errmsg":"invalidformidhint:[XiZ04574125]"}}//#如果支付成功,使用获得的prepay_id次数超过了三次,会有如下的信息:{"data":{"errcode":41029,"errmsg":"formidusedcountreachlimithint:[oFN1Aa08963936]"}}B.后台发货通知的设计思路1.首先,我们在数据表设计时,对于订单表需要有一个存储微信支付后"prepay_id"的存储字段2.进行微信支付时,将生成的"prepay_id"存到数据表中3.当对已支付订单进行后台发货操作时,调用的通知模板,使用前面数据表中的"prepay_id"数据4.其他的服务端代码设计同上文中的"sendTemplatePaySuccess()"方法温馨提示:16.毕竟存放的"prepay_id"最多只用使用三次,所以对于项目设计中的使用位置要做好规划!!!
C.使用真机测试,顺利运行的效果为:D.Access_Token建议17.官方文档-获取access_token
代码中,所必须涉及到的业务——access_token的获取,请参考文档介绍,进行定时刷新,以避免不必要的资源请求个人的思路就是,创建数据表字段,根据其返回的时长expires_in,在失效前保存数据access_token可根据自己的实际需求,优化小编提供的opGetAccessToken()方法!有一点,或许很多人不多加注意:当项目已上线,如果你线下依旧测试使用了获取"access_token"的操作,这会影响线上服务的!因为,一旦重新获取了"access_token"信息,微信服务器便会在短时间内,对之前的"access_token"进行失效处理建议,可以考虑在线下直接使用线上获得的"access_token",不要随意去刷新请求获取,影响大局就尴尬了...❺.源代码参考请对应代码进行正确配置哦CSDN下载地址GitHub下载地址
小程序发送模板消息的功能实现-小程序编写流程-开发小程序的流程
浏览量:2512
时间:
来源:moTzxx
版权声明
即速应用倡导尊重与保护知识产权。如发现本站文章存在版权问题,烦请提供版权疑问、身份证明、版权证明、联系方式等发邮件至197452366@qq.com ,我们将及时处理。本站文章仅作分享交流用途,作者观点不等同于即速应用观点。用户与作者的任何交易与本站无关,请知悉。
最新资讯
-

即速应用,赋能企业玩转微信小程序智慧经营
作为国内领军的智慧商业经营服务商,即速应用始终秉承“让每个企业都拥有自己的智慧店铺”的愿景,持续赋能更多企业玩转智慧经营。即速应用旗下拥有“小程序搭建工具-即速应用”、“私域流量专家-即客云”等产品,帮助商家打通互联网全生态营销闭环。 -

即客云2.0重磅更新,让微信小程序运营更简单!
即客云作为一款基于企业微信的第三方工具,现从多维度提供超过30种功能,自上线以来,已服务多家企业,受到一致好评。近期,我们根据客户反馈和市场调研正式推出升级版 即客云2.0!更新了私域运营SOP,群日历功能,批量拓客,客户雷达,消息推送,个人欢迎语,帮助企业更好运用企业微信;同时提升了社群运营工作标准化,提升运营效率,帮助企业实现客户增长,玩转私域流量。 -

零代码 + AI 双轮驱动|即速应用解锁人工智能小程序开发新范式
无需代码、无需 AI 算法功底,普通人也能快速搭建智能小程序。即速应用将人工智能与零代码开发深度融合,推出 AI 智能生成能力,用户通过自然语言描述需求,AI 自动生成小程序页面、功能模块与后台配置,覆盖商城、预约、同城、社区团购等全场景。平台内置 AI 智能推荐、智能客服、用户画像分析等能力,一键对接微信生态,打通视频号、企业微信、短信跳转,帮企业快速落地 AI 应用,抢占智慧经营先机,让每家企业都拥有 AI 驱动的智慧店铺。










