微信扫码登录的两种方式:利用微信开放平台、利用微信公众平台(微信公众号)

本文主要是介绍微信扫码登录的两种方式:利用微信开放平台、利用微信公众平台(微信公众号),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

微信扫码登录,有两种实现方式:
方式1、微信开放平台是微信为了接入更多第三方应用而开放的接口,依赖公司在【微信开放平台】用【公司营业执照】注册的账号,才能实现扫码登录
方式2、微信公众平台是扫码通过微信公众号授权登录的,借助个人或者公司的微信公众号,生成微信带参二维码,实现扫码关注公众号后登录
大家要明确自己要用哪种方式。

其实还有一种场景是h5页面通过点击某个按钮(实际调用微信的网页授权接口)从而获取用户信息。这种场景可以参考这个视频------->地址

本文只详细介绍第一种方式---------- 【微信开放平台】

第一种方式: 【微信开放平台】

现在微信的使用用户越来越多,如果网站添加上微信登录,就能节省很多用户注册时间,极大缩小了注册流程。会让用户觉得特别方便。接下来我们就说一下怎么来实现PC端微信扫码登录。

第一步:微信开放平台账户申请

网址:微信开放平台

1.首先我们要做的就是进入到微信开放平台申请一个开放平台账户,获得资质!

(1) 支持企业类型(以前只支持企业注册)

(2) 注册之后,会给你提供微信id和微信密钥

ps:注册需要准备营业执照、1-2个工作日审批、300元认证费

进入页面以后,点击注册按钮,开始注册我们的新账户。按照要求一步一步完成注册即可 

2. 申请网站应用名称。

进入到开放平台的“管理中心”=》“网站应用” 然后创建网站应用就能创建自己的网站应用了。

就是说你扫描二维码,它会显示当前网站的应用名称,这个一般在7个工作日内审批。

审核通过后,列表就会可以查看到这个网站应用,点击查看可以获取到appIdappSecret了。

3. 设置回调域名,需要域名地址。

地址作用:这个回调域名是我们扫码完成以后跳转的页面,这时这个页面上会返回微信给我们的code,基于这个code我们就能够拿到微信用户的信息,开进行登录了。设置跟appSecret一样也是在详情页面。


 接下来开始在前端去实现这个扫码功能

微信登录功能官方文档

文档中提到了两种方式去让用户扫码,也可以说是二维码展示的两种方式。

一种是跳转二维码扫描页面,另一种是内嵌式二维码。大家可以根据需要自行选择。

整个流程大致是这样子:

①第三方发起微信授权登录请求,微信用户允许授权第三方应用后,微信会拉起应用或重定向到第三方网站,并且带上授权临时票据code参数;

②通过code参数加上AppID和AppSecret等发送给后端,后端通过API换取access_token;

③后端通过access_token进行接口调用,获取用户基本数据资源或帮助用户实现基本操作。

接下来详细描述过程:

首先两种二维码展示的方式:

内嵌式二维码:(微信官方文档里面可以找到下面步骤)

1.首先在页面引入http://res.wx.qq.com/connect/zh_CN/htmledition/js/wxLogin.js,如果网站支持https那就把前缀改为https

2.在需要使用微信登录的地方实例以下JS对象:

var obj = new WxLogin({self_redirect:true,id:"login_container", appid: "", scope: "", redirect_uri: "",state: "",style: "",href: ""});

参数说明: 

ps:这个回调地址就是我们之前在配置文件中配置的redirect_url重定向地址,它是当初注册资质时填写的域名地址。

在页面内定义一个div来显示二维码,这个id要传入创建二维码的方法,下面这个方法接收的ID就是容器的ID。 

这样就可以把二维码展示出来了

跳转二维码扫描页面

 直接请求微信提供的固定的地址,向地址的后面拼接参数即可。

https://open.weixin.qq.com/connect/qrconnect?appid=APPID&redirect_uri=REDIRECT_URI&response_type=code&scope=SCOPE&state=STATE#wechat_redirects
 

参数说明:(详见官方文档)

ps:这个回调地址就是我们之前在配置文件中配置的redirect_url重定向地址,它是当初注册资质时填写的域名地址。

通过上面两种二维码的展示方式后,我们可以拿到code,接下来通过微信提供的api换取用户access_token,和openid

https://api.weixin.qq.com/sns/oauth2/access_token?appid=APPID&secret=SECRET&code=CODE&grant_type=authorization_code

 

返回说明

