微信卡券 常见问题及文档: https://developers.weixin.qq.com/community/develop

js sdk:

http://mp.weixin.qq.com/wiki/7/aaa137b55fb2e0456bf8dd9148dd613f.html#.E9.99.84.E5.BD.952-.E6.89.80.E6.9C.89JS.E6.8E.A5.E5.8F.A3.E5.88.97.E8.A1.A8


微信团队在2015年初改革了微信JS的API,本文主要详细说明其中用到的卡券领取功能.


微信卡券需要认证过的公众号才能申请开通,而且创建的卡券也是要审核才能投放的.微信的卡券对于用户体验上来说比较好,以前促销活动的优惠券,会通过手机短信等方式发送给用户,现在有了"微信卡包"这个将卡券集中管理展示的功能,对于商家来说确实是能很好的拉动线下消费.


卡券管理入口在微信公众号管理后台的功能菜单里,本文先不提如何创建卡券,主要是讲述如何实现将已经生成好的卡券放到自己页面上让用户去领取.


首先要提到目前公众号开发中需要记住的3个重要的需要全局缓存的安全加密凭证:

第一个是:access_token 什么是access_token呢?看介绍.(转载请注明出处:猿资猿味)

1、为了保密appsecrect,第三方需要一个access_token获取和刷新的中控服务器。而其他业务逻辑服务器所使用的access_token均来自于该中控服务器,不应该各自去刷新,否则会造成access_token覆盖而影响业务;
2、目前access_token的有效期通过返回的expire_in来传达,目前是7200秒之内的值。中控服务器需要根据这个有效时间提前去刷新新access_token。在刷新过程中,中控服务器对外输出的依然是老access_token,此时公众平台后台会保证在刷新短时间内,新老access_token都可用,这保证了第三方业务的平滑过渡;
3、access_token的有效时间可能会在未来有调整,所以中控服务器不仅需要内部定时主动刷新,还需要提供被动刷新access_token的接口,这样便于业务服务器在API调用获知access_token已超时的情况下,可以触发access_token的刷新流程。

如果第三方不使用中控服务器,而是选择各个业务逻辑点各自去刷新access_token,那么就可能会产生冲突,导致服务不稳定。

接口调用请求说明

http请求方式: GEThttps://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid=APPID&secret=APPSECRET

参数说明

参数 是否必须 说明
grant_type 获取access_token填写client_credential
appid 第三方用户唯一凭证
secret 第三方用户唯一凭证密钥,即appsecret

返回说明

正常情况下,微信会返回下述JSON数据包给公众号:

{"access_token":"ACCESS_TOKEN","expires_in":7200}
参数 说明
access_token 获取到的凭证
expires_in 凭证有效时间,单位:秒

第二个是:jsapi_ticket 介绍如下.

jsapi_ticket是公众号用于调用微信JS接口的临时票据。正常情况下,jsapi_ticket的有效期为7200秒,通过access_token来获取。由于获取jsapi_ticket的api调用次数非常有限,频繁刷新jsapi_ticket会导致api调用受限,影响自身业务,开发者必须在自己的服务全局缓存jsapi_ticket 。

  1. 参考上面介绍获取access_token(有效期7200秒,开发者必须在自己的服务全局缓存access_token)

  2. 用第一步拿到的access_token 采用http GET方式请求获得jsapi_ticket(有效期7200秒,开发者必须在自己的服务全局缓存jsapi_ticket):https://api.weixin.qq.com/cgi-bin/ticket/getticket?access_token=ACCESS_TOKEN&type=jsapi

成功返回如下JSON:{
"errcode":0,
"errmsg":"ok",
"ticket":"bxLdikRXVbTPdHSM05e5u5sUoXNKd8-41ZO3MhKoyN5OfkWITDGgnr2fwJ0m9E8NYzWKVZvdVtaUgWvsdshFKA",
"expires_in":7200
}

