微信授权获取用户openId等信息

在我们开发小程序的时候,需要通过授权获取用户的信息。

第一种使用wx.getUserInfo直接获取微信头像,昵称
// 必须是在用户已经授权的情况下调用
wx.getUserInfo({
    success: function(res) {
        var userInfo = res.userInfo
        var nickName = userInfo.nickName
        var avatarUrl = userInfo.avatarUrl
        var gender = userInfo.gender //性别 0:未知、1:男、2:女
        var province = userInfo.province
        var city = userInfo.city
        var country = userInfo.country
    }
})
第二种方式使用wx.login()

这种方式即将被放弃,目前使用比较多的是的wx.login()。因为直接使用wx.getUserInfo是不能获取更多的信息的,如微信用户的openid。 官方提示,需要发送获取到的code进行请求到微信的后端API。根据文档,只需要进行一个get请求到如下地址即可:
https://api.weixin.qq.com/sns/jscode2session?appid=APPID&secret=SECRET&js_code=JSCODE&grant_type=authorization_codeappid和secret在微信小程序后台可以看到,
js_code为使用wx.login登录时获取到的code参数数据,grant_type这个不用改动。

官方推荐

在login获取到code,然后发送到开发者后端,后端再通过接口去微信后端换取到openid和sessionKey之后,然后把session返回给前端,就已经完成登录行为。而login行为是静默,不必授权的,不会对用户造成骚扰。getUserInfo只是为了提供更优质的服务而存在,比如展示头像昵称,判断性别,通过unionId和其他公众号上已有的用户画像结合起来提供历史数据。所以不必在刚刚进入小程序的时候就强制要求授权。相关代码如下所示。

JS代码
var userInfo= (wx.getStorageSync('userInfo'))
        if (userInfo) {
          wx.getUserInfo({
            success: function (res) {
              that.setData({
                nickName: res.userInfo.nickName,
                avatarUrl: res.userInfo.avatarUrl,
              })
            },
            fail: function () {
              console.log("获取失败!")
            },
            complete: function () {
              console.log("获取用户信息完成!")
            }
          })
        } else {
          wx.login({
            success: function (res) {
              console.log(res.code)
              if (res.code) {
                wx.getUserInfo({
                  withCredentials: true,
                  success: function (res_user) {
                    wx.request({
                     //后台接口地址
                      url: 'https://xxxx.com/wx/login',
                      data: {
                        code: res.code
                      },
                      method: 'GET',
                      header: {
                        'content-type': 'application/json'
                      },
                      success: function (res) {
                        that.setData({
                          userInfo: res.errMsg.userInfo
                        })
                        wx.setStorageSync('userInfo', res.data.userInfo);

                      }
                    })
                  }, fail: function () {
                    wx.showModal({
                      title: '警告通知',
                      content: '您点击了拒绝授权,将无法正常显示个人信息,点击确定重新获取授权。',
                      success: function (res) {
                        if (res.confirm) {
                          wx.openSetting({
                            success: (res) => {
                              if (res.authSetting["scope.userInfo"]) {////如果用户重新同意了授权登录
                                wx.login({
                                  success: function (res_login) {
                                    if (res_login.code) {
                                      wx.getUserInfo({
                                        withCredentials: true,
                                        success: function (res_user) {
                                          wx.request({
                                           url: 'https://xxxx.com/wx/login',
                                            data: {
                                              code: res_login.code
                                             },
                                            method: 'GET',
                                            header: {
                                              'content-type': 'application/json'
                                            },
                                            success: function (res) {
                                              that.setData({
                                                userInfo: res.errMsg.userInfo

                                              })
                                              wx.setStorageSync('userInfo', res.errMsg.userInfo);
                                            }
                                          })
                                        }
                                      })
                                    }
                                  }
                                });
                              }
                            }, fail: function (res) {

                            }
                          })

                        }
                      }
                    })
                  }, complete: function (res) {

                  }
                })
              }
            }
          })

        }
  },
//globalData建议放在app.js,方便统一管理
  globalData: {   
    userInfo: null
  }

后端代码

由于我的后端是PHP写的,用的是thinkphp5框架,框架地址:https://www.kancloud.cn/manual/thinkphp5/118003

 /**
     * 小程序登录
     * @return array
     */
    public function login() {

        $code = input('post.code'); //这是从前端传过来的code
        $userInfo = input('post.userInfo');
        $info = json_decode($userInfo, true);
        $user = $info['userInfo'];
        $memberModel = model('Member');
        $appid = "小程序的appid"; //一定要是小程序的appid,不是微信公众号的appid
        $secret = "小程序的secret";
        $url = "https://api.weixin.qq.com/sns/jscode2session?appid=". $appid."&secret=".$secret."&js_code=" . $code . "&grant_type=authorization_code";
        //初始化curl
        $ch = curl_init($url);
        //3.设置参数
        curl_setopt($ch,CURLOPT_RETURNTRANSFER,1);
        curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, false);//跳过证书验证
        curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, false);  // 从证书中检查SSL加密算法是否存在
        $res = curl_exec($ch);
        if(curl_errno($ch)){
            var_dump(curl_error($ch));
        }
        $resArr = json_decode($res,1);
        $data = array();
        curl_close($ch);
        $mapData = array();

