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

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

$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一下即可

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值