PHP請(qǐng)求微信接口獲取用戶電話號(hào)功能示例
業(yè)務(wù)場(chǎng)景是為了在用戶登錄的時(shí)候判斷其是否已經(jīng)成功注冊(cè),沒有成功注冊(cè)的話就將獲取到的openid和session_key加密后作為token傳給前端,然后讓前臺(tái)通過組件獲得code之后連著token一起傳給后端,后端拿著code再去請(qǐng)求微信接口獲取到用戶的電話號(hào)碼,以此完成注冊(cè)。
實(shí)現(xiàn)過程中的問題結(jié)合微信官方手冊(cè):phonenumber.getPhoneNumber | 微信開放文檔 (qq.com)
怪我沒好好看手冊(cè),中間發(fā)生了hin多的插曲。比如報(bào)錯(cuò)返回:
require POST method hint errcode: 43002
一查文檔告訴我:這個(gè)請(qǐng)求需要用post請(qǐng)求!可是,我明明是用的post請(qǐng)求啊~~~
后面通過面向百度編程,在找了5678個(gè)公共發(fā)起post請(qǐng)求的方法之后,終于有一個(gè)post請(qǐng)求沒問題,但又遇到了一個(gè)問題,他返回: [0,null]
這里的原因是比較讓我耗費(fèi)時(shí)間的:這個(gè)接口的請(qǐng)求,必須在用戶處于登錄的條件下,并且必須在互聯(lián)網(wǎng)能夠訪問到的公共網(wǎng)站上(也就是得在我的項(xiàng)目配置好的域名下去請(qǐng)求,才能夠返回值!)我在本地試了好久,氣煞我也!
如果你后面寫好了對(duì)返回值的判斷的話會(huì)報(bào)錯(cuò):
Trying to access array offset on value of type null 。
就是告訴你不能嘗試將 null,bool,int,float 或 resource 類型的值用作數(shù)組 ( 例如 $null[“key”] ) 會(huì)產(chǎn)生一個(gè)通知。
遇到的這個(gè)問題我是萬萬妹想到,搞了整整一下午,最后在公司大佬的幫助下半個(gè)小時(shí)幫我解決了問題。ps:第一個(gè)參數(shù)access_token那是輕輕松松(有問題可以看看和我的代碼哪里不同)
廢話不多say,上代碼!common.php中
/** * 發(fā)送curl get * @param string $url * @return mixed */function curl_get($url){ $oCurl = curl_init(); if (stripos($url, 'https://') !== FALSE) {curl_setopt($oCurl, CURLOPT_SSL_VERIFYPEER, FALSE);curl_setopt($oCurl, CURLOPT_SSL_VERIFYHOST, FALSE);curl_setopt($oCurl, CURLOPT_SSLVERSION, 1); //CURL_SSLVERSION_TLSv1 } if (defined('CURLOPT_IPRESOLVE') && defined('CURL_IPRESOLVE_V4')) {curl_setopt($oCurl, CURLOPT_IPRESOLVE, CURL_IPRESOLVE_V4); } curl_setopt($oCurl, CURLOPT_URL, $url); curl_setopt($oCurl, CURLOPT_RETURNTRANSFER, 1); $sContent = curl_exec($oCurl); $aStatus = curl_getinfo($oCurl); curl_close($oCurl); if (intval($aStatus['http_code']) == 200) {return $sContent; } else {return false; }}if (!function_exists('http_post_json')){ //這一行是判斷公共方法有無這個(gè)方法,避免重名~ /** * PHP發(fā)送Json對(duì)象數(shù)據(jù) * @param $url string * @param $jsonStr string * @param string[] $headers * @return array */ function http_post_json(string $url, string $jsonStr, array $headers = array('Content-Type: application/json; charset=utf-8', )): array {$headers[] = 'Content-Length: ' . strlen($jsonStr);$ch = curl_init();curl_setopt($ch, CURLOPT_POST, 1);curl_setopt($ch, CURLOPT_URL, $url);curl_setopt($ch, CURLOPT_POSTFIELDS, $jsonStr);curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);curl_setopt($ch, CURLOPT_HTTPHEADER, $headers);$response = curl_exec($ch);$httpCode = curl_getinfo($ch, CURLINFO_HTTP_CODE);curl_close($ch);return array($httpCode, $response); }}調(diào)用接口代碼:(有空可以自己封裝一下~)
/**必須先進(jìn)入登錄狀態(tài),然后拿到phone的code去請(qǐng)求然后拿到access_code,請(qǐng)求phone的接口 */ $appid = getConfig('appid_y'); //填寫自己的appid,小程序中看 $secret = getConfig('secret_y'); //填自己的secret,公眾平臺(tái)看 $url = 'https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid=$appid&secret=$secret'; $access_token = json_decode(curl_get($url),true);if(isset($access_token['errcode']))return ['errcode'=>$access_token['errcode'],'msg'=>'請(qǐng)求失敗','data'=>$access_token]; $access_token = $access_token['access_token']; //獲取到了access_token //請(qǐng)求電話號(hào)使用方法只能在公網(wǎng)能訪問的目錄下進(jìn)行,本地進(jìn)行沒有返回值 $url = 'https://api.weixin.qq.com/wxa/business/getuserphonenumber?access_token='.$access_token; $json_code = json_encode(['code'=>$param['code']]); $headers = ['Accept: application/json','User-Agent: */*','Content-Type: application/json; charset=utf-8', ]; $phone = http_post_json($url,$json_code,$headers); $phone[1] = json_decode($phone[1],true); if(empty($phone[1])||$phone[1]['errcode']!=0)throw new Exception('系統(tǒng)獲取手機(jī)號(hào)失敗'); $phoneNumber = $phone[1]['phone_info']['phoneNumber']; /**拿到電話號(hào)碼end */另外,thinkphp5獲取微信授權(quán)用戶手機(jī)號(hào)的相關(guān)實(shí)現(xiàn)方法,可參考前面一篇:https://www.jb51.net/article/229956.htm
相關(guān)文章:
1. PHP與MYSQL數(shù)據(jù)庫(kù)連接2. PHP輸入流php://input的使用分析3. PHP基礎(chǔ)之生成器4——比較生成器和迭代器對(duì)象4. 詳解PHP laravel中的加密與解密函數(shù)5. 編寫自己的php擴(kuò)展函數(shù)6. PHP+TEXT留言本(五)7. 數(shù)據(jù)結(jié)構(gòu)之利用PHP實(shí)現(xiàn)二分搜索樹8. PHP5.3閉包特性及應(yīng)用詳解9. PHP JSAPI調(diào)支付API實(shí)現(xiàn)微信支付功能詳解10. php采用數(shù)據(jù)庫(kù)保存session

網(wǎng)公網(wǎng)安備