モバイル端末の時代において、WeChat 公式アカウントは徐々に人々が情報を入手するチャネルとなり、販売者にとっては潜在顧客を開拓する手段となりました。そのため、多くのプログラマーが WeChat 開発に目を向け、今日、私たちはここにいます。 WeChat パブリック アカウントの開発で Web ページ認証を実装する方法を紹介します。
#カスタム リクエスト インターフェイス関数を紹介する前に、この関数は次のサンプル コードのリクエスト インターフェイスで使用されています
この関数の機能は次のとおりです。インターフェイスへのリクエストを開始するには、パラメーターを渡し、インターフェイスによって返されたデータを返します。
(この内部のコードについては詳しく説明しません。さらに詳しく知りたい場合は、 phpカール関数の概要をご覧ください)
//自定义请求接口函数,$data为空时发起get请求,$data有值时发情post请求 function http_url($url,$data=null){ $ch = curl_init(); curl_setopt($ch,CURLOPT_URL,$url); curl_setopt($ch,CURLOPT_SSL_VERIFYPEER,FALSE); curl_setopt($ch,CURLOPT_SSL_VERIFYHOST,0); curl_setopt($ch,CURLOPT_RETURNTRANSFER,TRUE); if(!empty($data)){ curl_setopt($ch,CURLOPT_POST,1); curl_setopt($ch,CURLOPT_POSTFIELDS,$data); } $res = curl_exec($ch); if(curl_errno($ch)){ echo "error:".curl_error($ch); exit; } curl_close($ch); return $res; }
(この記事で使用されているインターフェイスはTencentによって公式に提供されています。WeChatパブリックプラットフォームを参照できます) 開発者ドキュメント#)
#1. まず、公式アカウントを設定する必要があります1. WeChat 公式アカウントがユーザー Web ページの認証をリクエストする前に、開発者はパブリック プラットフォームの公式 Web サイトにアクセスして基本的なユーザー情報を取得する必要があります
" 設定オプション、認証コールバック ドメインを変更する名前。ここに入力されるドメイン名 (文字列) は URL ではないことに注意してください。したがって、http:// およびその他のプロトコル ヘッダーを追加しないでください; 2. 認可コールバック ドメイン名構成仕様 これは完全なドメイン名です。たとえば、Web ページの認証が必要なドメイン名は www.qq.com です。構成後、このドメイン名のページは http://www.qq.com/music になります。 html および http://www.qq.com/login. .html は OAuth2.0 で認証できます。ただし、http://pay.qq.com、http://music.qq.com、http://qq.com では OAuth2.0 認証を行うことができません
3. 公式アカウントのログインが許可されている場合サードパーティの開発者が管理する場合は、特に設定を行う必要はなく、公式アカウントに代わってサードパーティがWebページの認証を実装することができます。認可を取得してコードを取得しますインターフェイス アドレス:https://open.weixin.qq.com/connect/oauth2/authorize?appid=APPID&redirect_uri=REDIRECT_URI&response_type=code&scope= SCOPE&state=STATE#wechat_redirect (インターフェースパラメータに注意してください)
function Get_Code() //获取code { //构造请求地址 $code_url = "https://open.weixin.qq.com/connect/oauth2/authorize?appid=微信公众号appid&redirect_uri=请求功后回调地址&response_type=code&scope=snsapi_userinfo&state=STATE #wechat_redirect"; //跳转到请求地址,应为本省设置了回调地址,所以不需要使用file_get_content()来请求接口。 header("location:" . $code_url); exit; }
3. 取得されたコードには、access_token と openid
# が含まれる場合があります。 ##インターフェース: https://api.weixin.qq.com/sns/oauth2/access_token?appid=APPID&secret=SECRET&code=CODE&grant_type=authorization_code/**
* 通过获取到的code来获取access_token和openid
* $code为获取到的code
* 接口的参数注意换成自己的,如appid和secret
*/
function GetAccess_Token($code)
{
$get_access_token_url = "https://api.weixin.qq.com/sns/oauth2/access_token?appid=appid&secret=secret&code=$code&grant_type=authorization_code";
$res = http_url($get_access_token_url);
return json_decode($res, true);
}
4. access_token が有効かどうかを確認します
##インターフェース:
/** * 检查access_token是否有效 * */ function CkeckAccessToken($access_token, $openid) { $check_url = "https://api.weixin.qq.com/sns/auth?access_token=$access_token&openid=$openid"; $res = http_url($check_url); $result = json_decode($res, true); if (isset($result['errmsg']) && $result['errmsg'] == 1) { return 1; //access_token有效 } else { return 0; //access_token无效 } }
5. 失敗した場合は、access_token## を更新します。
##インターフェイス:https://api.weixin.qq.com/sns/oauth2/refresh_token?appid=APPID&grant_type=refresh_token&refresh_token=REFRESH_TOKEN
/**
* 如果获取到的access_token无效,通过refresh_token来刷新access_token
*接口的参数注意换成自己的
*/
function GetRefresh_Token($refresh_token)
{
$get_refresh_token_url = "https://api.weixin.qq.com/sns/oauth2/refresh_token?appid=appid&grant_type=refresh_token&refresh_token=$refresh_token";
$res = http_url($get_refresh_token_url);
return json_decode($res, true);
}
6. ユーザー情報の取得
/** * 获取用户基本信息 * */ function Get_User_Info($access_token, $openid){ $get_user_info = "https://api.weixin.qq.com/sns/userinfo?access_token=$access_token&openid=$openid&lang=zh_CN"; $res = http_url($get_user_info); return json_decode($res, true); }
获取到用户信息数据:
{ "openid":" OPENID", " nickname": NICKNAME, "sex":"1", "province":"PROVINCE" "city":"CITY", "country":"COUNTRY", "headimgurl": "http://thirdwx.qlogo.cn/mmopen/g3MonUZtNHkdmzicIlibx6iaFqAc56vxLSUfpb6n5WKSYVY0ChQKkiaJSgQ1dZuTOgvLLrhJbERQQ4eMsv84eavHiaiceqxibJxCfHe/46", "privilege":[ "PRIVILEGE1" "PRIVILEGE2" ], "unionid": "o6_bmasdasdsad6_2sgVt7hMZOPfL" }
下面上完整代码:
<?php //跳转第三方页面,获取用户基本信息 // 这是请求页面也是code的回调页面 session_start(); //启动session if (isset($_GET['code'])) { //判断是否有code传过来,如果没有调用函数请求code $res = GetAccess_Token($_GET['code']); //使用code获取access_token和openid if (CkeckAccessToken($res['access_token'], $res['openid']) == 0) { //判断access_token是否有效,如果无效获取新的access_token $res = GetRefresh_Token($res['refresh_token']); //或缺新的access_token } $userinfo = Get_User_Info($res['access_token'], $res['openid']); //获取用户信息 $_SESSION['userinfo'] = $userinfo; //将用户信息存入session中 $next_url = 'http://web/index.php'; //下一个页面地址 header("location:" . $next_url); //获取到信息后跳转到其他页面 exit; } else { //获取code Get_Code(); } function Get_Code() //获取code{ $code_url = "https://open.weixin.qq.com/connect/oauth2/authorize?appid=appid&redirect_uri=回调地址&response_type=code&scope=snsapi_userinfo&state=STATE #wechat_redirect"; header("location:" . $code_url); exit; } /** * 通过获取到的code来获取access_token和openid * */ function GetAccess_Token($code){ $get_access_token_url = "https://api.weixin.qq.com/sns/oauth2/access_token?appid=appid&secret=secret&code=$code&grant_type=authorization_code"; $res = http_url($get_access_token_url); return json_decode($res, true); } /** * 检查access_token是否有效 * */ function CkeckAccessToken($access_token, $openid){ $check_url = "https://api.weixin.qq.com/sns/auth?access_token=$access_token&openid=$openid"; $res = http_url($check_url); $result = json_decode($res, true); if (isset($result['errmsg']) && $result['errmsg'] == 1) { return 1; //access_token有效 } else { return 0; //access_token无效 } } /** * 如果获取到的access_token无效,通过refresh_token来刷新access_token */ function GetRefresh_Token($refresh_token){ $get_refresh_token_url = "https://api.weixin.qq.com/sns/oauth2/refresh_token?appid=appid&grant_type=refresh_token&refresh_token=$refresh_token"; $res = http_url($get_refresh_token_url); return json_decode($res, true); } /** * 获取用户基本信息 * */ function Get_User_Info($access_token, $openid){ $get_user_info = "https://api.weixin.qq.com/sns/userinfo?access_token=$access_token&openid=$openid&lang=zh_CN"; $res = http_url($get_user_info); return json_decode($res, true);} //自定义请求接口函数,$data为空时发起get请求,$data有值时发起post请求 function http_url($url,$data=null){ $ch = curl_init(); curl_setopt($ch,CURLOPT_URL,$url); curl_setopt($ch,CURLOPT_SSL_VERIFYPEER,FALSE); curl_setopt($ch,CURLOPT_SSL_VERIFYHOST,0); curl_setopt($ch,CURLOPT_RETURNTRANSFER,TRUE); if(!empty($data)){ curl_setopt($ch,CURLOPT_POST,1); curl_setopt($ch,CURLOPT_POSTFIELDS,$data); } $res = curl_exec($ch); if(curl_errno($ch)){ echo "error:".curl_error($ch); exit; } curl_close($ch); return $res; }
以上がWeChatパブリックアカウントWeb認証の詳しい説明の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。