微信小程序获取用户手机号
程序员文章站
2022-10-28 09:45:20
前端通过微信接口获取这三个参数 $code = input('post.code'); $encryptedData = urldecode(input('post.encryptedData')); $iv = input('post.iv'); 首先 我们拿code去curl获取到用户的信息 ( ......
前端通过微信接口获取这三个参数
$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()函数,问题解决!