微信jssdk 返回的 config invalid signature
这几天一直在调试wxjssdk,按照api的需求,http://mp.weixin.qq.com/wiki/7/aaa137b55fb2e0456bf8dd9148dd613f.html ,先是根据appid和秘钥获取access_token并存入缓存:注意的是 此处的appid 和 秘钥 是 微信公众平台的appid(区别于微信开放平台,开放平台无法设置域名)。
public final String sharing(String url, HttpServletResponse response) {
StringBuilder stringBuilder = new StringBuilder();
Map<String,String> resMap = new HashMap<String, String>();
//返回给app端
net.sf.json.JSONObject jb = new net.sf.json.JSONObject();
net.sf.json.JSONObject data = new net.sf.json.JSONObject();
try {
if (url.contains("#")){
url = url.substring(0,url.indexOf("#")); //不需要获取后面的#的内容
}
Map<String,String> ecPaymentMap = myPayService.findPaymentTypeListInfo(PAYMENT_TYPE_ID);
String accessToken = cacheUtil.readCache("access_token"); //获取token
if (StringUtil.isEmpty(accessToken)){
Map<String,String> getTokenMap = new HashMap<String, String>();
getTokenMap.put("grant_type","client_credential"); //获取access_token填写client_credential
getTokenMap.put("appid", ecPaymentMap.get("appId")); //第三方用户唯一凭证
getTokenMap.put("secret",ecPaymentMap.get("appKey")); //第三方用户唯一凭证密钥,
String resTokenData = HttpClientTools.doGet(WXURLConstant.ACCESSTOKENURL, getTokenMap);
if (StringUtil.isEmpty(resTokenData)){
logger.error("WXJs Token is null");
throw new RuntimeException();
}
JSONObject jsonObject = JSONObject.parseObject(resTokenData);
logger.info("WXJs resData" + jsonObject); if (jsonObject.get("access_token") !=null){
cacheUtil.setCache("access_token",jsonObject.get("access_token").toString(),Integer.valueOf(jsonObject.get("expires_in").toString()));
}else {
logger.error("get WXJs token error,errorCode: " + jsonObject.get("errcode"));
}
accessToken=cacheUtil.readCache("access_token");
}
String jsapiTicket = cacheUtil.readCache("jsapiTicket"); //获取jsapiTicket
if (StringUtil.isEmpty(jsapiTicket)){
Map<String,String> map = new HashMap<String, String>(); //请求获取JS-SDK使用权限签名算法
map.put("access_token",accessToken); //请求参数access_token
map.put("type","jsapi"); //请求参数type 固定
String ticketResData = HttpClientTools.doGet(WXURLConstant.JSAPITICKET, map);
if (StringUtil.isEmpty(ticketResData)){
logger.error("requestData is null");
return null;
}
JSONObject jsonObject = JSONObject.parseObject(ticketResData); if (!"0".equals(jsonObject.get("errcode").toString())){
logger.error("WX get jsapiTicket error" + jsonObject.toString());
jb.element("status", 002);
jb.element("msg", "jsapi error");
data.element("data",jsonObject);
jb.put("data",data);
stringBuilder.append(jb);
response.resetBuffer();
response.setContentType("text/html;charset=UTF-8");
response.getWriter().print(stringBuilder);
response.getWriter().flush();
response.getWriter().close();
response.flushBuffer();
return stringBuilder.toString();
}
cacheUtil.setCache("jsapiTicket",jsonObject.get("ticket").toString(),WXJSSDKConstant.EXPIRETIME); //缓存2个小时 其实有自动任务一个小时会执行一次 防止过期
jsapiTicket = jsonObject.get("ticket").toString();
}
String timestamp = String.valueOf(System.currentTimeMillis()/1000);
String nonceStr = TenpayUtil.getNonceStr();
Map<String,String> requestSignMap = new HashMap<String, String>(); //后去signature
requestSignMap.put("noncestr", nonceStr);
requestSignMap.put("jsapi_ticket",jsapiTicket);
requestSignMap.put("timestamp",timestamp);
requestSignMap.put("url",url);
String signature = "";
try {
signature = WXUtil.sha1Sign(requestSignMap);
} catch (JDOMException e) {
e.printStackTrace();
} //增加签名
jb.element("status", 0);
jb.element("msg", "OK");
resMap.put("appId", ecPaymentMap.get("appId"));
resMap.put("timestamp", timestamp);
resMap.put("nonceStr", nonceStr);
resMap.put("signature", signature);
data.element("data",resMap);
jb.element("data", data);
stringBuilder.append(jb.toString());
response.resetBuffer();
response.setContentType("text/html;charset=UTF-8");
response.getWriter().print(stringBuilder.toString());
response.getWriter().flush();
response.getWriter().close();
response.flushBuffer(); } catch (IOException e) {
e.printStackTrace();
}
return stringBuilder.toString();
}
第二步 是根据acces_token获取jsapi_ticket并存入缓存,注意此处的参数type要是jsapi,还有一个获取卡卷的接口,此处容易出错
第三部 就是根据jsapiticket 来获取signature,参数主要是16位随机数,ticket 时间串(注意此处的格式是秒) url (注意路径:传递的时候需要转码,后台后去的时候需要解码,这个一定要注意了,好多人在这上面被坑的。。。)
noncestr
jsapi_ticket
timestamp
url
第四步 把获得的结果传到前台即可 遇到的问题,主要是 报这个 config invalid signature
用jsskd自带的签名工具验签 发现没有问题,但是无论如何就是报签名错误。然后google了好多,最后发现原来是url的问题: 前端需要转码 需要转码 需要转码 ,后台需要解码 需要解码 需要解码。
前端:url在JavaScript中千万别忘记“encodeURIComponent”!
url在JavaScript中千万别忘记“encodeURIComponent”!
url在JavaScript中千万别忘记“encodeURIComponent”!
后台:
public String sharing(HttpServletRequest request, HttpServletResponse response){
String url = request.getParameter("url"); //分享链接url
try {
logger.info("beforeDecode:" + url);
url = URLDecoder.decode(url,"utf-8");
logger.info("afterEncode:" + url);
} catch (UnsupportedEncodingException e) {
e.printStackTrace();
}
return wXSharingService.sharing(url,response);
}
微信jssdk 返回的 config invalid signature的更多相关文章
- 微信分享链接出现config:invalid signature错误的解决方法
首先贡献jssdk下载地址:http://demo.open.weixin.qq.com/jssdk/sample.zip 不建议大家在*SDN上花钱买积分下载 当开发微信时需要做特定的页面做分享时 ...
- Vue微信自定义分享时安卓系统config:ok,ios系统config:invalid signature签名错误,或者安卓和ios二次分享时均config:ok但是分享无效的解决办法
简述需求:要求指定页面可以进行微信自定义分享(自定义标题,描述,图片,链接),剩下的页面隐藏所有基础接口.二次分享依然可以正常使用,切换至其他页面也可以正常进行自定义分享. 这两天在做微信自定义分享的 ...
- 微信jssdk config:invalid signature 签名错误 ,问题排查过程
invalid signature签名错误.建议按如下顺序检查: 确认签名算法正确,可用 http://mp.weixin.qq.com/debug/cgi-bin/sandbox?t=jsapisi ...
- 微信网页分享 jssdk config:invalid signature 签名错误
invalid signature签名错误.建议按如下顺序检查: 确认签名算法正确,可用 http://mp.weixin.qq.com/debug/cgi-bin/sandbox?t=jsapisi ...
- 调用微信公众平台扫一扫示例及解决接口报错 { "errMsg": "config:invalid signature" }
一.解决报错问题 单从报错信息 invalid signature 就可以看出是 签名signature 有问题, 查了很多资料,终于知道了问题点, 后台让我直接调接口是不对的,签名是根据请求接口的页 ...
- 微信公众号报错 config:invalid signature
官方已经提供了微信 JS 接口签名校验工具(http://mp.weixin.qq.com/debug/cgi-bin/sandbox?t=jsapisign),填入相应的参数就能出来相应的signa ...
- 在做微信分享到朋友圈时,手机扫码报config:invalid signature,分享后后正常的问题,是url问题
是按照以下步骤检查的 除了ACCESS_TOKEN没有缓存其他都可以 如果是invalid signature签名错误.建议按如下顺序检查: 1.确认签名算法正确,可用 http://mp.weixi ...
- 微信分享报错config:invalid url domain
错误类型:invalid url domain 调试返回参数: { "errMsg": "config:invalid url domain" } 截图: 环境 ...
- 微信公众号签名错误 invalid signature
在出现了 invalid signature签名错误后按照以下步骤进行校验1.确认签名算法正确,可用 http://mp.weixin.qq.com/debug/cgi-bin/sandbox?t=j ...
随机推荐
- python2.x提示这个错误:UnicodeDecodeError: 'ascii' codec can't decode byte 0xe8 in position
查了好久下面这个方法可用: 发现应该是因为python2.x的默认编码是ascii,而代码中可能由utf-8的字符导致,解决方法是设置utf-8. 找到出错的文件,在import后增加下面几行: #! ...
- pyinstaller打包工具简单使用
python脚本如果在没有安装python的机器上不能运行,所以将脚本打包成exe文件将可跨平台使用,那么怎么打包了,python提供了专门的模块:pyinstaller,下面就介绍下怎么用 1.安装 ...
- 在win7系统设置SQL Server2014 express为远程数据
如何设置远程访问到SQLserver服务器(局域网内的设置) 1.首先,使用Windows+R键 输入services.msc 打开本地服务. *说明:①MSSQLSERVER是正式使用的SQL创建实 ...
- $bzoj1014-JSOI2008$ 火星人$prefix$ $splay$ $hash$
题面描述 火星人最近研究了一种操作:求一个字串两个后缀的公共前缀.比方说,有这样一个字符串:\(madamimadam\),我们将这个字符串的各个字符予以标号: 序号 1 2 3 4 5 6 7 8 ...
- EC2 Instance扩容EBS卷容量
EC2实例运行一段时间后,由于日志和一些应用程序数据的积累,可能出现之前预留的磁盘容量不够需要扩容的情况.AWS EBS目前还不支持在线扩容,不过可以通过结合snapshot来实现. 如,我的EC2 ...
- 使用not in的子查询
operand comparison_operator [NOT] in (subquery) =ANY运算符与IN等效 !=ALL或<>ALL运算符与NOT IN 等效 如果子查询返回任 ...
- Http请求响应模型
主要用到以下四个部分: Client API DB API 场景:登录 1.Client发起请求到API接口层 1.1用户在客户端输入登录信息,点击登录,发送请求 2.API接受用户发起的 ...
- 【CSS】 一个简单的导航条
今天来做一个导航条! 首先写一个坯子: <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" &quo ...
- 带双反斜杠的Json数据至单反斜杠的Json数据处理
假如你光看标题,你只能哦呵呵了!我也看不懂.还是先描述下问题吧.这里是使用微信接口返回了一些数据.因为该串数据包含html标签所以TX是对该串数据进行了编码的.所有的数据是通过Unicode编码的,然 ...
- html中 alt 和 title 的区别
alt 用来给图片来提示的(图片载入失败时以文本形式提示). Title用来给链接文字或普通文字提示的(在鼠标放上去的时候就会提示).