PHP小程序登录并获取用户手机号

后端代码

public function login(){
 	$code = input("code");  //小程序获取的code
 	if (!$code) {
            return AjaxReturn(0,"缺少code");
          }

            $config = config("mini_program");
            $app_id = $config["app_id"];  //appid
            $app_secret = $config["app_secret"];  //app_secret

            if (!$app_id || !$app_secret) {
                return AjaxReturn(0,"小程序配置错误");
            }

            $url = "https://api.weixin.qq.com/sns/jscode2session?appid=".$app_id."&secret=".$app_secret."&js_code=".$code."&grant_type=authorization_code";
            $json = file_get_contents($url);
            $data = json_decode($json,true);
	 if (!isset($data["errcode"])) {
                if (isset($data["unionid"])) {
                    $where = ["unionid"=>$data["unionid"]];
                } else {
                    $where = ["openid"=>$data["openid"]];
                }
                 $iv = input("iv");  //小程序传的iv
                $encryptedData = input("encryptedData");
                $phone = $this->decryptData($iv,$data['session_key'],$encryptedData); //调用解密方法
                if(strlen($phone['phoneNumber']) > 0){ //判断是否解析成功
                  ....你的其他数据操作
                }else{
                    return AjaxReturn(0,'获取手机号失败',$phone);
                }
          }else {
                return AjaxReturn(0,"获取用户信息失败");
          }
}

获取手机号解密方法

 public function decryptData($iv,$session_key,$encryptedData)
    {
        $config = config("mini_program");
        if (strlen($session_key) != 24)return false;
        if (strlen($iv) != 24)return false;
//        $encryptedData = str_replace(' ','+',$encryptedData);
//        $iv = str_replace(' ','+',$iv);

        $aesKey=base64_decode($session_key);
        $aesIV=base64_decode($iv);
        $aesCipher=base64_decode($encryptedData);

        $result=openssl_decrypt($aesCipher, "AES-128-CBC", $aesKey, 1, $aesIV);
        $dataObj=json_decode($result);

        if($dataObj == NULL)return false;
        if($dataObj->watermark->appid != $config["app_id"])return false;
        $data = get_object_vars($dataObj);
        return $data;
    }
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
要在PHP中实现微信小程序授权获取用户信息并绑定手机号登录,可以按照以下步骤进行操作: 1. 在微信小程序端,通过`wx.login`获取用户的临时登录凭证`code`。 2. 将获取到的`code`发送到服务器端,使用`https`接口调用`code2Session`接口,获取到`openid`和`session_key`。 3. 将`openid`和`session_key`保存至服务器端数据库或缓存中。 4. 在小程序端,使用`wx.getUserInfo`获取用户信息,包括`nickName`、`avatarUrl`等,并将用户信息传输到服务器端。 5. 在服务器端,接收到用户信息后,将用户信息保存到服务器数据库中,可以使用`openid`作为用户的唯一标识。 6. 在小程序端,点击绑定手机号的按钮,调用`wx.request`向服务器发送请求,请求获取手机号的能力。 7. 在服务器端,接收到手机号请求后,可以返回一个包含手机号获取能力的`code`给小程序端。 8. 小程序端收到`code`后,调用`wx.request`向服务器发送请求,请求获取手机号。 9. 服务器端接收到获取手机号的请求后,可以通过调用微信开放平台提供的解密能力,解密包含手机号的数据,并将解密得到的手机号用户信息进行绑定。 10. 绑定成功后,返回相应的状态给小程序端。 总结:通过以上步骤,我们可以在PHP中实现微信小程序授权获取用户信息并绑定手机号登录的功能。在小程序端,用户使用微信授权登录后,将用户信息传输到服务器端保存,并通过绑定手机号使用户能够更便捷地登录和使用小程序。同时,在服务器端需要进行数据加密和解密的操作,确保用户的信息安全。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值