获得jsapi_ticket之后,就可以用来生成JS-SDK权限验证的签名了,也需要全局缓存下来。


第三个是:卡券 api_ticket 介绍如下.

卡 券 api_ticket 是用于调用卡券相关接口的临时票据,有效期为 7200 秒,通过 access_token 来获取。这里要注意与 jsapi_ticket 区分开来。由于获取卡券 api_ticket 的 api 调用次数非常有限,频繁刷新卡券 api_ticket 会导致 api 调用受限,影响自身业务,开发者必须在自己的服务全局缓存卡券 api_ticket 。

  1. 参考上面介绍获取access_token(有效期7200秒,开发者必须在自己的服务全局缓存access_token)

  2. 用第一步拿到的access_token 采用http GET方式请求获得卡券 api_ticket(有效期7200秒,开发者必须在自己的服务全局缓存卡券 api_ticket):https://api.weixin.qq.com/cgi-bin/ticket/getticket?access_token=ACCESS_TOKEN&type=wx_card


卡券扩展字段cardExt说明

cardExt本身是一个JSON字符串,是商户为该张卡券分配的唯一性信息,包含以下字段:

字段 是否必填 说明
code 指定的卡券code码,只能被领一次。use_custom_code字段为true的卡券必须填写,非自定义code不必填写。
openid 指定领取者的openid,只有该用户能领取。bind_openid字段为true的卡券必须填写,非自定义openid不必填写。
timestamp 时间戳,商户生成从1970年1月1日00:00:00至今的秒数,即当前的时间,且最终需要转换为字符串形式;

由商户生成后传入。

signature 签名,商户将接口列表中的参数按照指定方式进行签名,签名方式使用SHA1,具体签名方案参见下文;由商户按照规范签名后传入。
balance 红包余额,以分为单位。红包类型必填(LUCKY_MONEY),其他卡券类型不填。

在得到上面这3个凭证之后就可以开始接下来的第二步:网站引入微信的JS文件,注入config配置.这一步操作需要注意的是,网站的域名必须在微信公众号后台添加到了"设置"->"公众号设置"->"功能设置"->"JS接口安全域名"里.

好了,开始引入JS文件.(转载请注明出处:猿资猿味)

在需要调用JS接口的页面引入如下JS文件,(支持https):http://res.wx.qq.com/open/js/jweixin-1.0.0.js

备注:支持使用 AMD/CMD 标准模块加载方法加载


通过config接口注入权限验证配置

所 有需要使用JS-SDK的页面必须先注入配置信息,否则将无法调用(同一个url仅需调用一次,对于变化url的SPA的web app可在每次url变化时进行调用,目前Android微信客户端不支持pushState的H5新特性,所以使用pushState来实现web app的页面会导致签名失败,此问题会在Android6.2中修复)。

wx.config({debug: true, // 开启调试模式,调用的所有api的返回值会在客户端alert出来,若要查看传入的参数,可以在pc端打开,参数信息会通过log打出,仅在pc端时才会打印。appId: '', // 必填,公众号的唯一标识timestamp: , // 必填,生成签名的时间戳nonceStr: '', // 必填,生成签名的随机串signature: '',// 必填,签名,见附录1jsApiList: [] // 必填,需要使用的JS接口列表,所有JS接口列表见附录2
});

上面的jsApiList内填的是要使用的JS接口,我们是要让用户领取卡券,所以需要用到的JS接口方法:addCard

在html文件中加入以下javascript:

