H5分享提示签名错误,是后端还是前端的问题?
在后端返回的:随机字符串,时间戳,和后端生成的签名,还有url;经过http://mp.weixin.qq.com/debug/cgi-bin/sandbox?t=jsapisign这个验证,后端返回的签名与验证工具生成的签名一致.但是前端用到的时候,报
在后端返回的:随机字符串,时间戳,和后端生成的签名,还有url;经过http://mp.weixin.qq.com/debug/cgi-bin/sandbox?t=jsapisign这个验证,后端返回的签名与验证工具生成的签名一致.但是前端用到的时候,报
public Map<String, String> SHA1(String url, String jsapiTicket) { Map<String, String> map = new HashMap<>(6); String nonceStr = getRandomStr(16);//生成16位随机字符串 String timestamp = createTimestamp(); String string1; String signature = ""; //签名 //注意这里参数名必须全部小写,且必须有序 string1 = "jsapi_ticket=" + jsapiTicket + "&noncestr=" + nonceStr + "×tamp=" + timestamp + "&url=" + url; try { MessageDigest digest = MessageDigest .getInstance("SHA-1"); digest.update(string1.getBytes()); byte messageDigest[] = digest.digest(); StringBuffer hexStr = new StringBuffer(); for (int i = 0; i < messageDigest.length; i++) { String shaHex = Integer.toHexString(messageDigest[i] & 0xFF); if (shaHex.length() < 2) { hexStr.append(0); } hexStr.append(shaHex); } signature = hexStr.toString(); //签名 map.put("url", url); map.put("jsapi_ticket", jsapiTicket); map.put("nonceStr", nonceStr); map.put("timestamp", timestamp); map.put("signature", signature); return map; } catch (NoSuchAlgorithmException e) { e.printStackTrace(); } return null; } |
这个是签名生成方法
出现这种问题 基本上是前端调用后端签名接口时所传当前url不对。
通常遇到这种情况的话,在分享的页面打印一下当前页面的url 和在wx.init 的页面打印一下url 如果不一样 分享是不会成功的,如果发现不一样的话 需要在wx.init的时候重新做一次init。单页面应用的history模式 会有一部分安卓机器出现这种问题