최근 PC측 웹사이트 개발에는 WeChat 인증 로그인이 필요합니다. 휴대폰측은 이미 초기 단계에서 많은 수의 WeChat 사용자 그룹을 확보한 점을 고려하여 현재 데이터 동기화를 충족하기 위한 리소스 통합을 고려하고 있습니다. 동일한 WeChat 사용자의 것입니다.
WeChat 개발에 대한 지식을 접하게 되므로 필연적으로 OpenID 및 UnionID의 사용을 접하게 됩니다. 다음은 WeChat 공식 문서에 대한 소개입니다. 구별에 주의:
팔로어가 공식 계정과 상호 작용한 후 공식 계정은 팔로어의 OpenID를 얻을 수 있습니다(암호화된 WeChat ID, 각 공식 계정에 대한 각 사용자의 OpenID는 고유합니다. 다른 공식 계정의 경우 OpenID는 동일한 사용자는 다릅니다). 공식 계정은 OpenID를 기반으로 해당 인터페이스를 통해 닉네임, 아바타, 성별, 도시, 언어, 관심 시간 등 사용자 기본 정보를 얻을 수 있습니다.
개발자가 여러 공식 계정 간 또는 공식 계정과 모바일 애플리케이션 간 사용자 계정을 통합해야 하는 경우 WeChat 오픈 플랫폼(open.weixin.qq.com)으로 이동하여 공식 계정을 연결해야 합니다. 그래야만 UnionID 메커니즘을 사용하여 위의 요구 사항을 충족할 수 있습니다.
간단히 말하면:
OpenID는 일반 사용자의 식별 번호이며 현재 개발자 계정에 고유합니다. OpenID는 공식 계정에 해당합니다.
UnionID는 사용자의 통합식별번호입니다. WeChat 오픈 플랫폼 계정을 사용하는 애플리케이션의 경우 동일한 사용자의 UnionID는 고유합니다.
는 이 원을 중심으로 진행되었습니다. 즉, 동일한 WeChat 사용자가 다른 플랫폼을 사용하려는 경우 WeChat 공개 계정 개발과 WeChat 개발 플랫폼 개발에는 차이가 있습니다. PC, 앱, 위챗 애플릿 등) 웹사이트 로그인에는 계정 바인딩이 필요하며, 바인딩된 계정은 OpenID로 구분할 수 없고 UnionID로 구분해야 합니다.
Appendix 일반적인 디자인 문제는 주로 개발 전 지식의 활용 부족으로 인해 발생하며 이는 이후 확장에도 영향을 미치게 됩니다. 모두에게 경각심을 불러일으키세요.
다음 요구 사항에 따라 "웹사이트 애플리케이션 개발" 생성을 선택한 후 공식 안내에 따라 자료를 신청하세요. 일반적으로 더 많은 시간이 소요됩니다. 3일 이상.
애플리케이션이 생성된 후에는 인터페이스 권한 획득 요구 사항도 충족해야 하며, 직원이 사전에 연락을 드릴 것이며 일반적으로 하루 안에 완료될 수 있습니다.
동일한 개발 계정의 WeChat 사용자에 해당하는 UnionID가 바인딩되어 사용되도록 해야 합니다. 해당 공개 계정/서비스 계정을 결정합니다. 문서에서는 일반적으로 WeChat 결제 기능을 충족해야 한다고 소개합니다.
실제로 초기 애플리케이션 작업에 소요되는 코드 구현은 매우 간단합니다. 다음은 제 구현 방법입니다.
주요 구성 정보는 구성 파일 'ApplicationCommonConfconfig.php'에 저장하는 것이 관례입니다.
'WEIXIN_LOGIN' => array( // 微信开放平台 使用微信帐号登录App或者网站 配置信息 'OPEN_APPID' => 'wxbd961b2a6b7b2963', //应用 AppID 'OPEN_APPSECRET' => 'e6xxxxxxxxxxxxxxxxxxxxe90',//应用 AppSecret 'OPEN_CALLBACKURL' => 'http://www.52zhenmi.com/Home/Login/wxBack', //微信用户使用微信扫描二维码并且确认登录后,PC端跳转路径 ),
public function wxIndex(){ //--微信登录-----生成唯一随机串防CSRF攻击 $state = md5(uniqid(rand(), TRUE)); $_SESSION["wx_state"] = $state; //存到SESSION $callback = urlencode($this->callBackUrl); 'https://open.weixin.qq.com/connect/qrconnect?appid=APPID&redirect_uri=REDIRECT_URI&response_type=code&scope=SCOPE&state=STATE#wechat_redirect'; $wxurl = "https://open.weixin.qq.com/connect/qrconnect?appid=" .$this->appID."&redirect_uri=" .$callback."&response_type=code&scope=snsapi_login&state=" .$state."#wechat_redirect"; header("Location: $wxurl"); } public function wxBack(){ if($_GET['state']!=$_SESSION["wx_state"]){ echo 'sorry,网络请求失败...'; exit("5001"); } $url='https://api.weixin.qq.com/sns/oauth2/access_token?appid='.$this->appID.'&secret='.$this->appSecret.'&code='.$_GET['code'].'&grant_type=authorization_code'; $arr = curl_get_contents($url); //得到 access_token 与 openid $url='https://api.weixin.qq.com/sns/userinfo?access_token='.$arr['access_token'].'&openid='.$arr['openid'].'&lang=zh_CN'; $user_info = curl_get_contents($url); $this->dealWithWxLogin($user_info); } /** * 根据微信授权用户的信息 进行下一步的梳理 * @param $user_info */ public function dealWithWxLogin($user_info){ //TODO 数据处理 var_dump($user_info); die; }
공식 문서 소개에 따르면 인증된 코드 스캔 인터페이스에 직접 액세스하거나 디자인을 사용자 정의할 수 있습니다. , 그리고 로그인 코드 스캔을 중첩하는 기능은 시간이 오래 걸리고 작동하지 않아서 여기서는 기본 점프를 사용해야 했습니다.
표시 효과는 다음과 같습니다.
성공적으로 스캔하고 로그인하면 페이지가 점프합니다
1. , 로그인한 사용자의 정보는 추후 업무 처리를 위해 데이터베이스에 저장될 수 있습니다.
2. 아래에서 설명하는 능력은 한계가 있으니 공식 개발 문서와 구글 선배님들의 실무 경험을 참고하시길 권합니다...
3. 참조: WeChat 공용 계정 사용자와 웹사이트 사용자 바인딩 맞춤형 솔루션
관련 권장 사항:
WeChat 오픈 플랫폼 개발 웹사이트 애플리케이션 WeChat 로그인 소개
방법 WeChat 로그인을 PHP의 laravel 프레임워크와 신속하게 통합합니다
위 내용은 PHP 웹사이트에서 WeChat을 사용하여 로그인하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!