How to obtain user information through web page authorization
The steps to obtain user information are as follows:
1 Step 1: The user agrees to authorize and obtain code
2 Step 2: Exchange the code for web page authorization access_token
3 Step 3 : Refresh access_token (if necessary)
4 Step 4: Pull user information (scope is required to be snsapi_userinfo)
1 Obtain code
Make sure that the WeChat public account has an authorization scope ( scope parameter) (after the service account obtains the advanced interface , it will have snsapi_base and snsapi_userinfo in the scope parameter by default), guide followers to open the following page:
open .weixin.qq.com/connect/oauth2/authorize?appid=APPID&redirect_uri=REDIRECT_URI&response_type=code&scope=SCOPE&state=STATE#wechat_redirect
If it prompts "The link cannot be accessed", please check whether the parameters are filled in incorrectly , whether it has the authorization scope permission corresponding to the scope parameter.
Special note: Since the authorization operation has a high security level, when initiating an authorization request, WeChat will perform a regular strong matching check on the authorization link. If the order of the parameters of the link is No, the authorization page will not be accessible normally
Among them:
AppID - the unique identifier of the official account
REDIRECT_URI - jump url
SCOPE - the value is snsapi_base (not The authorization page pops up and jumps directly. You can only obtain the user's openid) or snsapi_userinfo (the authorization page pops up. You can get the nickname, gender, and location through openid. Moreover, even if you are not following the user, you can also obtain it as long as the user authorizes it. Information)
STATE - Developers can customize the parameter value of a-zA-Z0-9
2 Exchange the code for web page authorization access_token
If the user agrees to the authorization, the page will jump Go to redirect_uri/?code=CODE&state=STATE.
state is the STATE parameter above passed as it is
Implementation code:
<code class="hljs php">$code = I('get.code');if (empty($code)) { //todo 非微信访问 exit('</code>'); } else { //授权后操作 }
Here we can get the code for subsequent acquisition of access_token.
After obtaining the code, request the following link to obtain access_token:
api.weixin.qq.com/sns/oauth2/access_token?appid=APPID&secret=SECRET&code=CODE&grant_type=authorization_code
appid - the unique identification of the public account
secret - key
code - the code returned above
grant_type - the value is authorization_code
Implementation code:
<code class="hljs bash">$url = 'https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid=' . C('wechat.AppID') . '&secret=' . C('wechat.AppSecret');$str = file_get_contents ($url);$str = json _decode($str, true);$access_token = $str['access_token'];</code>
here access_token can be cache processed to avoid frequent acquisition of
implementation code. Take TPframework as an example:
<code class="hljs php">$access_token = S('access_token');if (empty($access_token)) { $url = 'https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid=' . C('wechat.AppID') . '&secret=' . C('wechat.AppSecret'); $str = file_get_contents($url); $str = json_decode($str, true); $access_token = $str['access_token']; S('access_token', $access_token, 3600);}</code>
After obtaining access_token, it will also be Returns openid (user's unique identifier). The explanation of WeChat official documentation is: user's unique identifier. Please note that when the user does not follow the official account, when the user visits the official account's webpage, an OpenID
unique to the user and official account will also be generated.
openid uniquely identifies a WeChat user. If the user is not logging in for the first time, he can querythe database to see if there is a user bound to this openid after getting the openid. There is no need to re-obtain the user afterwards. Data, directly obtain the database user_id settingsession, directly log in to access
3 Ignore the third step, only re-obtain the access_token when needed
4 Pull users Information (scope is required to be snsapi_userinfo)
If the database is not bound to this WeChat ID user, it is equivalent to the user's first visit and login, and the user information is obtained through the fourth step (with user authorization, the web page The authorization scope is snsapi_userinfo, then the developer can now pull user information through access_token and openid), then create a user in the background and bind this WeChat user (through openid)
http: GET (please use https protocol) api.weixin.qq.com/sns/userinfo?access_token=ACCESS_TOKEN&openid=OPENID&
=zh_CNaccess_token - the access_token obtained above
openid - the unique identifier of the public account
Implementation code:
<code class="hljs php">$access_token = S('access_token');if (empty($access_token)) { $url = 'https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid=' . C('wechat.AppID') . '&secret=' . C('wechat.AppSecret'); $str = file_get_contents($url); $str = json_decode($str, true); $access_token = $str['access_token']; S('access_token', $access_token, 3600);}</code>
The above is the WeChat public Specific steps to obtain user information.
【Related Recommendations】
1.
WeChat public account platform source code downloadWeizhichuang T+ WeChat robot source codeThe above is the detailed content of How to obtain user information through web page authorization. For more information, please follow other related articles on the PHP Chinese website!

Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics

This article provides a detailed guide to safe download of Ouyi OKX App in China. Due to restrictions on domestic app stores, users are advised to download the App through the official website of Ouyi OKX, or use the QR code provided by the official website to scan and download. During the download process, be sure to verify the official website address, check the application permissions, perform a security scan after installation, and enable two-factor verification. During use, please abide by local laws and regulations, use a safe network environment, protect account security, be vigilant against fraud, and invest rationally. This article is for reference only and does not constitute investment advice. Digital asset transactions are at your own risk.

H5. The main difference between mini programs and APP is: technical architecture: H5 is based on web technology, and mini programs and APP are independent applications. Experience and functions: H5 is light and easy to use, with limited functions; mini programs are lightweight and have good interactiveness; APPs are powerful and have smooth experience. Compatibility: H5 is cross-platform compatible, applets and APPs are restricted by the platform. Development cost: H5 has low development cost, medium mini programs, and highest APP. Applicable scenarios: H5 is suitable for information display, applets are suitable for lightweight applications, and APPs are suitable for complex functions.

Compatibility issues and troubleshooting methods for company security software and application. Many companies will install security software in order to ensure intranet security. However, security software sometimes...

H5 is more flexible and customizable, but requires skilled technology; mini programs are quick to get started and easy to maintain, but are limited by the WeChat framework.

Discussion on the JS resource caching issue of Enterprise WeChat. When upgrading project functions, some users often encounter situations where they fail to successfully upgrade, especially in the enterprise...

The choice of H5 and applet depends on the requirements. For applications with cross-platform, rapid development and high scalability, choose H5; for applications with native experience, rich functions and platform dependencies, choose applets.

This article provides a brief guide to buying and selling of Binance virtual currency updated in 2025, and explains in detail the operation steps of virtual currency transactions on the Binance platform. The guide covers fiat currency purchase USDT, currency transaction purchase of other currencies (such as BTC), and selling operations, including market trading and limit trading. In addition, the guide also specifically reminds key risks such as payment security and network selection for fiat currency transactions, helping users to conduct Binance transactions safely and efficiently. Through this article, you can quickly master the skills of buying and selling virtual currencies on the Binance platform and reduce transaction risks.

Lianyungang Huaguoshan Scenic Area joins hands with Tencent Cloud to launch the first "dual-core brain" Digital Homo sapiens in the cultural and tourism industry - Monkey King! On March 1, the scenic spot officially connected the Monkey King to the DeepSeek platform, so that it has the two AI model capabilities of Tencent Hunyuan and DeepSeek, bringing tourists a smarter and more considerate service experience. Huaguoshan Scenic Area has previously launched the Monkey King of the Digital Homo sapiens based on Tencent Hunyuan model. This time, Tencent Cloud further utilizes technologies such as the big model knowledge engine to connect it to DeepSeek to achieve a "dual-core" upgrade. This makes the Monkey King's interactive ability to a higher level, faster response speed, stronger understanding ability, and more warmth. Monkey King has strong natural language processing capabilities and can understand various ways of asking questions from tourists.
