최근에는 위챗 미니 프로그램 사용법을 공부하고 있어요. 연락을 해보니 많은 함정을 발견했습니다. 이 기사에서는 WeChat 애플릿을 통해 사용자 정보를 얻는 방법을 설명합니다.
예를 들어 브라우저에서는 document.getElementById를 통해 페이지의 DOM 개체를 가져올 수 있습니다. 그러나 WeChat 애플릿에서는 DOM 개체를 얻을 수 없습니다. document.getElementById()는 getElementById가 작동하지 않는다는 오류를 직접 보고합니다. 저도 취했습니다. 이를 지원하지 않으면 많은 흥미로운 기능을 구현할 수 없습니다.
본론으로 돌아가서, 사용자 정보 획득에 대한 내 생각을 말씀드리겠습니다.
사용자 정보를 얻는 방법에는 두 가지가 있습니다.
1. 민감한 정보인 openId(닉네임, 아바타Url 등 기본 정보 포함)가 포함되지 않은 json 객체
2. 민감한 정보인 openId 등의 기본 정보가 포함되어 있습니다.
첫 번째 획득 솔루션
1. 먼저 wx.login() 인터페이스를 호출하여 사용자 인증 확인을 허용합니다. 이는 xxxxx 인증 여부를 육안으로 관찰하는 것입니다.
2. 사용자가 성공적으로 인증된 후 wx.getUserInfo() 인터페이스를 호출하여 사용자 정보를 얻습니다.
완전한 코드는 다음과 같습니다
wx.login({ success:function(){ wx.getUserInfo({ success:function(res){ var simpleUser = res.userInfo; console.log(simpleUser.nickName); } }); } });
두 번째 코드는 더 복잡하고 userInfo를 얻기 위해 배경과의 상호 작용이 필요하지만 이 솔루션으로 얻은 데이터는 완전합니다(openId 포함).
1. wx.login() 인터페이스를 호출하여 성공 함수의 매개변수에 코드를 승인하고 포함합니다.
2.cryptedData 및 iv가 포함된 wx.getUserInfo() 인터페이스 성공 함수를 호출합니다.
3. 위 매개변수를 백그라운드 분석에 전달하여 userInfo를 생성합니다.
코드는 다음과 같습니다
js
var request = require("../../utils/request.js"); wx.login({ success:function(res_login){ if(res_login.code) { wx.getUserInfo({ withCredentials:true, success:function(res_user){ var requestUrl = "/getUserApi/xxx.php"; var jsonData = { code:res_login.code, encryptedData:res_user.encryptedData, iv:res_user.iv }; request.httpsPostRequest(requestUrl,jsonData,function(res){ console.log(res.openId); }); } }) } } })
백엔드 분석
/** * 获取粉丝信息 * 其中的参数就是前端传递过来的 */ public function wxUserInfo($code,$encryptedData,$iv) { $apiUrl = "https://api.weixin.qq.com/sns/jscode2session?appid={$this->wxConfig['appid']}&secret={$this->wxConfig['appsecret']}&js_code={$code}&grant_type=authorization_code"; $apiData = json_decode(curlHttp($apiUrl,true),true); if(!isset($apiData['session_key'])) { echoJson(array( "code" => 102, "msg" => "curl error" ),true); } $userInfo = getUserInfo($this->wxConfig['appid'],$apiData['session_key'],$encryptedData,$iv); if(!$userInfo) { echoJson(array( "code" => 105, "msg" => "userInfo not" )); } //$userInfo = json_decode($userInfo,true); //载入用户服务 //$userService = load_service("User"); //$userService->checkUser($this->projectId,$userInfo); echo $userInfo; //微信响应的就是一个json数据 }
getUserInfo 함수는 WeChat에서 공식적으로 제공하는 자료 패키지입니다.
curlHttp 함수는 이 함수의 소스 코드를 확인하세요. 내 글을 확인하세요.
app.globalData.host는https://xxxxx.com
;과 같은 도메인 이름 주소입니다. 관련 권장 사항:
사용자 정보 인터페이스를 얻기 위해 WeChat 애플릿을 구현하는 방법에 대한 Thinkphp5 사례 연구
웹페이지 사용자 정보에 대한 접근 권한을 부여하는 방법
위 내용은 WeChat 애플릿을 통해 사용자 정보를 얻는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!