H5微信分享 自定义图标和内容

一、需配置的东西

1、请确认公众号已经认证,只有认证的公众号才具有分享相关接口权限
2、登录微信公众平台进入“公众号设置”的“功能设置”里填写“JS接口安全域名”。(需要调用微信接口的h5域名)
3、在需要调用JS接口的页面引入如下JS文件,(支持https):http://res.wx.qq.com/open/js/jweixin-1.6.0.js
4、配置IP白名单,基本配置-公众号开发信息-IP白名单。(调用后台接口的域名)

二、前端代码

var title = h5_title;//这里是标题
var desc = share_content;//这里是描述
var imgUrl = url_img + share_img;//这里是图片
$.ajax({
    url:url_jk+"/html/wxgetjsapi?url=" + link,
    type: "GET",
    dataType: "json",
    success: function (res) {
        console.log(res);
        wx.config({
            debug: false,//开启调试模式,调用的所有api的返回值会在客户端alert出来,若要查看传入的参数,可以在pc端打开,参数信息会通过log打出,仅在pc端时才会打印。
            appId: res.appid,// 必填,公众号的唯一标识
            timestamp: res.timestamp,// 必填,生成签名的时间戳
            nonceStr: res.nonceStr,// 必填,生成签名的随机串
            signature: res.signature,// 必填,签名
            jsApiList: ["onMenuShareTimeline", "onMenuShareAppMessage","updateTimelineShareData", "updateAppMessageShareData",]// 必填,需要使用的JS接口列表
         });

         wx.ready(function () {
               //  config信息验证后会执行ready方法,所有接口调用都必须在config接口获得结果之后,config是一个客户端的异步操作,
              //  所以如果需要在页面加载时就调用相关接口,则须把相关接口放在ready函数中调用来确保正确执行。对于用户触发时才调用的接口,则可以直接调用,不需要放在ready函数中。
             //分享到朋友圈
             wx.onMenuShareTimeline({
                   title: title,// 分享标题
                   link: link,// 分享链接,该链接域名或路径必须与当前页面对应的公众号JS安全域名一致
                   imgUrl: imgUrl,// 分享图标
                   success: function () {
                       // 设置成功
                   }
              });

              //分享给微信好友
              wx.onMenuShareAppMessage({
                    title: title,
                    desc: desc, // 分享描述
                    link: link,
                    imgUrl: imgUrl,
                    type: "",// 分享类型,music、video或link,不填默认为link
                    dataUrl: "",// 如果type是music或video,则要提供数据链接,默认为空
                    success: function () {}
               });

               // 自定义“分享到朋友圈”及“分享到QQ空间”按钮的分享内容
               wx.updateTimelineShareData({
                     title: title,
                     link: link,
                     imgUrl: imgUrl,
                     success: function () {}
                });

                // 自定义“分享给朋友”及“分享到QQ”按钮的分享内容
                wx.updateAppMessageShareData({
                      title: title,
                      desc: desc,
                      link: link,
                      imgUrl: imgUrl,
                      success: function () {}
                 })
             })
          },
          error: function (res) {
            // config信息验证失败会执行error函数,如签名过期导致验证失败,具体错误信息可以打开config的debug模式查看,也可以在返回的res参数中查看,对于SPA可以在这里更新签名。
            console.log("通信失败");
          }
      })

三、二次分享图片和自定义的内容丢失的解决办法

问题:从别人分享的链接点进去再分享出来,自定义缩略图和内容丢失
原因:微信在分享的时候,会自动给你的地址后面加入参数,导致你分享的地址改变了,这时候再去用原来的地址获取签名,就不能用了。

WechatIMG3.jpeg

后面带上了这一串参数:?from=singlemessage&isappinstalled=0
解决办法:截掉地址后面给你加的那一串参数,重置地址

var link = location.href.split("#")[0];//获取url替换#后面的部分hash值
if(link.indexOf("&")>-1){
   link = link.substring(0,link.indexOf("&"))
   window.location.href = link;
}

测试有效!!!


WechatIMG4.jpeg

你可能感兴趣的:(H5微信分享 自定义图标和内容)