获取小程序 openid 返回 null 问题解决

简介: 获取小程序 openid 返回 null 问题解决

获取小程序 openid 返回 null

登录 wx.login() 获取到 code,为了安全 session_key 和 openid 不暴露在客户端,而且

https://api.weixin.qq.com

不能设置白名单,需要使用 code 在服务端换取 session_key 和 openid

之前小程序服务一直正常,无提交任何代码,突然获取openid失败,搜索各种文章解决,遇到各种问题 41004 ,40163,code 只能使用一次没问题,Peer certificate CN=miniapi.x.com' did not match expected CN=api.weixin.qq.com`
DNS服务器无法连接,ping 过发现没有问题,etc/host 配置也没问题,关联公众号白名单也设置了,后端换两种写法也不行。
设置关联小程序的公众号添加IP白名单

看以下步骤

先打印出来 app.js

    globalData: {
   
        appid: 'wx7db46aji5jf6',//小程序appid,需自己提供
        secret: '9cb98jjk57okp245sd',//小程序密钥,需自己提供
        hasLogin: false,
        openid: null,
        firstTime: true,
        accessToken: null
    },
    getUserOpenId: function() {
   
        var that = this;
        //登录
        wx.login({
   
            success: function(res) {
   
              console.log(res)//打印code
              var d = that.globalData;//这里存储了appid、secret、token串  
              var l = 'https://api.weixin.qq.com/sns/jscode2session?appid=' + d.appid + '&secret=' + d.secret + '&js_code=' + res.code + '&grant_type=authorization_code';
              console.log(l)打印 curl
              //以下代码会报错 https://api.weixin.qq.com 不在以下 request 合法域名列表中,也不能设置IP白名单,而且为了安全客户端不暴露 session_key 和 openid,只能服务端获取
              wx.request({
   
                url: l,
                data: {
   },
                method: 'GET',
                // header: {}, // 设置请求的 header  
                success: function (res) {
   
                  console.log(res)
                  var obj = {
   };
                  obj.openid = res.data.openid;
                  obj.expires_in = Date.now() + res.data.expires_in;
                  console.log(obj);
                  //wx.setStorageSync('user', obj);//存储openid  
                }
              });


        /*
        //code 获取 openid 的正确方式,code每次都是最新的而且只能使用一次
        wx.request({
                    url: that.apis.domain + that.apis.login,
                    header: {
                        "Content-Type": "application/x-www-form-urlencoded"
                    },
                    method: 'POST',
                    data: {
                        code: res.code
                    },
                    success: function(res) {
                        if(res.data.status == 1){
                            //console.log('拉取openid成功', res);
              console.log(res)
                            that.globalData.hasLogin = true;
                            that.globalData.openid = res.data.data.openid;
                            that.firstTime(res.data.data.openid);
                        } else {
                            that.globalData.hasLogin = false;
                            //console.log('拉取openID失败,将无法正常使用开放接口等服务',res);
                        }
                    },
                    fail: function(res) {
                        console.log('拉取用户openid失败,将无法正常使用开放接口等服务', res)
                        callback(res)
                    }
                })
        */
            },
            fail: function(err) {
   
                console.log('wx.login 接口调用失败,将无法正常使用开放接口等服务', err)
                callback(err)
            }
        })
    },

看打印结果 code 和 url
B4090E41_26F6_44A8_99EF_9F4BF42F0370

在 postman 测试,先使用 code 请求后端接口,返回 null
1564566554519

把 url 拿出来直接在 postman 请求每次都是成功的,确认是后端服务的问题
1564566948437

把 url 放在服务器直接 curl,各种报错来了 "errcode":41004,"errmsg":"appsecret missing 各种方法用过没有解决问题
B28E2F4A_1B59_4255_9EB6_4973E6953FC5

最后设置关联小程序的公众号添加IP白名单后重启服务器问题解决了,没有更改任何代码

目录
相关文章
|
小程序 JavaScript
小程序云开发获取openid及出现openid是undefind的坑
小程序云开发获取openid及出现openid是undefind的坑
716 0
|
存储 算法 NoSQL
还分不清 Cookie、Session、Token、JWT?看这一篇就够了
Cookie、Session、Token 和 JWT(JSON Web Token)都是用于在网络应用中进行身份验证和状态管理的机制。虽然它们有一些相似之处,但在实际应用中有着不同的作用和特点,接下来就让我们一起看看吧,本文转载至http://juejin.im/post/5e055d9ef265da33997a42cc
48713 13
|
小程序 前端开发 API
【微信小程序】TypeError: Cannot read property ‘get‘ of undefined & Error: MiniProgramError
【微信小程序】TypeError: Cannot read property ‘get‘ of undefined & Error: MiniProgramError
|
缓存 Java Nacos
nacos常见问题之无法注册如何解决
Nacos是阿里云开源的服务发现和配置管理平台,用于构建动态微服务应用架构;本汇总针对Nacos在实际应用中用户常遇到的问题进行了归纳和解答,旨在帮助开发者和运维人员高效解决使用Nacos时的各类疑难杂症。
2890 7
|
12月前
|
缓存 Java 测试技术
分享干货:idea常用快捷键分类总结(适合速查~~建议收藏♥)
本文以分类的形式总结了IDEA常用、好用快捷键,全是干货~
4019 1
分享干货:idea常用快捷键分类总结(适合速查~~建议收藏♥)
|
缓存 IDE Java
maven install报错原因揭秘:‘parent.relativePath‘指向错误的本地POM文件
在使用Maven构建项目时,遇到'parent.relativePath'错误通常是由于父项目POM路径设置错误、版本不一致或内容不匹配导致的。解决方法包括:校正父项目POM的相对路径、确保版本一致、保持POM文件内容同步,并排查其他潜在问题,如子模块命名冲突和Maven缓存问题。通过这些步骤可解决该错误,避免项目构建失败。
maven install报错原因揭秘:‘parent.relativePath‘指向错误的本地POM文件
使用npm,快速构建第一个vue项目
本文介绍了如何使用npm快速构建第一个Vue项目。步骤包括确保安装了Node.js并且配置了正确的环境变量,创建一个空文件夹并使用VSCode打开,通过VSCode的终端执行`npm init vue@latest`命令以初始化项目,选择默认配置即可。接着安装项目依赖并启动开发服务器,最后通过浏览器访问开发服务器提供的本地地址查看项目运行结果。文章还提供了相关代码和操作截图。
|
存储 Java API
阿里云OSS使用购买流程
本文介绍了阿里云对象存储OSS的基本使用,包括准备工作、购买开通阿里云账号并进行实名认证,以及通过Web控制台、命令行工具ossutil和SDK进行文件操作。此外,还提到了RESTful API和图形化工具OSSBrowser的使用,并给出了Java SDK下载对象的示例代码。文章内容包括了OSS的基本概念,如存储空间Bucket和对象Object,以及不同类型的存储类型。
|
Java 编译器 Spring
面试突击78:@Autowired 和 @Resource 有什么区别?
面试突击78:@Autowired 和 @Resource 有什么区别?
16547 6
vue2 插槽(默认插槽 slot 、具名插槽 v-slot 、作用域插槽 slot-scope -- 插槽传值 )
vue2 插槽(默认插槽 slot 、具名插槽 v-slot 、作用域插槽 slot-scope -- 插槽传值 )
3064 1