微信强大的整合能力让企业公众号的开发迅速窜红。尤其是企业须要个性化定制的一些功能。公司在同一时候上线的app和触屏版的应用中,微信分享自然是不可或缺的重要一环。

纵观如今大多数的微信公众号。分享大都是弹出二维码或者干脆直接使用微信右上方的分享功能分享网页链接,对于自己定义分享内容这个功能就显得力不从心了,所以在公司伟大领袖的号召下。我们要自己定义分享内容,分享标题。分享链接。好的。领导的精神已经公布了,接下来该我们发神经了。

拿到微信jssdk开发文档的那一刻我信心百倍的告诉自己。小意思。搞得定(我知道我又想多了)。是的,事情确实没有那么的顺利。測试号的开发进行的坎坎坷坷一切都要归功于开发文档的英明指导,一開始是微信版本太低。接着是绑定安全域名,好easy到了js验证的时候一直报“invalid signature”,细致检查下来原来是当前页面的url一定是要动态获取的。

最终搞定了,简单分享一下开发过程。

1.首先引入jweixin-1.0.0.js文件,这个文件是微信验证签名的运行文件。

2.到官网下载微信提供的签名生成类,这个类须要稍加改造,得到生成ticket的方法,同一时候要注意缓存jsapi_ticket和token。防止频繁请求微信。

3.通过js请求后台得到生成的时间戳,nonceStr和signature。

