zoukankan      html  css  js  c++  java
  • 微信小程序获取用户手机号

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

    $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()函数,问题解决!

  • 相关阅读:
    手动删除木马程序
    病毒注册表常用目标Svchost和Explorer
    对电脑假死现象的修复
    "添加与删除程序"报rundll32错误
    通过注册表regedit对Windows回收站进行恢复
    Win7的话,可能有十种简单的方法进行提速呢
    Windows死机的话,可能的一些猫病
    Android开发发布真机调试
    Java Web-----JSP与Servlet(一)
    Java——Log4j与Log4j2
  • 原文地址:https://www.cnblogs.com/zmdComeOn/p/11857266.html
Copyright © 2011-2022 走看看