微信二次分享报错invalid signature问题及解决方法

下面是关于“微信二次分享报错invalidsignature问题及解决方法”的完整攻略:

问题描述

在微信二次分享(通过分享出去的链接再次点击进行分享)时,有时会出现invalidsignature的问题,导致分享失败。

问题的原因

这个问题的原因是由于微信分享的signature签名生成机制,每个URL只能生成一次,但是如果URL参数发生了改变,那么就需要重新生成签名,否则就会出现invalidsignature的错误。

解决方法

那么,如何避免或解决这个问题呢?有两种方法可以尝试:

方法一:设置URL不变

第一种方法是设置URL不变,在分享链接中传参数时不改变URL,这样可以保证signature签名能够正确生成。这个方法比较简单,不需要进行特别的操作,只需要在分享链接的时候保证URL的不变性即可。

方法二:动态生成signature

第二种方法是动态生成signature,即在每次分享时获取到正确的URL参数后再生成signature签名,这样可以避免由于URL改变导致的signature错误。

下面是利用Node.js实现动态生成signature的一个示例:

const crypto = require('crypto');
const request = require('request');

const appID = 'your appid';
const appSecret = 'your appsecret';

// 微信JS-SDK签名生成函数
function createNonceStr() {
  return Math.random().toString(36).substr(2, 15);
}

function createTimestamp() {
  return parseInt(new Date().getTime() / 1000) + '';
}

function raw(args) {
  let keys = Object.keys(args);
  keys = keys.sort();
  let newArgs = {};
  keys.forEach(function(key) {
    newArgs[key.toLowerCase()] = args[key];
  });

  let string = '';
  for (let k in newArgs) {
    string += '&' + k + '=' + newArgs[k];
  }
  string = string.substr(1);
  return string;
}

function sign(jsapiTicket, url) {
  let nonceStr = createNonceStr();
  let timestamp = createTimestamp();
  let ret = {
    jsapi_ticket: jsapiTicket,
    nonceStr: nonceStr,
    timestamp: timestamp,
    url: url
  };
  let string = raw(ret);
  let sha1 = crypto.createHash('sha1');
  sha1.update(string);
  ret.signature = sha1.digest('hex');
  ret.appId = appID;
  return ret;
}

// 获取access_token和jsapi_ticket
function getTokenAndTicket(cb) {
  const url = `https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid=${appID}&secret=${appSecret}`;
  request(url, function(err, res, body) {
    const result = JSON.parse(body);
    const accessToken = result.access_token;
    const url = `https://api.weixin.qq.com/cgi-bin/ticket/getticket?access_token=${accessToken}&type=jsapi`;
    request(url, function(err, res, body) {
      const result = JSON.parse(body);
      const ticket = result.ticket;
      cb(ticket);
    });
  });
}

// 生成新的签名参数
function generateNewSignature(url, cb) {
  getTokenAndTicket(function(jsapiTicket) {
    const newSignature = sign(jsapiTicket, url);
    cb(newSignature);
  });
}

// 生成动态签名
const dynamicSignature = (req, res) => {
  const url = req.body.url;
  generateNewSignature(url, function(newSignature) {
    res.send(newSignature);
  });
};

以上示例中,raw函数用于将传入的参数按照字母序排序并进行拼接,sign函数则是利用上述raw函数生成signature签名,getTokenAndTicket函数则是用于获取access_token和jsapi_ticket。generateNewSignature函数调用getTokenAndTicket函数获取到最新的jsapi_ticket后再生成动态签名,最后在dynamicSignature函数中调用generateNewSignature生成新的签名参数。

总结

通过以上两种方法,我们可以避免或解决微信二次分享出现invalidsignature的问题。同时,我们也可以看出,微信开发中,很多问题都可以通过动态生成signature实现,这对于微信开发者来说是非常有用的技巧。

营销型网站