代码例如以下:“(document).ready(function() {  
    var inviteLink = “邀请链接”;(“#shareContent”).val(inviteLink);

$.ajax({

url: ‘<%=path %>/weixin/myshare.htm?url=’+pathURL,

type: ‘POST’,

dataType: ‘json’,

contentType:”application/json;charset=utf-8”,

data:{},

error: function(){alert(‘Error’);},

success: function(result){

wx.config({

debug: false, // 开启调试模式,调用的全部api的返回值会在clientalert出来,若要查看传入的參数,能够在pc端打开,參数信息会通过log打出。仅在pc端时才会打印。

appId: result.appId, // 必填。公众号的唯一标识

timestamp: result.timestamp, // 必填,生成签名的时间戳

nonceStr: result.nonceStr, // 必填,生成签名的随机串

signature: result.signature,// 必填,签名。见附录1

jsApiList: [

‘checkJsApi’,

‘onMenuShareTimeline’,

‘onMenuShareAppMessage’,

‘onMenuShareQQ’,

‘onMenuShareWeibo’

]

});

wx.ready(function(){

        });
wx.error(function(res){
// config信息验证失败会运行error函数
//alert(res);
});
}
});

});“

当中jsApiList中是微信提供的分享功能,各自是分享到朋友圈,发送给微信好友,分享到微博和分享到QQ,开发前期能够使用checkJsApi检查公众号是否获取了这些权限。假设没有勿必先获取权限。否则无法正常使用。另外一个须要注意的问题就是在微信内置浏览器的缓存问题。常常困扰验证结果的就是缓存。所以每当进行一次測试之前最好先关闭微信。因缓存造成的麻烦太让人痛苦了。

微信jssdk已无力吐槽的更多相关文章

  1. 微信JSSDK与录音相关的坑

    欢迎各位转载, 以让微信团队重视这些恼人的BUG. 请注明出处微信JSSDK与录音相关的坑 by lzl124631x 最近一直在做微信JSSDK与录音相关的功能开发, 遇到了各种奇尺大坑, 时不时冷 ...

  2. 微信JSSDK与录音相关的坑

    微信JSSDK与录音相关的坑 最近一直在做微信JSSDK与录音相关的功能开发, 遇到了各种奇尺大坑, 时不时冷不丁地被坑一道, 让我时常想嘶吼: "微信JSSDK就是个大腊鸡!!!!!!!! ...

  3. 微信JS-SDK坐标位置转换为百度地图坐标

    微信JS-SDK开发过程中,使用getLocation获取坐标位置,如何将微信获取的坐标直接应用到百度地图中,显示以下效果: 说明:红色图标是从微信转换过来的位置,蓝色图标是周边位置.首先从微信开发流 ...

  4. 微信公众平台开发 微信JSSDK开发

    根据微信开发文档步骤如下: 1.先登录微信公众平台进入“公众号设置”的“功能设置”里填写“JS接口安全域名”. JS接口安全域名设置 mi.com(前面不用带www/http,域名必须备案过) 2.引 ...

  5. 微信JS-SDK

    <div class="lbox_close wxapi_form"> <h3 id="menu-basic">基础接口</h3& ...

  6. 微信公开课发布微信官方教程:教你用好微信JS-SDK接口

    微信公众平台开放JS-SDK(微信内网页开发工具包),说明文档已经有相关使用方法和示例了,很多同学觉得不是很直观,为此微信公开课发布微信官方教程:教你用好微信JS-SDK接口. 1.分享类接口:支持获 ...

  7. 官方教程:教你用好微信JS-SDK接口

    微信开放JS-SDK接口,开发者和行业用户可谓是欢欣鼓舞.奔走相告,目测将激起一大波第三方开发商的创新产品!真真是H5开发者的利好!但也有用户表示,还不了解JS-SDK接口到底是啥,究竟怎么用.现在, ...

  8. 微信JS-SDK 接口调用与 php 遇到的坑

    问题:config:invalid signature一直爆这个错误 解决: 看我把这些坑都总结了一下:要命的invalid signature. https://segmentfault.com/q ...

  9. 微信JS-SDK说明文档及常见问题处理

    概述 微信JS-SDK是微信公众平台面向网页开发者提供的基于微信内的网页开发工具包. 通过使用微信JS-SDK,网页开发者可借助微信高效地使用拍照.选图.语音.位置等手机系统的能力,同时可以直接使用微 ...

随机推荐

  1. 异步和同步http请求超时机制

    异步超时设置: 例子: Example: do a simple HTTP GET request for http://www.nethype.de/ and print the response ...

  2. UVA 103 Stacking Boxes (dp + DAG上的最长路径 + 记忆化搜索)

     Stacking Boxes  Background Some concepts in Mathematics and Computer Science are simple in one or t ...

  3. 【论文阅读】Retrieving Similar Similar Styles to Parse Clothing(相关工作)

    发表于2015年5月PAMI 作者: Kota Yamaguchi, M.Hadi Kiapour, Luis E. Ortiz, Tamara L. Berg 相关工作: [服装检索Clothing ...

  4. BZOJ 1797: [Ahoi2009]Mincut 最小割( 网络流 )

    先跑网络流, 然后在残余网络tarjan缩点. 考虑一条边(u,v): 当且仅当scc[u] != scc[v], (u,v)可能出现在最小割中...然而我并不会证明 当且仅当scc[u] = scc ...

  5. 触发器应用 trigger

    首先有一张表: create table T_SALARY ( name VARCHAR2(20), age NUMBER(2), salary NUMBER(5) ); insert into t_ ...

  6. [转] iOS (OC) 中 KVC 与 KVO 理解

    转自: http://magicalboy.com/kvc_and_kvo/ KVC 与 KVO 是 Objective C 的关键概念,个人认为必须理解的东西,下面是实例讲解. Key-Value ...

  7. 创建出多个app

    修改红线里的内容

  8. 基于visual Studio2013解决算法导论之052深度优先

     题目 深度优先 解决代码及点评 // 深度优先.cpp : 定义控制台应用程序的入口点. // // 图的邻接表表示.cpp : 定义控制台应用程序的入口点. // #include < ...

  9. Linux环境下编译并执行ava helloworld程序

    原文:http://blog.lupaworld.com/home-space-uid-24466-do-blog-id-2578.html 已经学会怎样在Windows下怎样编辑,编译和运行Java ...

  10. Android:创建可穿戴应用 - 安装和依赖管理

    安装可穿戴应用 在开发时,你能够像一般移动应用一样直接把应用安装到可穿戴设备中. 使用adb install或者 Android Studio上的Play button. 当你准备好要公布时,你须要把 ...