调用wx.login,在成功回调中,拿自己小程序的appId、secret请求接口 url: ' https://api.weixin.qq.com/sns/jscode2session?appid=' + appId + '&secret=' + secret + '&js_code=' +code + '&grant_type=authorization_code',请求成功即可拿到openid和session-key
小程序的appId必须要在微信公众平台完成微信认证(里面需要上传一些企业的一些证件和信息)才能有获取用户手机号的权限
最后拿用户的获取到的e.detail.iv、和e.detail.encryptedData(加密的手机号)和前面拿到过的session-key传给后台,交给后台解密即可
具体解密规则参考官方文档:( https://developers.weixin.qq.com/miniprogram/dev/framework/open-ability/getPhoneNumber.html )
我遇到的情况是:{ errMsg: "cloud.callFunction:ok", result: null }
方法一:先检查是否在开发前安装好nods.js和npm;
在cmd输入:
node -v
npm -v
可以看到安装好的对应版本;
云函数中使用 wx-server-sdk 需在对应云函数目录下安装 wx-server-sdk 依赖,可通过:
npm install --save wx-server-sdk@latest安装;
最后会提示:+wx-server-sdk@版本号。
成功安装依赖后,相应的云函数文件夹将生成一个package-lock.json文件。
再次上传并部署云函数:所有文件。
方法二:
在云端和本地上都要删除函数,再重新创建和上传,也许问题就会解决了!
方法三:
在云端上删除已经部署过的login函数:再次上传的时候可能会出现:
"Code": "ResourceNotFound.Function", "Message": "未找到函数版本,请创建后再...
然后此时在云端上新建函数,如下图:
再次上传并部署云函数,此时提醒函数已存在,不能重复上传,此时编译一下。
发现原本获取openid值为null的,现在能够成功获取到了用户的openid。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)