위 챗 웹 페이지 인증(OAuth 2.0)PHP 소스 코드 간단하게 구현
3858 단어 위 챗 홈 페이지 인증OAuth2.0PHP
1.OAuth 2.0 프로 토 콜 에 대한 학습 을 권장 합 니 다.
2.위 챗 공식 문서 와 위 챗 홈 페이지 도 구 를 충분히 활용 해 야 한다.
비교적 간단 해서 직접 소스 코드 를 붙 였 다.그 중에서'xxxxxxxxxx'부분 은 자신의 환경 에 따라 교체 해 야 한다.
/**
* OAuth2.0
*
* @author zzy
* @ :GetWxUserInfo.php
*/
//
$url = urlencode("http://www.xxxxxxxxx.com/GetWxUserInfo.php");
// id secret
$appid = 'xxxxxxxxx';
$appsecret = 'xxxxxxxxx';
session_start();
// code , token。 : OAuth2.0 ,
if(!isset($_GET['code']) && !isset($_SESSION['code'])){
echo
'<a href="https://open.weixin.qq.com/connect/oauth2/authorize?appid=wx6c11a252ff1d00c4
&redirect_uri='.$url.'&response_type=code&scope=snsapi_userinfo&state=1#wechat_redirect">
<font style="font-size:30"> </font></a>';
exit;
}
// code openid access_token,
if (isset($_GET['code']) && !isset($_SESSION['token'])){
$_SESSION['code'] = $_GET['code'];
$url="https://api.weixin.qq.com/sns/oauth2/access_token?appid=".$appid.
"&secret=".$appsecret."&code=".$_GET['code']."&grant_type=authorization_code";
$res = https_request($url);
$res=(json_decode($res, true));
$_SESSION['token'] = $res;
}
print_r($_SESSION);
// access_token openid, Userinfo 。
if (isset($_SESSION['token']['access_token'])){
$url = "https://api.weixin.qq.com/sns/userinfo?access_token=".$_SESSION['token']['access_token']."&openid=".$_SESSION['token']['openid']."&lang=zh_CN";
echo $url;
$res = https_request($url);
$res = json_decode($res, true);
$_SESSION['userinfo'] = $res;
}
print_r($_SESSION);
// cURL
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;
}
정확 한 결 과 를 얻 으 면 다음 과 같다.
Array
(
[code] => 041GZI4l0tvGHg10N75l05FQ4l0GZI42
[token] => Array
(
[access_token] => TWo6w5QMpzTZibu3FPh2k4EdC5bllp4sGeQkC4NbZtj-zti-ctZj1SrrNL1qGCf2lB1-6o3N7kh2bcxl5bxtQqJEGk1cq12l8CzF40R9XvA
[expires_in] => 7200
[refresh_token] => Iz3olCrkqPBOJvSSH2bOKvA09Sjvsp1c8Ltm7MvxxPfQXSbvI_WoVmzhjqASzwlMa7TAGgsg3mIJmaHjL7jrJHDqUF1jKbhd6GNDnLtXq0U
[openid] => ota_XwQ4r_5nioVmshQ
[scope] => snsapi_userinfo
)
[userinfo] => Array
(
[openid] => ota_XwQ4r_5nioVmshQq
[nickname] =>
[sex] => 1
[language] => zh_CN
[city] =>
[province] =>
[country] =>
[headimgurl] => http://wx.qlogo.cn/mmopen/PiajxSqBRaELwee7rhrt2ibnkC1MEnu04WiaWrw9FkuPBbGOgnrMbynNoEuxicgXOetW5VqQbTrS4fZDXNvAWsz6GQ/0
[privilege] => Array
(
)
)
)
이상 이 바로 본 고의 모든 내용 입 니 다.여러분 의 학습 에 도움 이 되 고 저 희 를 많이 응원 해 주 셨 으 면 좋 겠 습 니 다.
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
쉽게 그림에서 OAuth2 흐름 유형에 대해 이해!Authorization Code Grant 타입(이미지 오른쪽 상단)은 4가지 타입 중에서 가장 구현하기가 어렵습니다. Client Credential 및 Authorization Code grant 유형은 보안 ...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.