//这里我把用户的信息保存起来,方便下次调用,数据库结构我们在下面会介绍
        if (!empty($resArr['openid'])) {
            $res = $memberModel->checkMember($resArr['openid']);
            Log::write('用户信息:' . $memberModel->getLastSql());
            if ($res) {
                $mapData['userInfo'] = $res;
                $mapData['session_key'] = $resArr['session_key'];
                return $this->resMap(200, $mapData, $mapData);
            } else {
                $data['nickName'] = $user['nickName'];
                $data['avatarUrl'] = $user['avatarUrl'];
                $data['m_province'] = $user['province'];
                $data['m_city'] = $user['city'];
                $data['m_gender'] = $user['gender'];
                $data['m_language'] = $user['language'];
                $data['signature'] = $info['signature'];
                $data['iv'] = $info['iv'];
                $data['m_uuid'] = showUuid();
                $data['m_openid'] = $resArr['openid'];
                $data['m_country'] = $resArr['country'];
                $data['m_ip'] = GetIP();
                $data['m_createtime'] = getDateTime(1);
                $memberModel->addOne($data);
                $mapData['userInfo'] = $data;
                $mapData['session_key'] = $resArr['session_key'];
                return $this->resMap(200, $mapData, $mapData);
            }
        } else {
            return $this->resMap(4002, '登录失败', '登录失败');
        }
    }

 /**
     * 返回提示信息
     * @param $code string 错误码  4001 空值  4002 格式不正确  4003 长度  4004 提示  200正确放回 ,0失败
     * @param $msg string 错误描述
     * @param $data string 返回值
     * @return array
     */
    public function resMap($code, $msg, $data)
    {
        $map = array();
        $map['errMsg'] = $msg;
        $map['data'] = $data;
        $map['errCode'] = $code;
        return json($map);
    }

以上就是核心代码,希望对大家有用。在上面,我们需要保存用户的信息,因此我们需要数据库表,下面就谈到表的设计。

用户表的设计
SET FOREIGN_KEY_CHECKS=0;
-- ----------------------------
-- Table structure for `system_member`
-- ----------------------------
DROP TABLE IF EXISTS `system_member`;
CREATE TABLE `system_member` (
  `m_id` INT(11) NOT NULL AUTO_INCREMENT,
  `nickName` VARCHAR(50) DEFAULT NULL COMMENT '用户昵称',
  `avatarUrl` VARCHAR(255) DEFAULT NULL COMMENT '头像',
  `m_province` VARCHAR(40) DEFAULT NULL COMMENT '省份',
  `m_city` VARCHAR(50) DEFAULT NULL COMMENT '城市',
  `m_name` VARCHAR(30) DEFAULT NULL COMMENT '真实姓名',
  `m_gender` TINYINT(1) DEFAULT '3' COMMENT '用户性别(1、男 2、女 3、未知)',
  `m_createtime` DATETIME DEFAULT NULL COMMENT '创建时间',
  `m_country` VARCHAR(100) DEFAULT NULL COMMENT '国家',
  `m_language` VARCHAR(50) DEFAULT NULL COMMENT '语言',
  `m_openid` VARCHAR(50) DEFAULT NULL COMMENT 'openID',
  `m_ip` VARCHAR(15) DEFAULT NULL COMMENT 'IP',
  `m_mobile` VARCHAR(20) DEFAULT NULL COMMENT '手机号码',
  `m_uuid` VARCHAR(50) DEFAULT NULL,
  `m_username` VARCHAR(50) DEFAULT NULL COMMENT '用户名',
  `m_pwd` VARCHAR(50) DEFAULT NULL COMMENT '密码',
  `session_key` VARCHAR(255) DEFAULT NULL COMMENT '会话密钥',
  `unionid` VARCHAR(255) DEFAULT NULL COMMENT '用户在开放平台的唯一标识符',
  `signature` VARCHAR(255) DEFAULT NULL,
  `iv` VARCHAR(255) DEFAULT NULL,
  `k_id` VARCHAR(50) DEFAULT NULL,
  `k_openid` VARCHAR(80) DEFAULT NULL,
  PRIMARY KEY (`m_id`)
) ENGINE=INNODB AUTO_INCREMENT=9 DEFAULT CHARSET=utf8 COMMENT='获取用户小程序信息';

以上就是获取用户信息的完整流程,下面我们附上一张用户登录的流程图。

流程图

以上就是全部内容,希望对大家有用,谢谢大家(__) 嘻嘻……

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,776评论 6 496
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,527评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,361评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,430评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,511评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,544评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,561评论 3 414
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,315评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,763评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,070评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,235评论 1 343
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,911评论 5 338
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,554评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,173评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,424评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,106评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,103评论 2 352

推荐阅读更多精彩内容