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("通信失败");
          }
      })

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

问题:从别人分享的链接点进去再分享出来,自定义缩略图和内容丢失

原因:微信在分享的时候,会自动给你的地址后面加入参数,导致你分享的地址改变了,这时候再去用原来的地址获取签名,就不能用了。

H5微信分享 自定义图标和内容(以及二次分享图片丢失的解决办法)_第1张图片

后面带上了这一串参数:?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;
}

测试有效!!!

H5微信分享 自定义图标和内容(以及二次分享图片丢失的解决办法)_第2张图片

更多内容,请关注公众号

H5微信分享 自定义图标和内容(以及二次分享图片丢失的解决办法)_第3张图片

你可能感兴趣的:(web前端,html,html5)