正确的返回:

{ 
"access_token":"ACCESS_TOKEN",   //接口调用凭证
"expires_in":7200,               //access_token接口调用凭证超时时间,单位(秒)
"refresh_token":"REFRESH_TOKEN",  //用户刷新access_token
"openid":"OPENID",                //授权用户唯一标识
"scope":"SCOPE",                  //用户授权的作用域,使用逗号(,)分隔
"unionid": "o6_bmasdasdsad6_2sgVt7hMZOPfL"   //当且仅当该网站应用已获得该用户的userinfo授权时,才会出现该字段。
}

 

这篇关于微信扫码登录的两种方式:利用微信开放平台、利用微信公众平台(微信公众号)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/733776

相关文章

gitlab安装及邮箱配置和常用使用方式

《gitlab安装及邮箱配置和常用使用方式》:本文主要介绍gitlab安装及邮箱配置和常用使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1.安装GitLab2.配置GitLab邮件服务3.GitLab的账号注册邮箱验证及其分组4.gitlab分支和标签的

C++中零拷贝的多种实现方式

《C++中零拷贝的多种实现方式》本文主要介绍了C++中零拷贝的实现示例,旨在在减少数据在内存中的不必要复制,从而提高程序性能、降低内存使用并减少CPU消耗,零拷贝技术通过多种方式实现,下面就来了解一下... 目录一、C++中零拷贝技术的核心概念二、std::string_view 简介三、std::stri

Linux脚本(shell)的使用方式

《Linux脚本(shell)的使用方式》:本文主要介绍Linux脚本(shell)的使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录概述语法详解数学运算表达式Shell变量变量分类环境变量Shell内部变量自定义变量:定义、赋值自定义变量:引用、修改、删

python判断文件是否存在常用的几种方式

《python判断文件是否存在常用的几种方式》在Python中我们在读写文件之前,首先要做的事情就是判断文件是否存在,否则很容易发生错误的情况,:本文主要介绍python判断文件是否存在常用的几种... 目录1. 使用 os.path.exists()2. 使用 os.path.isfile()3. 使用

SpringBoot服务获取Pod当前IP的两种方案

《SpringBoot服务获取Pod当前IP的两种方案》在Kubernetes集群中,SpringBoot服务获取Pod当前IP的方案主要有两种,通过环境变量注入或通过Java代码动态获取网络接口IP... 目录方案一:通过 Kubernetes Downward API 注入环境变量原理步骤方案二:通过

Mybatis的分页实现方式

《Mybatis的分页实现方式》MyBatis的分页实现方式主要有以下几种,每种方式适用于不同的场景,且在性能、灵活性和代码侵入性上有所差异,对Mybatis的分页实现方式感兴趣的朋友一起看看吧... 目录​1. 原生 SQL 分页(物理分页)​​2. RowBounds 分页(逻辑分页)​​3. Page

Python基于微信OCR引擎实现高效图片文字识别

《Python基于微信OCR引擎实现高效图片文字识别》这篇文章主要为大家详细介绍了一款基于微信OCR引擎的图片文字识别桌面应用开发全过程,可以实现从图片拖拽识别到文字提取,感兴趣的小伙伴可以跟随小编一... 目录一、项目概述1.1 开发背景1.2 技术选型1.3 核心优势二、功能详解2.1 核心功能模块2.

Linux链表操作方式

《Linux链表操作方式》:本文主要介绍Linux链表操作方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、链表基础概念与内核链表优势二、内核链表结构与宏解析三、内核链表的优点四、用户态链表示例五、双向循环链表在内核中的实现优势六、典型应用场景七、调试技巧与

Linux实现线程同步的多种方式汇总

《Linux实现线程同步的多种方式汇总》本文详细介绍了Linux下线程同步的多种方法,包括互斥锁、自旋锁、信号量以及它们的使用示例,通过这些同步机制,可以解决线程安全问题,防止资源竞争导致的错误,示例... 目录什么是线程同步?一、互斥锁(单人洗手间规则)适用场景:特点:二、条件变量(咖啡厅取餐系统)工作流

RedisTemplate默认序列化方式显示中文乱码的解决

《RedisTemplate默认序列化方式显示中文乱码的解决》本文主要介绍了SpringDataRedis默认使用JdkSerializationRedisSerializer导致数据乱码,文中通过示... 目录1. 问题原因2. 解决方案3. 配置类示例4. 配置说明5. 使用示例6. 验证存储结果7.