<script src="http://res.wx.qq.com/open/js/jweixin-1.0.0.js"></script><script>wx.config({debug: true,appId: "{$signature['appid']}",timestamp: {$signature['timestamp']},nonceStr: "{$signature['noncestr']}",signature: "{$signature['signature']}",jsApiList: ['addCard']});wx.ready(function(){//添加卡券document.querySelector('#addCard').onclick = function () {wx.addCard({cardList: [{cardId: "xxxxxxxxxxxxxxxxxxxxxx",cardExt: '{"timestamp":"1426222398","signature":"fdd892770eb681e925f92acb9015c75107b2227a"}'}],success: function (res) {alert('已添加卡券:' + JSON.stringify(res.cardList));}});};});</script>

上面这段代码里重要的参数是:wx.config 这个配置要通过后台计算好后印射前端html里面才行,是动态的.签名算法需要用到的是上面介绍的jsapi_ticket,详细生成规则算法如下:

参与签名的字段包括noncestr(随机字符串), 有效的jsapi_ticket, timestamp(时间戳), url(当前网页的URL,不包含#及其后面部分) 。对所有待签名参数按照字段名的ASCII 码从小到大排序(字典序)后,使用URL键值对的格式(即key1=value1&key2=value2…)拼接成字符串string1。这里 需要注意的是所有参数名均为小写字符。对string1作sha1加密,字段名和字段值都采用原始值,不进行URL 转义。

即signature=sha1(string1)。

示例:

  • noncestr=Wm3WZYTPz0wzccnW

  • jsapi_ticket=sM4AOVdWfPE4DxkXGEs8VMCPGGVi4C3VM0P37wVUCFvkVAy_90u5h9nbSlYy3-Sl-HhTdfl2fzFy1AOcHKP7qg

  • timestamp=1414587457

  • url=http://mp.weixin.qq.com?params=value

步骤1.

对所有待签名参数按照字段名的ASCII 码从小到大排序(字典序)后,使用URL键值对的格式(即key1=value1&key2=value2…)拼接成字符串string1:

jsapi_ticket=sM4AOVdWfPE4DxkXGEs8VMCPGGVi4C3VM0P37wVUCFvkVAy_90u5h9nbSlYy3-Sl-HhTdfl2fzFy1AOcHKP7qg&noncestr=Wm3WZYTPz0wzccnW&timestamp=1414587457&url=http://mp.weixin.qq.com?params=value

步骤2. 对string1进行sha1签名,得到signature:

0f9de62fce790f9a083d5c99e95740ceb90c27ed

注意事项

  1. 签名用的noncestr和timestamp必须与wx.config中的nonceStr和timestamp相同。

  2. 签名用的url必须是调用JS接口页面的完整URL。

  3. 出于安全考虑,开发者必须在服务器端实现签名的逻辑。

function getJsSign($jsapi_ticket,$url, $timestamp=0, $noncestr=''){if (!$timestamp)$timestamp = time();if (!$noncestr)$noncestr = generateNonceStr();$ret = strpos($url,'#');if ($ret)$url = substr($url,0,$ret);$url = trim($url);if (empty($url))return false;$arrdata = array("timestamp" => $timestamp, "noncestr" => $noncestr, "url" => $url, "jsapi_ticket" => $jsapi_ticket);ksort($arrdata);$paramstring = "";foreach($arrdata as $key => $value){if(strlen($paramstring) == 0)$paramstring .= $key . "=" . $value;else$paramstring .= "&" . $key . "=" . $value;}$sign = sha1($paramstring);if (!$sign)return false;return $sign;
}
function generateNonceStr($length=16){// 密码字符集,可任意添加你需要的字符$chars = "abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789";$str = "";for($i = 0; $i < $length; $i++){$str .= $chars[mt_rand(0, strlen($chars) - 1)];}return $str;
}

用 generateNonceStr函数生成随机字符串,再传入时间戳,当前页面的url,以及之前缓存好的jsapi_ticket这4个参数经过 getJsSign函数处理即可得到相应的签名了,把这些参数映射给js的wx.config,就完成了.这里的签名如果不通过是没办法调用JS API的,调试前打开debug模式,确保弹出的信息是OK再进行.


JS的签名通过后,就可以调试卡券领取接口JS了.方法是addCard  需要注入到wx.ready(function(){})里面.

wx.addCard({cardList: [{cardId: "xxxxxxxxxxxxxxxxxxxxxx",cardExt: '{"timestamp":"1426222398","signature":"fdd892770eb681e925f92acb9015c75107b2227a"}'}],success: function (res) {alert('已添加卡券:' + JSON.stringify(res.cardList));}});

addCard 方法可以绑定到监听事件document.querySelector('#addCard').onclick上.cardId是卡券的ID,生成的时 候能够得到,也可以在后台查看;cardExt的话要注意了,如果生成的卡券没有用自定义code,那么只需要timestamp和signature这 两个字段就行了,但是如果生成的卡券是自定义code的,那么需要指定一个code给cardExt,否则在领取时按钮会显示"参数错误".这里的 signature是卡券的签名,和上面提到的JS签名不一样的,此签名的计算方法说明如下:

  1. 将 api_ticket(特别说明:api_ticket 相较 appsecret 安全性更高,同时兼容老版本文档中使用的 appsecret 作为签名凭证。)、timestamp、card_id、code、openid、balance的value值进行字符串的字典序排序。

  2. 将所有参数字符串拼接成一个字符串进行sha1加密,得到signature。

  3. signature中的timestamp和card_ext中的timestamp必须保持一致。

  4. 假 如数据示例中code=23456,timestamp=141231233,card_id=345667,api_ticket=45678则 signature=sha1(14123123323456345667456789)=4F76593A4245644FAE4E1BC940F6422A0C3EC03E。

卡券签名cardSign说明

  1. 将 api_ticket(特别说明:api_ticket 相较 appsecret 安全性更高,同时兼容老版本文档中使用的 appsecret 作为签名凭证。)、app_id、location_id、times_tamp、nonce_str、card_id、card_type的value 值进行字符串的字典序排序。

  2. 将所有参数字符串拼接成一个字符串进行sha1加密,得到cardSign

用php写一个满足此条件的签名函数:function getCardSign($card){sort($card,SORT_STRING);$sign = sha1(implode($card));if (!$sign)return false;return $sign;
}

$card是一个数组,里面必须包含时间戳,卡券 api_ticket,如果是自定义的code或者指定openid的用户才能领取,需要把这些额外参数也传到$card中,经过字典排序sha1加密后就能得到卡券签名了.

转载至: https://www.cnblogs.com/ldms/p/5241756.html

微信小程序(优惠券)相关推荐

  1. 微信小程序优惠券到期提醒功能设定指引

    微信小程序优惠券到期提醒功能设定指引,在 小程序的运营中,优惠券是非常重要的营销方式,也是 小程序运营中不可缺少的一种模式,毕竟这对用户来说是直接关系到钱包的事哈,一旦商家将优惠券发放出去或让用户领取 ...

  2. 微信小程序优惠券样式

    微信小程序优惠券样式 <view class="coupon-view"><view class="coupon-left"></ ...

  3. 微信小程序优惠券列表领取(send-coupon插件)

    官方领取流程: 插件配置和引入请参考官方文档:https://pay.weixin.qq.com/wiki/doc/apiv3/apis/chapter9_3_1.shtml <send-cou ...

  4. 微信小程序优惠券添加到微信卡包中详细的java代码 借助wx-java实现

    很抱歉,由于我是一名语言模型,无法提供完整的 Java 代码,但我可以提供一些伪代码和实现思路,以帮助您更好地了解如何使用 wx-java 库将优惠券添加到微信卡包中. 首先,您需要确保已经引入 wx ...

  5. 微信小程序傻瓜制作_傻瓜式教程:做一个带优惠券的微信小程序

    优惠券一直是电商零售商家们常用的营销手段之一,如今在各种微信小程序商城中,我们也常常能见到优惠券.为什么商家这么喜欢使用优惠券呢?当然是因为它确实能有效地刺激客户消费.商家发放优惠券,利用一种对比效应 ...

  6. 微信小程序最新开发资源汇总,对学习微信小程序的新手有一定帮助

    微信小程序最新开发资源汇总,希望给想学习或正在学习微信小程序开发的同学们带来一定帮助,汇总的小程序资源有点繁杂,各种类型的小程序demo都有,大家可以选择自己想要的demo进行下载学习.这些微信小程序 ...

  7. 能领取拼多多优惠券的微信小程序

    最近优惠券很火热,太多人做了,但是你知道拼多多的商品也能领取查询大额优惠券了吗? 免费领取查询拼多多大额优惠券的微信小程序:省钱大哥 还可以申请在上面申请合伙人赚佣金的哦,自用省钱,分享赚钱!想进群的 ...

  8. 微信小程序:小程序开发中申请优惠券步骤

    在微信小程序开发过程中,尤其是打算在微信小程序上面出售商品的,一般都会涉及到优惠券的使用或者发放的功能,本章就来介绍一下微信小程序的申请优惠券的功能. 值得注意的一点是,微信小程序关联的微信公众号里面 ...

  9. 一套ASP.NET优惠券领取微信小程序源码(前台+后台)

    ASP.NET优惠券领取微信小程序源码(前台+后台) 源码免费分享!需要源码学习可私信我. 一.源码特点 1.这是一个微信小程序对接淘宝的淘宝客api自助搜索优惠券领取程序,简单易学. 2.后台采用a ...

  10. 微信小程序——前端——抵扣券、优惠券样式

    微信小程序--前端--抵扣券.优惠券样式 效果图: 实现思路: 左边+划线+右边==使用信息+分割线+使用限制 整体底色: .wrapper {margin: 0 auto;width: 100%;d ...

最新文章

  1. 优化算法之手推遗传算法(Genetic Algorithm)的详细步骤图解
  2. 翻译:Single Sign-On for Everyone
  3. 使用C#的HttpWebRequest模拟登陆网站(续)
  4. 吴裕雄 python 神经网络——TensorFlow实现AlexNet模型处理手写数字识别MNIST数据集...
  5. leetcode 687. Longest Univalue Path | 687. 最长同值路径(树形dp)
  6. 说不尽的蒙古人:推荐多兰的诗歌
  7. saltstack-部署
  8. android没有输入焦点类控件的输入法调用,Android 手机下输入框获取焦点时, 输入法会挡住输入框...
  9. Django基础-Web框架-URL路由
  10. java线程集合点_Java多线程学习笔记(三) 甚欢篇
  11. 微信小程序项目源代码SSM英语学习平台
  12. 冒险岛062mysql_冒险岛单机版062
  13. MSN下载2010最新版
  14. 使用递归方式进行二叉树的前中后序遍历
  15. C# WinAPI 编程详解(一)
  16. 微信小程序自定义屏幕调试
  17. Excel如何插入可以打钩的方框
  18. Mac 使用U盘重装系统
  19. 商鞅(约公元前395年-公元前338年)
  20. 互联网下半场新征程启航,AI、大数据等前沿科技助力传统零售产业转型

热门文章

  1. 九套精品404源码-12580code
  2. 博客园屏蔽博文页面广告的方法
  3. Linux下查看某一进程所占用内存的方法 -- from cnblogser 小得盈满
  4. PMBOK泛读(第十一章) - 项目风险管理
  5. 鸟哥的linux私房菜 第八章
  6. ElasticSearch 亿级数据检索深度优化
  7. cisco asa(asa5510 设置)防火墙的配置详解
  8. 智慧工地人员/车辆管理整体解决方案
  9. 疯狂天才霍兹:17岁黑掉苹果,22岁搞垮索尼,还是特斯拉、谷歌最可怕的对手!
  10. 微信公众账号使用获取token次数到达上限reach max api daily quota limit rid: 5fd6fd6a-49fcc7d4-65df845f