PHP实践:手把手微信公众号网页授权登录功能实现

在这里插入图片描述

🏆作者简介,黑夜开发者,全栈领域新星创作者✌,CSDN博客专家,阿里云社区专家博主,2023年6月CSDN上海赛道top4。
🏆数年电商行业从业经验,历任核心研发工程师,项目技术负责人。
🏆本文已收录于PHP专栏:PHP进阶实战教程。
🏆另有专栏PHP入门基础教程,希望各位大佬多多支持❤️。
🎉欢迎 👍点赞✍评论⭐收藏

文章目录

  • 🚀一、前言
  • 🚀二、准备工作
  • 🚀三、授权登录的流程
  • 🚀四、具体步骤和代码实现
    • 🔎4.1 用户点击登录按钮
    • 🔎4.2 获取授权码
    • 🔎4.3 使用授权码获取access_token和openid
    • 🔎4.4 获取用户信息
    • 🔎4.5 更新用户表
  • 🚀五、总结


🚀一、前言

Web应用中,用户登录是非常常见的功能之一。为了提供更好的用户体验,并且方便用户进行登录,很多应用选择通过第三方平台进行登录授权,比如微信QQ等。本文将以微信登录授权为例,介绍如何使用PHP实现网页授权登录,并将用户昵称和头像更新到用户表中。

在这里插入图片描述

🚀二、准备工作

在开始之前,我们需要进行一些准备工作:

一个可以运行PHP的环境,比如搭建好的服务器或者本地开发环境。
注册并获取微信公众号的AppIDAppSecret,这个要去微信公众号后台获取,见下图。

在这里插入图片描述

🚀三、授权登录的流程

授权登录的流程主要分为以下几步:

  1. 用户访问我们的网站,并点击登录按钮。
  2. 我们的网站将用户引导至微信的授权页面。
  3. 用户在微信授权页面进行登录并同意授权。
  4. 微信将用户重定向回我们的网站,并携带授权码。
  5. 我们的网站使用授权码获取access_tokenopenid
  6. 使用access_tokenopenid,我们可以获取用户的信息。
  7. 更新用户表中对应用户的昵称和头像。

在这里插入图片描述

🚀四、具体步骤和代码实现

🔎4.1 用户点击登录按钮

首先,在我们的网站上添加一个“登录”按钮,当用户点击该按钮时将会跳转至微信授权页面。

<a href="https://open.weixin.qq.com/connect/oauth2/authorize?appid=YOUR_APP_ID&redirect_uri=REDIRECT_URL&response_type=code&scope=snsapi_userinfo&state=STATE#wechat_redirect">登录</a>

替换上述代码中的YOUR_APP_ID为你的微信公众号的AppID,REDIRECT_URL为用户授权后重定向的URL。

🔎4.2 获取授权码

当用户点击登录按钮后,将会跳转至微信授权页面。用户在微信授权页面登录并同意授权后,微信将用户重定向回我们的网站,并携带一个授权码。

我们可以通过GET请求获取这个授权码:

$code = $_GET['code'];

🔎4.3 使用授权码获取access_token和openid

使用这个授权码,我们可以请求微信的接口,获取到access_token和openid。这里我们使用了PHP的curl库来发送HTTP请求:

$curl = curl_init();
$url = "https://api.weixin.qq.com/sns/oauth2/access_token?appid=YOUR_APP_ID&secret=YOUR_APP_SECRET&code=".$code."&grant_type=authorization_code";
curl_setopt($curl, CURLOPT_URL, $url);
curl_setopt($curl, CURLOPT_RETURNTRANSFER, 1);
$result = curl_exec($curl);
curl_close($curl);$json = json_decode($result, true);
$access_token = $json['access_token'];
$openid = $json['openid'];

替换上述代码中的YOUR_APP_ID为你的微信公众号的AppID,YOUR_APP_SECRET为你的微信公众号的AppSecret。

🔎4.4 获取用户信息

有了access_token和openid,我们就可以请求微信的用户信息接口,获取到用户的昵称和头像。

$curl = curl_init();
$url = "https://api.weixin.qq.com/sns/userinfo?access_token=".$access_token."&openid=".$openid."&lang=zh_CN";
curl_setopt($curl, CURLOPT_URL, $url);
curl_setopt($curl, CURLOPT_RETURNTRANSFER, 1);
$result = curl_exec($curl);
curl_close($curl);$json = json_decode($result, true);
$nickname = $json['nickname'];
$avatar = $json['headimgurl'];

🔎4.5 更新用户表

最后一步,我们将获取到的用户昵称和头像更新到我们的用户表中。假设我们的用户表是一个名为users的表,包含字段idnicknameavatar

// 假设我们已经连接到数据库,并且设置了正确的数据库连接参数$stmt = $pdo->prepare("UPDATE users SET nickname = :nickname, avatar = :avatar WHERE id = :id");
$stmt->bindParam(':nickname', $nickname);
$stmt->bindParam(':avatar', $avatar);
$stmt->bindParam(':id', $userId);
$stmt->execute();

替换上述代码中的:nickname:avatar:id为对应的占位符。另外,需要根据实际情况将$userId设置为当前登录用户的ID。实际上使用的时候效果图如下。
在这里插入图片描述

🚀五、总结

通过以上的步骤,我们可以实现网页授权登录,并将用户的昵称和头像更新到用户表中。当用户点击登录按钮后,会跳转至微信授权页面进行登录和授权。用户同意授权后,微信将用户重定向回我们的网站,并携带一个授权码。我们使用这个授权码获取access_tokenopenid,并通过access_tokenopenid获取用户的信息。最后,我们将用户的昵称和头像更新到用户表中。这样,就实现了网页授权登录的功能。

