当前位置: 移动技术网 > IT编程>开发语言>PHP > 微信小程序获取用户手机号

微信小程序获取用户手机号

2019年11月14日  | 移动技术网IT编程  | 我要评论

龙之谷兽娘加点,围观叶孤城的日子,大哥大电影

前端通过微信接口获取这三个参数

$code = input('post.code');
$encrypteddata = urldecode(input('post.encrypteddata'));
$iv = input('post.iv');

首先  我们拿code去curl获取到用户的信息 (openid,session_key)

然后  通过session_key,appid,encryptedata,iv 这几个参数 通过官方demo 的解密方式 获取到信息 

最后  电话号入库就结束了!

整合了下demo

    public function wxtel()
    {

        $code = input('post.code');
        $encrypteddata = urldecode(input('post.encrypteddata'));
        $iv = input('post.iv');

        /**
         * 获取用户的openid和session_key
         */
        $appid='wx3bde8f37288981f3';
        $secret='4dc2c819e4c84594535e9f880eed9386';
        $url = "https://api.weixin.qq.com/sns/jscode2session?appid=$appid&secret=$secret&js_code=$code&grant_type=authorization_code";
        $ch = curl_init();
        $timeout = 5;
        curl_setopt($ch, curlopt_url, $url);
        curl_setopt($ch, curlopt_returntransfer, 1);
        curl_setopt($ch, curlopt_connecttimeout, $timeout);
        $contents = curl_exec($ch);
        curl_close($ch);
        $info = json_decode($contents,true);

        /**
         * 获取加密电话数据
         */
        $openid = $info['openid'];
        $sessionkey = $info['session_key'];

        $errcode = $this->decryptdata($appid,$sessionkey,$encrypteddata, $iv, $data );

        if ($errcode == 0) {
            $datas['tel'] = $data->phonenumber;
            $datas['openid'] = $openid;
            $datas['add_time'] = date('y-m-d h:i:s');
            $telmodel = new telmodel();
            $status = $telmodel->insertrow($datas);
            $return['code'] = $status ? 200:300;
            $return['data'] = $status;
        } else {
            $return['code'] = 301;
            $return['data'] = $errcode;
        }

        return json_encode($return);

    }


    /**
     * 检验数据的真实性,并且获取解密后的明文.
     * @param $encrypteddata string 加密的用户数据
     * @param $iv string 与用户数据一同返回的初始向量
     * @param $data string 解密后的原文
     *
     * @return int 成功0,失败返回对应的错误码
     */
    private function decryptdata( $appid,$sessionkey,$encrypteddata, $iv, &$data )
    {
        if (strlen($sessionkey) != 24) {
            return -41001;
        }
        $aeskey=base64_decode($sessionkey);


        if (strlen($iv) != 24) {
            return -41002;
        }
        $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 -41003;
        }
        if( $dataobj->watermark->appid != $appid )
        {
            return -41004;
        }
        $data = $dataobj;
        return 0;
    }

这里遇到个坑  

encryptedata 这个值 在前端传给后端的时候 会发生变化 导致解密结果为空 报错-41003  解决方法:后端接收的时候urldecode一下即可

有时候会报-41001 解决办法:php的json字符串有时候加上反斜杠”\”来转义,php处理时需要先去掉反斜杠,然后再json_decode

  $str = stripslashes($json); 
  $arr = json_decode($str,true);

使用stripslashes()函数,问题解决!

如对本文有疑问,请在下面进行留言讨论,广大热心网友会与你互动!! 点击进行留言回复

相关文章:

验证码:
移动技术网