1. 認可コールバック ページのドメイン名を設定します (www.aaa.com など)。
?
2. 公開アカウントをシミュレートするサードパーティ Web ページ、fn_system.php
<?php if(empty($_SESSION['user'])){ header("Location:http://www.aaa.net/uc/fn_wx_login.php"); }else{ print_r($_SESSION['user']); } ?>
ログイン後にコピー
?
3. サードパーティの Web ページにアクセスするときに、セッションにセッション情報がない場合は、ログイン ページ (fn_wx_login.php) にジャンプします。
<?php $appid = "公众号在微信的appid"; $url = 'https://open.weixin.qq.com/connect/oauth2/authorize?appid='.$appid.'&redirect_uri=http%3a%2f%2fwww.aaa.com%2fuc%2ffn_callback.php&response_type=code&scope=snsapi_userinfo&state=STATE#wechat_redirect'; header("Location:".$url); ?>
ログイン後にコピー
4. ログインページでappid、バウンスURLなどの情報を組み立て、WeChatのユーザー認証ページにジャンプします。
?
5. WeChat のユーザー認証ページで、ユーザーが「承認に同意する」を選択すると、WeChat がサードパーティ Web ページのバウンス アドレスにジャンプするときにコード パラメーターが添付されます。
?
6. サードパーティ Web ページのバウンス URL で、まずリクエストからコードを取得し、そのコードに基づいて openid と access_token を交換します。その後、それに基づいて WeChat の関連インターフェイスを呼び出すことができます。 openid と access_token を使用してユーザー情報をクエリします。
<?php $appid = "公众号在微信的appid"; $secret = "公众号在微信的app secret"; $code = $_GET["code"]; $get_token_url = 'https://api.weixin.qq.com/sns/oauth2/access_token?appid='.$appid.'&secret='.$secret.'&code='.$code.'&grant_type=authorization_code'; $ch = curl_init(); curl_setopt($ch,CURLOPT_URL,$get_token_url); curl_setopt($ch,CURLOPT_HEADER,0); curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1 ); curl_setopt($ch, CURLOPT_CONNECTTIMEOUT, 10); $res = curl_exec($ch); curl_close($ch); $json_obj = json_decode($res,true); //根据openid和access_token查询用户信息 $access_token = $json_obj['access_token']; $openid = $json_obj['openid']; $get_user_info_url = 'https://api.weixin.qq.com/sns/userinfo?access_token='.$access_token.'&openid='.$openid.'&lang=zh_CN'; $ch = curl_init(); curl_setopt($ch,CURLOPT_URL,$get_user_info_url); curl_setopt($ch,CURLOPT_HEADER,0); curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1 ); curl_setopt($ch, CURLOPT_CONNECTTIMEOUT, 10); $res = curl_exec($ch); curl_close($ch); //解析json $user_obj = json_decode($res,true); $_SESSION['user'] = $user_obj; print_r($user_obj); ?>
ログイン後にコピー