java微信分享签名错误_微信公众号H5页面自定义分享功能,JAVA后台签名算法实现,前端总是出现config:invalid signature....

问题描述

根据微信公众号网页服务的自定义分享服务接口的相关说明,我使用access_token获取到了ticket,后台再结合根据前端提交的时间戳(timestamp)、随机字符串(nonceStr)、url(JS接口安全域名)共4个参数,生成String1,再用SHA1加密得到签名signature,最后把这个签名signature返回给前端,可是前端在分享页面死活都是提示config:invalid signature.我已经晕了,不知道怎么处理了。请大神帮我看下代码,谢谢你。

问题出现的环境背景及自己尝试过哪些方法

按照官方的文档:“对所有待签名参数按照字段名的 ASCII 码从小到大排序(字典序)后,使用 URL 键值对的格式”,我在服务器端代码里面对相应参数实现了ascII升序排序,微信公众号会报错;后来我看到官方提供的生成签名的沙盒,里面的String1并没有对参数进行AscII升序排序,我又把相关代码注释掉了,然后直接拼接,结果还是报那个错误。最后我直接使用沙盒里面的随机字符串和时间戳和最后生成的签名,任然报错。我真的不晓得到底怎么搞的。

相关代码

java 代码实现签名算法的部分

import java.security.MessageDigest;

public class WxSignatrueService {

private static final char[] HEX_DIGITS = { '0', '1', '2', '3', '4', '5', '6', '7', '8', '9', 'a', 'b', 'c', 'd', 'e', 'f' };

public static String getWxShareSignatrue(String ticket, String noStr, String url, String timestamp) {

// char[] _ticket = ticket.toCharArray();

// char[] _noStr = noStr.toCharArray();

// char[] _url = url.toCharArray();

// char[] _timestamp = timestamp.toCharArray();

//

// Arrays.sort(_ticket);

// Arrays.sort(_noStr);

// Arrays.sort(_url);

// Arrays.sort(_timestamp);

// String jsapi_ticket =

// String.valueOf(_ticket)+"&noncestr="+String.valueOf(_noStr)+"&timestamp="+String.valueOf(_timestamp)+"&url="+_url.toString();

String jsapi_ticket = "jsapi_ticket=" + ticket + "&noncestr=" + noStr + "&timestamp=" + timestamp + "&url="

+ url;

return new String(encode(jsapi_ticket));

}

private static String getFormattedText(byte[] bytes) {

int len = bytes.length;

StringBuilder buf = new StringBuilder(len * 2);

// 把密文转换成十六进制的字符串形式

for (int j = 0; j < len; j++) {

buf.append(HEX_DIGITS[(bytes[j] >> 4) & 0x0f]);

buf.append(HEX_DIGITS[bytes[j] & 0x0f]);

}

return buf.toString();

}

public static String encode(String str) {

if (str == null) {

return null;

}

try {

MessageDigest messageDigest = MessageDigest.getInstance("SHA1");

messageDigest.update(str.getBytes());

return getFormattedText(messageDigest.digest());

} catch (Exception e) {

throw new RuntimeException(e);

}

}

}

前端,在vue相关页面我是这样实现的:

mounted(){

/* eslint-disable */

let timestamp = Date.parse(new Date());

let random = Math.random().toString(36).substr(2);

let me = this;

axios.get("https://我的域名/getSignature",{params:{noStr:random,url:"我的域名",timestamp:timestamp}}).then(res=>{

wx.config({

debug:true,

appId:"appid",

timestamp:timestamp,

nonceStr:random,

signatrue:res.data.data,

jsApiList:["onMenuShareTimeline","onMenuShareAppMessage"]

});

wx.ready(function(){

wx.onMenuShareTimeline({

title:"我的专属房子",

link:"我的域名",

imgUrl:"我的域名"+me.backUrl,

success:function(){

}

});

wx.onMenuShareAppMessage({

title:"我的专属房子",

desc:"我的未来房子是这个样子",

link:"我的域名/eaglepublic",

imgUrl:"我的域名"+me.backUrl,

success:function(){

}

})

})

})

你期待的结果是什么?实际看到的错误信息又是什么?

我期待在分享我的页面给朋友或者朋友圈的时候,能看到图标,并且不要提示那个错误,并且能进入我指定的link地址。

请问哪个有经验的大神能帮我解决这个问题。

这个错误提示是由于在Vue H5页面分享微信时,分享链接的签名无效导致的。 在微信分享中,需要对分享链接进行签名,以确保链接的完整性和安全性。签名的原理是利用配置的appID、appSecret、noncestr(随机字符串)和timestamp(时间戳)等参数,通过特定的算法生成一个字符串,再将这个字符串进行加密得到签名signature微信客户端在收到分享链接时,会根据这个签名来验证链接的合法性。 出现"invalid signature"的错误提示,通常是由以下几个原因导致的: 1. 参数配置错误:检查在使用微信分享API时,是否正确配置了appID和appSecret等参数。需要确保这些参数的值是有效的,并且与微信开放平台中的配置一致。 2. 签名生成错误签名算法可能有误。可以参考微信提供的官方文档,了解签名算法的具体步骤和规则,确保在生成签名时没有遗漏或错误处理相关参数。 3. 随机字符串和时间戳:noncestr和timestamp参数可能未传递或传递错误。在生成签名时,需要使用正确的noncestr和timestamp值。 4. URL编码问题:分享链接中如果包含特殊字符或需要URL编码的字符,需要在生成签名时进行正确的编码处理。 如果还是无法解决该错误,可以尝试在开发者工具中调试,查看具体的错误信息,以便定位问题所在。同时,可以参考微信开放平台的相关文档和社区中的讨论,寻找其他开发者遇到类似问题的解决方法。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值