在这里插入图片描述

以上仅是一个示例,实际情况可能会更复杂。在实际开发中,我们还需要处理错误和异常情况,比如授权失败、接口请求错误等。此外,为了保证用户的安全和隐私,我们需要使用HTTPS协议进行通信,并且合理保存用户的信息。

推荐您阅读本专栏其他内容,PHP进阶实战教程,相信不会让您失望。如果你对上面的功能有疑问,随时欢迎与我交流。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/83607.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【2023深圳杯数学建模A题思路模型与代码分享】

2023深圳杯数学建模A题 A题 影响城市居民身体健康的因素分析解题思路第一问第二问第三问第四问 技术文档第一问完整代码写在最后 A题 影响城市居民身体健康的因素分析 以心脑血管疾病、糖尿病、恶性肿瘤以及慢性阻塞性肺病为代表的慢性非传染性疾病&#xff08;以下简称慢性病…

SQL注入读写文件

文章目录 条件利用SQL注入漏洞读取hosts文件查看文件读写权限安全选项允许导入导出读取hosts文件 利用SQL注入漏洞写入一句话木马&#xff0c;并用蚁剑连接webshell写入文件 条件 SQL注入有直接SQL注入&#xff0c;也有文件读写时的注入&#xff0c;后者的主要 目的在于获取web…

探讨uniapp的页面问题

1 新建页面 uni-app中的页面&#xff0c;默认保存在工程根目录下的pages目录下。 每次新建页面&#xff0c;均需在pages.json中配置pages列表&#xff1b; 未在pages.json -> pages 中注册的页面&#xff0c;uni-app会在编译阶段进行忽略。pages.json的完整配置参考&am…

APSIM模型应用与参数优化、批量模拟

APSIM (Agricultural Production Systems sIMulator)模型是世界知名的作物生长模拟模型之一。APSIM模型有Classic和Next Generation两个系列模型&#xff0c;能模拟几十种农作物、牧草和树木的土壤-植物-大气过程&#xff0c;被广泛应用于精细农业、水肥管理、气候变化、粮食安…

【动手学深度学习】--18.图像增广

文章目录 图像增广1.常用的图像增广方法1.1翻转和裁剪1.2改变颜色1.3结合多种图像增广方法 2.使用图像增广进行训练3.训练 图像增广 官方笔记&#xff1a;图像增广 学习视频&#xff1a;数据增广【动手学深度学习v2】 图像增广在对训练图像进行一系列的随机变化之后&#xff…

【从零学习python 】56. 异常处理在程序设计中的重要性与应用

文章目录 异常的概念读取文件异常try...except语句try...else语句try...finally语句 进阶案例 异常的概念 在程序运行过程中&#xff0c;由于编码不规范或其他客观原因&#xff0c;可能会导致程序无法继续运行&#xff0c;此时就会出现异常。如果不对异常进行处理&#xff0c;…

APP Binder客户端调用全流程分析

现在要搞明白JAVA层app调用跨进程的Service接口时&#xff0c;它的binder是怎样从Java->jni-->native--->binder驱动的这条链路&#xff1a;就是上图中的左半部分从上至下的流程。所以切入点在于&#xff0c;如app调用另一个进程的Service接口的getString&#xff08;…

“石头剪刀布”游戏:while、函数自调用实现循环游戏

if…else实现“石头剪刀布”游戏&#xff0c;while、函数自调用实现循环游戏。 (本笔记适合学过if…else的coder翻阅) 【学习的细节是欢悦的历程】 Python 官网&#xff1a;https://www.python.org/ Free&#xff1a;大咖免费“圣经”教程《 python 完全自学教程》&#xff0c…

React Diff算法

文章目录 React Diff算法一、它的作用是什么&#xff1f;二、React的Diff算法1.了解一下什么是调和&#xff1f;2.react的diff算法3.React Diff的三大策略4.tree diff&#xff1a;1、如果DOM节点出现了跨层级操作&#xff0c;Diff会怎么办? 5. component diff&#xff1a;6. e…

Windows平台Unity下播放RTSP或RTMP如何开启硬解码?

我们在做Windows平台Unity播放RTMP或RTSP的时候&#xff0c;遇到这样的问题&#xff0c;比如展会、安防监控等场景下&#xff0c;需要同时播放多路RTMP或RTSP流&#xff0c;这样对设备性能&#xff0c;提出来更高的要求。 虽然我们软解码&#xff0c;已经做的资源占有非常低了…

mysql 默认的4个数据库 介绍

mysql 存储MySQL的用户账号和权限信息&#xff0c;一些存储过程、事件的定义信息 一些运行过程中产生的日志信息&#xff0c;一些帮助信息以及时区信息等 information_schema 存储Mysql服务器 维护的所有其它数据库的信息&#xff0c;比如有哪些表、哪些视图、哪些触发器、哪…

基于YOLOv8模型和DarkFace数据集的黑夜人脸检测系统(PyTorch+Pyside6+YOLOv8模型)

摘要&#xff1a;基于YOLOv8模型和DarkFace数据集的黑夜人脸检测系统可用于日常生活中检测与定位黑夜下的人脸&#xff0c;利用深度学习算法可实现图片、视频、摄像头等方式的目标检测&#xff0c;另外本系统还支持图片、视频等格式的结果可视化与结果导出。本系统采用YOLOv8目…