這篇文章主要介紹了PHP版微信第三方實現一鍵登入及獲取用戶資訊的方法,較為詳細的分析了微信第三方登陸的相關注意事項與實現技巧,需要的朋友可以參考下
注意,要使用微信在第三方網頁登入是需要「服務號碼」才可以哦,所以必須到官方申請。
一開始你需要進入微信公眾平台開啟開發模式,並且填寫oauth2的回呼地址,地址填寫你項目的域名就可以了.比如:www.baidu.com或zhidao.baidu. com.如果你的專案在二級網域就寫二級網域
前端url授權地址,在url中填寫appid與你專案中方法中的oauth的地址,具體在下面的程式碼中可以看到.
複製程式碼 程式碼如下:
再說後台邏輯,首先調用微信介面的SDK.(後面會有)
include('./Card/Common/class_weixin_adv.php');
#之後填入微信官方給的的appid與secret
$weixin=new class_weixin_adv("appid", "secret");
初始化SDK的類別,取到code,利用取得到的code在取得出openid 看下面程式碼註解!
$url="https://api.weixin.qq.com/sns/oauth2/access_token?appid=appid&secret=secret&code=".$_GET['code']."&grant_type=authorization_code"; $res = $weixin->https_request($url);//调用SDK方法获取到res 从中可以得到openid $res=(json_decode($res, true));//转换成array 方便调用openid
繼續呼叫SDK方法,取得到使用者資訊.此時$row已經取得使用者資訊了可以var_dump下看看鍵值方便存入資料庫
$row=$weixin->get_user_info($res['openid']);
取得使用者資訊就大功告成了,但這還不夠.我們需要的是無需註冊!所以需要利用openid,openid屬於唯一憑證,每個使用者對不同的公眾號都有不同的openid.可以理解成使用者帳號的感覺.我這裡用的是把openid存入cookie的解決方案,類似用戶登陸的感覺,一些關鍵數據驗證只需要與數據庫中的openid進行對比.其他的一些利用方法可以發揮大家的想像!可以跟我留言交流!
關於先前的a連結的授權,大家也可以判斷cookie是否存在openid,從而讓未授權使用者直接跳到該位址,省卻了使用者的一步操作.
以下是完整邏輯程式碼,大家可以參考下!
public function oauth2(){ include('./Card/Common/class_weixin_adv.php'); $weixin=new class_weixin_adv("appid", "secret"); if (isset($_GET['code'])){ $url="https://api.weixin.qq.com/sns/oauth2/access_token?appid=appid&secret=secret&code=".$_GET['code']."&grant_type=authorization_code"; $res = $weixin->https_request($url); $res=(json_decode($res, true)); $row=$weixin->get_user_info($res['openid']); if ($row['openid']) { //这里写上逻辑,存入cookie,数据库等操作 cookie('weixin',$row['openid'],25920); }else{ $this->error('授权出错,请重新授权!'); } }else{ echo "NO CODE"; } $this->display(); }
SDK程式碼:微信官方有手冊,我就不多講了,自己研究,很簡單的!
<?php /** * 微信SDK * pan041ymail@gmail.com */ class class_weixin_adv { var $appid = ""; var $appsecret = ""; //构造函数,获取Access Token public function __construct($appid = NULL, $appsecret = NULL) { if($appid){ $this->appid = $appid; } if($appsecret){ $this->appsecret = $appsecret; } $this->lasttime = 1395049256; $this->access_token = "nRZvVpDU7LxcSi7GnG2LrUcmKbAECzRf0NyDBwKlng4nMPf88d34pkzdNcvhqm4clidLGAS18cN1RTSK60p49zIZY4aO13sF-eqsCs0xjlbad-lKVskk8T7gALQ5dIrgXbQQ_TAesSasjJ210vIqTQ"; if (time() > ($this->lasttime + 7200)){ $url = "https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid=".$this->appid."&secret=".$this->appsecret; $res = $this->https_request($url); $result = json_decode($res, true); $this->access_token = $result["access_token"]; $this->lasttime = time(); } } //获取用户基本信息 public function get_user_info($openid) { $url = "https://api.weixin.qq.com/cgi-bin/user/info?access_token=".$this->access_token."&openid=".$openid."&lang=zh_CN"; $res = $this->https_request($url); return json_decode($res, true); } //https请求 public function https_request($url, $data = null) { $curl = curl_init(); curl_setopt($curl, CURLOPT_URL, $url); curl_setopt($curl, CURLOPT_SSL_VERIFYPEER, FALSE); curl_setopt($curl, CURLOPT_SSL_VERIFYHOST, FALSE); if (!empty($data)){ curl_setopt($curl, CURLOPT_POST, 1); curl_setopt($curl, CURLOPT_POSTFIELDS, $data); } curl_setopt($curl, CURLOPT_RETURNTRANSFER, 1); $output = curl_exec($curl); curl_close($curl); return $output; } }
總結:以上就是這篇文章的全部內容,希望能對大家的學習有所幫助。
相關推薦:
##JSON PHP中,Json字串反序列化成物件/陣列的方法
以上是PHP微信第三方實作一鍵登入及取得使用者資訊的方法(實例詳解)的詳細內容。更多資訊請關注PHP中文網其他相關文章!