微信分享调用jssdk实例
0、上demo,补充一点小问题按照之前的思路,发现一直签名失败,我查了半天,发现是url那地方有问题。通过api获取时,签名的url默认获取的是接口的api地址,比较纳闷。后来我在请求时加入了当前网址,然后再myapi中获取一下,再赋值过去。就可以了。具体代码见第三段。 效果如图。 1、问题说明搞了半天,终于搞定。说下基本需求,很简单,网页在微信中打开,分享。 2、问题解析根据微信官方给出的demo,可以看到核心就是获取四个参数,从而配置wx.config。 3、解析思路接下来,说下我的思路,在js中通过ajax调用jssdk部署的接口,返回上述所需参数。 <?php require_once "jssdk.class.php"; $uurl = ""; if(is_array($_GET)&&count($_GET)>0)//先判断是否通过get传值了 { if(isset($_GET["urlparam"]))//是否存在"urlparam"的参数 { $uurl=$_GET["urlparam"];//存在 } } $cfg_appid = "你的appid"; $cfg_screct = "你的appsecrect"; $weixin = new jssdk($cfg_appid,$cfg_screct,$uurl); $signPackage = $weixin->get_sign(); $data = array( 'appId' => $signPackage["appId"],'timestamp' => $signPackage["timestamp"],'nonceStr' => $signPackage["nonceStr"],'signature' => $signPackage["signature"]); echo json_encode($data);
前端页面 <script src="http://res.wx.qq.com/open/js/jweixin-1.0.0.js"></script>
<script type="text/javascript"> $(function(){ $.ajax({ type: "GET",url: "../wxconfig/myapi.php",data: "urlparam="+window.location.href.split('#')[0],success: function(data){ var result = JSON.parse(data); if (result != null) { wx.config({ debug: false,appId: result.appId,timestamp: result.timestamp,nonceStr: result.nonceStr,signature: result.signature,jsApiList: ['onMenuShareTimeline','onMenuShareAppMessage'] }); } },error: function(){ } }); }); window.sharedata = { title: '标题',desc: '描述',link: window.location.href,imgUrl: 'http://avatar.csdn.net/0/4/F/1_zyq527758142.jpg',success: function () { alert('成功分享'); },cancel: function () { alert('取消分享'); } }; wx.ready(function () { wx.onMenuShareAppMessage(sharedata); wx.onMenuShareTimeline(sharedata); }); </script>
4、知识点1、微信分享jssdk的使用 2、html调用ajax 3、解决微信分享为何出现链接的问题 (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |