Maison > développement back-end > tutoriel php > Développement d'un compte public php WeChat pour obtenir les informations personnelles des utilisateurs WeChat

Développement d'un compte public php WeChat pour obtenir les informations personnelles des utilisateurs WeChat

不言
Libérer: 2023-03-24 12:08:01
original
9274 Les gens l'ont consulté


De nombreux développeurs doivent obtenir l'avatar de l'utilisateur lors du développement d'un compte officiel WeChat. S'il s'agit d'un compte WeChat personnel, vous devez demander un « compte de test de plateforme publique » pour obtenir un. Compte officiel WeChat. Toutes les autorisations d'interface ;

Tout d'abord, vous devez obtenir le access_token envoyé par WeChat, puis utiliser l'openid et l'access_token pour obtenir le message utilisateur au format json envoyé par le serveur WeChat. josn_decode pour le convertir pour obtenir les détails de l'utilisateur.

Avant d'écrire le code, vous pouvez tester le fonctionnement de l'interface comme indiqué ci-dessous :

Entrez d'abord sur la plateforme publique WeChat, comme indiqué. ci-dessous :


Cliquez sur Outils de développement, puis cliquez sur Débogage de l'interface en ligne, comme indiqué dans la figure ci-dessous, pour accéder à l'interface de sélection d'interface


Cliquez. Entrez ensuite dans la page ci-dessous et sélectionnez dans le type d'interface : Gestion des utilisateurs, sélectionnez dans la liste des interfaces : Obtenir les informations du profil utilisateur interface/utilisateur/info

Copier après la connexion
Consultez ensuite la documentation de développement WeChat pour obtenir le access_token à utiliser. Accédez à l'appid et à l'appsecret comme indiqué ci-dessous


Cliquez pour activer l'appsecret pour récupérez-le, puis saisissez-le dans l'URL du navigateur :

https://api weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid=$appid&secret=$appsecret" URL, où $. appid est la chaîne appid dans l'image ci-dessus, $appsecret est votre mot de passe développeur, remplacez-le par une chaîne. Après les deux variables (attention à bien supprimer les guillemets), cliquez sur la touche entrée pour obtenir les données access_token et expires_in envoyées par le Serveur WeChat. Copiez la chaîne access_token obtenue sur la page de débogage de l'interface. Openid est le seul identifiant du compte de test après avoir suivi la plateforme. Pour la méthode d'obtention, voir l'article précédent, ou vous pouvez également utiliser Baidu. Entrez les deux paramètres dans les zones de saisie correspondantes sur la page d'interface (une vérification verte s'affichera une fois la saisie terminée), puis cliquez pour détecter le problème


Les informations obtenues sont telles qu'indiquées ci-dessous ; :


Cela signifie que vous l'avez obtenu avec succès. Ajoutons le code pour obtenir le jeton d'accès et les informations personnelles

public function getaccss_token(){
		$table = 'Access_token';
		$useraccess_token = Db::table('Access_token')->select();
		$appid = "你的appid";
		$appsecret = "你的appsecret";
		$url = "https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid=$appid&secret=$appsecret";
		//判断是不是第一次获取access_token		
		if(!count($useraccess_token)){			
			$ch = curl_init();
			curl_setopt($ch, CURLOPT_URL, $url);
			curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, FALSE); 
			curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, FALSE); 
			curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
			$output = curl_exec($ch);
			curl_close($ch);
			$jsoninfo = json_decode($output, true);
			$access_token = $jsoninfo["access_token"];			
			$data=['access_token'=>$access_token,'expires_time'=>($jsoninfo['expires_in']+time()-200)];
			Db::table($table)->insert($data);
			return $access_token;
	}else if($useraccess_token[0][&#39;expires_time&#39;]<time()){//判断是否过期
		
			$ch = curl_init();
			curl_setopt($ch, CURLOPT_URL, $url);
			curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, FALSE); 
			curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, FALSE); 
			curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
			$output = curl_exec($ch);
			curl_close($ch);
			$jsoninfo = json_decode($output, true);//转换格式
			$access_token = $jsoninfo["access_token"];			
			$data=[&#39;access_token&#39;=>$access_token,&#39;expires_time&#39;=>($jsoninfo[&#39;expires_in&#39;]+time()-200)];
			Db::table($table)->where(&#39;expires_time&#39;,$useraccess_token[0][&#39;expires_time&#39;])->update($data);//更新数据库;
			return $access_token;
	}else{	
		$access_token = $useraccess_token[0][&#39;access_token&#39;];
		return $access_token;
		
	}
	}
Copier après la connexion
. Utilisez la fonction curl pour intercepter le message envoyé par WeChat. Étant donné que le access_token obtenu n'est valide que pendant 7 200 secondes, soit deux heures, cela doit être fait chaque fois que l'utilisateur effectue une entrée sur le compte officiel. Vérifiez s'il a expiré. il a expiré, vous devez le récupérer. Les différents jugements if dans l'image ci-dessus sont utilisés pour juger. J'ai enregistré le access_token et l'heure dans la base de données afin qu'il puisse être détecté à chaque fois. également être appelé depuis le cache ou placé dans un fichier et appelé depuis le fichier

Après avoir obtenu le access_token, les informations personnelles de l'utilisateur peuvent être obtenues via access_token et openid, comme indiqué ci-dessous :

public function userinfo($openid){
		$access_token = $this->getaccss_token();
		//获取用户信息地址		
		$urlid = &#39;https://api.weixin.qq.com/cgi-bin/user/info?access_token=&#39;.$access_token.&#39;&openid=&#39;.$openid.&#39;&lang=zh_CN&#39;;
		$curl = curl_init(); // 启动一个CURL会话
		curl_setopt($curl, CURLOPT_URL, $urlid);
		curl_setopt($curl, CURLOPT_HEADER, 0);
		curl_setopt($curl, CURLOPT_RETURNTRANSFER, 1);
		curl_setopt($curl, CURLOPT_SSL_VERIFYPEER, false); // 跳过证书检查
		//curl_setopt($curl, CURLOPT_SSL_VERIFYHOST, true);  // 从证书中检查SSL加密算法是否存在
		$tmpInfo = curl_exec($curl);     //返回api的json对象
		//关闭URL请求
		curl_close($curl);
                $userinfo = json_decode($tmpInfo,true);			
		return $userinfo;
	}
Copier après la connexion
est également De la même manière, les informations sont interceptées via les opérations liées à la fonction curl et le format est converti. La dernière information utilisateur est le tableau d'informations personnelles de l'utilisateur. Il vous suffit de l'appeler

Ce qui précède. est d'obtenir l'utilisateur via access_token Opération d'informations personnelles ~ !

Recommandations associées :

Développement d'un compte public PHP WeChat, obtention d'un avatar d'utilisateur et téléchargement

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Étiquettes associées:
source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal