找回密码
 立即注册

QQ登录

只需一步,快速开始

查看: 763|回复: 0
打印 上一主题 下一主题

微信自定义分享php代码分析

[复制链接]

2500

主题

2513

帖子

7520

积分

论坛元老

Rank: 8Rank: 8

积分
7520
跳转到指定楼层
楼主
发表于 2018-2-14 05:30:20 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式

            前一段之间做微信自定义分享,积累了一些经验,分享给大家。

步骤一、二在微信开发者文档中已经很详细了,直接从步骤三开始吧。
步骤三要参数微信的参数,除了appId之外,其他的参数都是动态的,这里,我用的php语言,在后端生成的参数,代码如下:
php端代码:
public function getwxinfo(){
$dataurl = I('dataurl');
include('./ThinkPHP/Library/Vendor/jssdk/jssdk.php');
$jssdk = new \JSSDK('appId','appSecret');
$signPackage = $jssdk->GetSignPackage($dataurl);
exit(response('1','ok',$signPackage));
}
生成签名时,必须获取当前页面的URL,所以$dataurl是通过下面JS动态获取的,切记。
JS端代码:
var dataurl = window.location.href;
$.ajax({
type:'post',
data:{'dataurl':dataurl},
url:'/index.php/Home/Index/getwxinfo',
dataType:'json',
success:function(json){
  var list = json.data;
  var appId = list.appId;
  var timestamp = list.timestamp;
  var nonceStr = list.nonceStr;
  var signature = list.signature;
  weixinInfo(appId,timestamp,nonceStr,signature);
},
error:function() {
  //alert('网络不给力哦...')
}
});
function weixinInfo(appId,timestamp,nonceStr,signature){
wx.config({
  debug: false,
  appId: appId,
  timestamp:timestamp ,
  nonceStr:nonceStr,
  signature:signature,
  jsApiList: [
   'checkJsApi', //判断当前客户端版本是否支持指定JS接口
   'onMenuShareTimeline', //分享到朋友圈
   'onMenuShareAppMessage', //分享给好友
   'onMenuShareQQ', //分享到QQ
   'onMenuShareWeibo' //分享到微博
  ]
});
}

wx.ready(function () {
//微信好友
var s_title = '分享标题';
var s_desc = '分享描述';
var s_link = '分享后的链接';
var s_'图片链接';
wx.onMenuShareAppMessage({ //例如分享到朋友圈的API
  title: s_title, // 分享标题
  desc: s_desc, // 分享描述
  link: s_link, // 分享链接
  , // 分享图标
  success: function () { },
  cancel: function () { }
});
//朋友圈
wx.onMenuShareTimeline({
  title: s_title, // 分享标题
  link: s_link, // 分享链接
  , // 分享图标
  success: function () { },
  cancel: function () { }
});
//QQ好友
wx.onMenuShareQQ({
  title: s_title, // 分享标题
  desc: s_desc, // 分享描述
  link: s_link, // 分享链接
  , // 分享图标
  success: function () { },
  cancel: function () { }
});
});
wx.error(function (res) {
alert(res.errMsg); //打印错误消息。及把 debug:false,设置为debug:ture就可以直接在网页上看到弹出的错误提示
});
就这么简单。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。
            
            
您可能感兴趣的文章:
  • PHP对接微信公众平台消息接口开发流程教程
  • 基于php的微信公众平台开发入门实例
  • php微信浏览器分享设置以及回调详解
  • php版微信公众号自定义分享内容实现方法
  • 基于thinkPHP实现的微信自定义分享功能示例
  • PHP微信分享开发详解
  • thinkphp项目如何自定义微信分享描述内容
  • thinkPHP微信分享接口JSSDK用法实例
  • php实现的微信分享到朋友圈并记录分享次数功能
            
  • 分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
    收藏收藏
    回复

    使用道具 举报

    您需要登录后才可以回帖 登录 | 立即注册

    本版积分规则

    用户反馈
    客户端