• .NET 微信开发 JSSDK配置 wx.config调用 invalid signature签名错误分析


       官方文档 要认真看一遍之后,开始搞

       JSSDK是网页调用微信功能的配置文件。在这里浪费了大量时间  所以记录一下。(吐槽下微信返回的错误信息,也是没谁了。。。)

    页面先配置一下。注释里几个参数,可以用ajax会获取。

    <script type="text/javascript">
        wx.config({
            debug: false, // 开启调试模式,调用的所有api的返回值会在客户端alert出来,若要查看传入的参数,可以在pc端打开,参数信息会通过log打出,仅在pc端时才会打印。
            appId: '@ViewBag.AppID', // 必填,公众号的唯一标识
            timestamp: @ViewBag.timestamp, // 必填,生成签名的时间戳    <%= Html.Encode(ViewData["timestamp" ]) %>
            nonceStr: '@ViewBag.nonceStr', // 必填,生成签名的随机串
            signature: '@ViewBag.signature', // 必填,签名
            jsApiList: ['scanQRCode'] // 必填,需要使用的JS接口列表, 这里只需要调用扫一扫
        });
    
        $(function() {
            //console.log(location.href);
            //alert(location.href.split('#')[0]);
    
            $(".btnsis").click(function() {
                alert('ee');
                var ua = navigator.userAgent.toLowerCase();
                var isWeixin = ua.indexOf('micromessenger') !== -1;
                if (!isWeixin) {
                    alert('请用微信打开连接,才可使用扫一扫');
                }
                qrCode();
            });
    
            function qrCode() {
                wx.scanQRCode({
                    needResult: 1, // 默认为0,扫描结果由微信处理,1则直接返回扫描结果,
                    scanType: ["qrCode"], // 可以指定扫二维码还是一维码,默认二者都有
                    success: function (res) {
                        var result = res.resultStr; // 当needResult 为 1 时,扫码返回的结果
                        alert(result);
                    },
                    error:function(res) {
                        if (res.errMsg.indexOf('function_not_exist') > 0) {
                            alert('当前版本过低,请进行升级');
                        }
                    }
                });
            }
        });
    
    
    </script>

    官方常见错误处理方式:

    invalid signature签名错误。建议按如下顺序检查:

    1. 确认签名算法正确,可用http://mp.weixin.qq.com/debug/cgi-bin/sandbox?t=jsapisign 页面工具进行校验。

    2. 确认config中nonceStr(js中驼峰标准大写S), timestamp与用以签名中的对应noncestr, timestamp一致。

    3. 确认url是页面完整的url(请在当前页面alert(location.href.split('#')[0])确认),包括'http(s)://'部分,以及'?'后面的GET参数部分,但不包括'#'hash后面的部分。

    4. 确认 config 中的 appid 与用来获取 jsapi_ticket 的 appid 一致。

    5. 确保一定缓存access_token和jsapi_ticket。

    6. 确保你获取用来签名的url是动态获取的,动态页面可参见实例代码中php的实现方式。如果是html的静态页面在前端通过ajax将url传到后台签名,前端需要用js获取当前页面除去'#'hash部分的链接(可用location.href.split('#')[0]获取,而且需要encodeURIComponent),因为页面一旦分享,微信客户端会在你的链接末尾加入其它参数,如果不是动态获取当前链接,将导致分享后的页面签名失败。

    个人有关错误经验整理

    1.时间戳与签名是对应的,用同一时间,不能timestamp用了 datetime.now,签名(signature)不能再重新取了 datetime.now。会造成签名错误(可能时而正确,时而错误的情况)

    http://mp.weixin.qq.com/debug/cgi-bin/sandbox?t=jsapisign验证签名算法正确之后,还是出现错误:

    2.前端wx.config里的  nonceStr, 这个S是大写的,这个坑了很多开发者

    3.appid保持一致,正式appid与测试appid可能会搞混淆的,打日志看一下。

    4. 注意请求参数,不要写错了

     5.服务器JS域名是否配置:

    调用文章,参考链接:https://www.cnblogs.com/cr-cool/p/10959974.html

  • 相关阅读:
    让Controller支持对平铺参数执行@Valid数据校验
    @Validated和@Valid的区别?校验级联属性(内部类)
    Apache和Spring提供的StopWatch执行时间监视器
    Spring方法级别数据校验:@Validated + MethodValidationPostProcessor
    疑问
    第20章 链接详解(笔记)
    nm命令介绍
    使用Euclid算法求最大公约数
    Linux Man手册的使用示例
    VMware12 + Ubuntu16.04 虚拟磁盘扩容
  • 原文地址:https://www.cnblogs.com/cr-cool/p/12597667.html
Copyright © 2020-2023  润新知