ThinkPHP3.2.3集成微信分享JS-SDK实践
2016-11-01 23:03
267 查看
先来看看微信分享效果:
在没有集成微信分享js-sdk前是这样的:没有摘要,缩略图任意抓取正文图片
![](http://img.blog.csdn.net/20161103172922346?watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQv/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/Center)
在集成微信分享js-sdk后是这样的:标题,摘要,缩略图自定义
![](http://img.blog.csdn.net/20161103172959378?watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQv/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/Center)
下面进入正题:
一、下载微信SDK开发包
下载地址:http://demo.open.weixin.qq.com/jssdk/sample.zip
二、设置安全域名
所有的微信JS接口都只能在公众号绑定的域名下调用。登录微信公众平台,点击左边的“公众号设置”,切换到“功能设置”,在“JS接口安全域名”一栏设置安全域名,下载验证文件到网站根目录,再回到窗口点击“确定”(注:在点击“确定”前,设置的域名下都要能在浏览器下正常访问刚才下载的验证文件才能通过验证)。
![](http://img.blog.csdn.net/20161101231054443?watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQv/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/Center)
三、以第三方插件形式集成到ThinkPHP
1、定义第三方类库目录(也可以放置在TP框架默认的插件目录ThinkPHP/Library/Vendor/)。
在入口文件中加入define('VENDOR_PATH', APP_PATH .'Common/Vendor/');
2、在\Application\Common\Vendor文件夹下新建文件夹Wxshare,解压微信SDK开发包,将jssdk.php、access_token.php、jsapi_ticket.php复制到Wxshare,重命名jssdk.php为class.jssdk.php(符合TP加载规则的文件名)。
![](http://img.blog.csdn.net/20161101231146492?watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQv/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/Center)
3、修改access_token.php、jsapi_ticket.php的读写路径。打开class.jssdk.php文件,加入私有属性private $filePath;
在构造函数中设置属性为当前文件路径:$this->filePath = __DIR__.'/';
搜索access_token.php、jsapi_ticket.php,在文件名前连接上$this->filePath
4、在公共函数库写一函数方便调用。
四、应用
1、控制器调用
在需要做微信分享的控制器方法中调用:
在模板文件尾部加入:
到此完成!在微信中访问网址并分享试试看效果。
五、查阅开发文档
微信JS-SDK Demo地址:http://demo.open.weixin.qq.com
常见问题及完整 JS-SDK 文档地址:http://mp.weixin.qq.com/wiki/7/aaa137b55fb2e0456bf8dd9148dd613f.html
--------------------------------------------------------------------------------------------------------------------------------------------------
补充一个使用场景:
如果是前后台端分离的网站架构(也就是通过api接口的形式),前端必然要用到ajax请求,会出现一个问题:
被请求的网址与调用的网址不一致,微信SDK会提示签名无效。提供一个解决办法是:把调用的网址当成参数发回给服务器端,再生成微信签名。
示例代码:
1、后端代码(如请求:/api/common/wxshareinit)将获取的微信签名参数打包成一个JSON,格式如:
2、前端页面调用:
在没有集成微信分享js-sdk前是这样的:没有摘要,缩略图任意抓取正文图片
在集成微信分享js-sdk后是这样的:标题,摘要,缩略图自定义
下面进入正题:
一、下载微信SDK开发包
下载地址:http://demo.open.weixin.qq.com/jssdk/sample.zip二、设置安全域名
所有的微信JS接口都只能在公众号绑定的域名下调用。登录微信公众平台,点击左边的“公众号设置”,切换到“功能设置”,在“JS接口安全域名”一栏设置安全域名,下载验证文件到网站根目录,再回到窗口点击“确定”(注:在点击“确定”前,设置的域名下都要能在浏览器下正常访问刚才下载的验证文件才能通过验证)。三、以第三方插件形式集成到ThinkPHP
1、定义第三方类库目录(也可以放置在TP框架默认的插件目录ThinkPHP/Library/Vendor/)。在入口文件中加入define('VENDOR_PATH', APP_PATH .'Common/Vendor/');
2、在\Application\Common\Vendor文件夹下新建文件夹Wxshare,解压微信SDK开发包,将jssdk.php、access_token.php、jsapi_ticket.php复制到Wxshare,重命名jssdk.php为class.jssdk.php(符合TP加载规则的文件名)。
3、修改access_token.php、jsapi_ticket.php的读写路径。打开class.jssdk.php文件,加入私有属性private $filePath;
在构造函数中设置属性为当前文件路径:$this->filePath = __DIR__.'/';
搜索access_token.php、jsapi_ticket.php,在文件名前连接上$this->filePath
4、在公共函数库写一函数方便调用。
/** * 微信分享初始化 * @return array * @author simon <vsiryxm@qq.com> */ if (!function_exists('wx_share_init')) { function wx_share_init() { $wxconfig = array(); vendor('Wxshare.class#jssdk'); $config = APP_DEBUG ? C("WECHAT_SDK_TEST") : C("WECHAT_SDK"); //这里配置了微信公众号的AppId和AppSecret $jssdk = new JSSDK($config['APPID'], $config['APPSECRET']); $wxconfig = $jssdk->GetSignPackage(); return $wxconfig; } }
四、应用
1、控制器调用在需要做微信分享的控制器方法中调用:
$wxconfig = wx_share_init(); $this->assign('wxconfig', $wxconfig);2、模板填充
在模板文件尾部加入:
<script src="//res.wx.qq.com/open/js/jweixin-1.0.0.js"></script> <script> wx.config({ debug: false, // 是否开启调试模式 appId: '<?php echo $wxconfig["appId"]; ?>', // 必填,微信号AppID timestamp: <?php echo $wxconfig["timestamp"]; ?>, // 必填,生成签名的时间戳 nonceStr: '<?php echo $wxconfig["nonceStr"]; ?>', // 必填,生成签名的随机串 signature: '<?php echo $wxconfig["signature"]; ?>',// 必填,签名,见附录1 jsApiList: ['onMenuShareTimeline', //分享到朋友圈 'onMenuShareAppMessage', //分享给朋友 'onMenuShareQQ' //分享到QQ ] // 必填,需要使用的JS接口列表,所有JS接口列表见附录2 }); wx.ready(function(){ var options = { title: '<?php echo $news["title"]; ?>', // 分享标题 link: 'http://www.xxx.com/news/detail/id/<?php echo $news["id"]; ?>', // 分享链接,记得使用绝对路径 imgUrl: 'http://www.xxx.com/<?php echo $news["picture"]; ?>', // 分享图标,记得使用绝对路径 desc: '<?php echo $news["brief"]; ?>', // 分享描述 success: function () { console.info('分享成功!'); // 用户确认分享后执行的回调函数 }, cancel: function () { console.info('取消分享!'); // 用户取消分享后执行的回调函数 } } wx.onMenuShareTimeline(options); // 分享到朋友圈 wx.onMenuShareAppMessage(options); // 分享给朋友 wx.onMenuShareQQ(options); // 分享到QQ }); </script>
到此完成!在微信中访问网址并分享试试看效果。
五、查阅开发文档
微信JS-SDK Demo地址:http://demo.open.weixin.qq.com常见问题及完整 JS-SDK 文档地址:http://mp.weixin.qq.com/wiki/7/aaa137b55fb2e0456bf8dd9148dd613f.html
--------------------------------------------------------------------------------------------------------------------------------------------------
补充一个使用场景:
如果是前后台端分离的网站架构(也就是通过api接口的形式),前端必然要用到ajax请求,会出现一个问题:
被请求的网址与调用的网址不一致,微信SDK会提示签名无效。提供一个解决办法是:把调用的网址当成参数发回给服务器端,再生成微信签名。
示例代码:
1、后端代码(如请求:/api/common/wxshareinit)将获取的微信签名参数打包成一个JSON,格式如:
{ "appId": "wx44faa06a8046525e", "nonceStr": "NJVodYffglDbM3fD", "timestamp": 1478161661, "url": "http:\/\/www.xxx.com\/news\/detail\/id\/54", "signature": "aa4eeec5e1ad6f39c85cd4f3c1147329a16eb784", "rawString": "jsapi_ticket=sM4AOVdWfPE4DxkXGEs8VIqb--nsh20pd5ZnAlGF4nz5j33A5wpvImM6P1_QX3azn2Kca1KYOCO9NfeWEQsNng&noncestr=NJVodYffglDbM3fD×tamp=1478161661&url=http:\/ \/www.xxx.com\/news\/detail\/id\/54" }
2、前端页面调用:
<script src="//res.wx.qq.com/open/js/jweixin-1.0.0.js"></script> <script> var wxconfig = []; //定义一个全局的保存微信配置的变量 $(function() { $.ajax({ async: false, //这里设为同步请求(重要) type: 'POST', url: '/api/common/wxshareinit', //被请求的网址 data: {url:document.URL}, //将当前调用网址发回给服务器做签名用 dateType: 'JSON', cache: false, success: function(result) { wxconfig = result.data; }, error:function() { alert('微信分享初始化失败!'); } }); wx.config({ debug: false, // 是否开启调试模式 appId: wxconfig.appId, // 必填,微信号AppID timestamp: wxconfig.timestamp, // 必填,生成签名的时间戳 nonceStr: wxconfig.nonceStr, // 必填,生成签名的随机串 signature: wxconfig.signature,// 必填,签名,见附录1 jsApiList: ['onMenuShareTimeline', //分享到朋友圈 'onMenuShareAppMessage', //分享给朋友 'onMenuShareQQ' //分享到QQ ] // 必填,需要使用的JS接口列表,所有JS接口列表见附录2 }); wx.ready(function(){ var options = { title: '【有料】3号产品神秘体验,到底爽在哪?—xxx平台', // 分享标题 link: 'http://www.xxx.com/news/detail/id/52', // 分享链接 imgUrl: 'http://www.xxx.com/Uploads/News/2016-11/1477995152201598.jpg', // 分享图标 desc: '年化收益9.9%,3个月到期还本付息,起购门槛20万', // 分享描述 success: function () { console.info('分享成功!'); // 用户确认分享后执行的回调函数 }, cancel: function () { console.info('取消分享!'); // 用户取消分享后执行的回调函数 } } wx.onMenuShareTimeline(options); // 分享到朋友圈 wx.onMenuShareAppMessage(options); // 分享给朋友 wx.onMenuShareQQ(options); // 分享到QQ }); }); </script>
集成包下载
相关文章推荐
- Angularjs+ThinkPHP3.2.3集成微信分享JS-SDK实践
- ThinkPHP3.2.3集成微信分享JS-SDK实践
- 微信开发实践(一):使用JS-SDK实现自定义分享 Ⅰ 3ff8
- 微信分享 使用weixin js sdk 兼容 旧版本
- 微信JS-SDK2015年升级分享到朋友圈接口限制
- 转:js-sdk探索之微信网页分享
- 微信JS-SDK实现自定义分享功能,分享给朋友,分享到朋友圈
- 微信JS-SDK 分享到朋友圈 分享给朋友 分享到QQ 拍照或从手机相册中选图 识别音频并返回识别结果 使用微信内置地图查看位置
- 微信JS-SDK“分享信息设置”API及数字签名生成方法(NodeJS版本)
- 用c#开发微信 (10) JS-SDK 基本用法- 分享接口“发送到朋友”
- ThinkPHP微信开发实例——JSSDK图像接口上传下载并将图片流写入本地
- 【微信分享】 微信分享集成 使用weixin js sdk 兼容 旧版本 2
- 微信自定义分享JS-SDK制作
- 微信分享jssdk实例
- 微信JS-SDK“分享信息设置”API及数字签名生成方法(NodeJS版本)
- 微信js_sdk的分享功能的问题
- thinkphp微信开发之jssdk拉取卡券及卡券的核销
- 实现微信JS-SDK分享自定义标题和图片
- 微信JS-SDK 修改分享标题 分享图片