h5怎么在微信公众号发布(H5微信公众号授权的简单实现步骤)
类别:编程学习 浏览量:1256
时间:2021-09-29 01:53:36 h5怎么在微信公众号发布
H5微信公众号授权的简单实现步骤前言
昨天因为有一个项目上面需要实现h5微信授权工作。所以花了两个小时来完成这个功能。
开始工作前做的准备流程说明【提前沟通过的流程】
- 微信授权具有时效性,一段时间内授权之后,就不需要在重复点击确认。如果卸载微信重新安装,还是需要重新确认授权的。
- 不管是第一次确认授权还是授权之后,都可以通过微信服务器授权回调到我们的后端接口回调。
- 微信授权回调之后,会返回回调回来的code&state参数,后端可以通过code获取accessToken,然后通过accessToken获取用户信息
- 后端在接收到服务器回调之后,在回调到前端的时候存在两个主要的字段,isAuth代表是否授权,isBindFlag代表是否在我们系统当中已经注册登录。这里因为我们当前的系统需要用户授权注册,所以存在这两个字段。
域名,端口
- 准备好的域名 - 公安部备案的域名
- 端口号使用80端口
域名和端口号的要求是因为微信公众号配置域名以及微信服务器回调都需要域名和80端口。
这里同一个域名,端口适配前后端IP,通过nginx统一代理处理。
准备就绪开始工作
- 域名:http.xxx.cn
- 前端资源部署:http.xxx.cn
- 后端回调接口:http.xxx.cn/api/auth
配置微信公众号
域名配置
服务器根路径上传校验文件,不然域名配置保存不了。
白名单配置
书写代码
import React, { useEffect } from "react"; import { View } from "@tarojs/components"; export default () => { useEffect(() => { // 后端回调回来路径格式:http://xxx.cn/#/pages/webAuthorization?bindFlag=0&openid=xxxxxxxxxxx&unionid=null&isAuth=true var isBindFlag = false, isAuth = false, opendId = '', paramsArray = []; /* * 省略代码:地址判断,参数处理 赋值给isAuth, isBindFlag, openId */ if (!isAuth) { // 未授权 window.location.href=`https://open.weixin.qq.com/connect/oauth2/authorize?appid=${'xxxxxxx'}&redirect_uri=http://xxxxx/api/auth?response_type=code&scope=snsapi_userinfo&state=STATE&connect_redirect=1#wechat_redirect`; } else if (!isBindFlag) { // 未注册 window.location.href = '#/pages/login' } else { // 登录 window.location.href = '#/pages/index' } }, []); return ( <View> </View> ); };
总结
到此这篇关于H5微信公众号授权的文章就介绍到这了,更多相关微信公众号授权内容请搜索开心学习网以前的文章或继续浏览下面的相关文章希望大家以后多多支持开心学习网!
您可能感兴趣
- 微信公众号扫码跳转网页(微信公众号实现扫码获取微信用户信息网页授权)
- 微信公众号怎么获取用户openid(微信公众平台开发教程①获取用户Openid及个人信息图文详解)
- 微信公众号用户怎么增加(微信公众号用户与网站用户的绑定解决方案分析)
- 微信公众号文章 爬虫(python抓取搜狗微信公众号文章)
- 微信公众号怎么开发页面(微信公众平台开发教程②微信端分享功能图文详解)
- 开发者微信公众号开发流程(微信公众平台开发教程⑥ 微信开发集成类的使用图文详解)
- 微信公众号怎么申请支付接口(微信公众平台开发教程③ PHP实现微信公众号支付功能图文详解)
- h5怎么在微信公众号发布(H5微信公众号授权的简单实现步骤)
- python有什么好的微信公众号(python下载微信公众号相关文章)
- python如何抓取公众号文章(python爬取微信公众号文章的方法)
- 如何用微信公众号发送信息(微信公众号之主动给用户发送消息功能)
- h5页面强制关注微信公众号(Html5页面获取微信公众号的openid的方法)
- php微信公众号管理后台(php实现微信公众号创建自定义菜单功能的实例代码)
- 涉及3条地铁线路 成都这4座轨道交通站点有新名字了(涉及3条地铁线路)
- 来了 成都轨道交通5条线路刷新 进度条(成都轨道交通5条线路刷新)
- 一部手机两套系统 OPPO Find X3的正确打开方式你知道吗(一部手机两套系统)
- OPPO用户看过来 汇总几个春节实用技巧,轻松搞定多设备联动玩法(汇总几个春节实用技巧)
- 北京旅游攻略(北京旅游攻略5日游及其花费)
- 四川旅游攻略(四川旅游攻略自由行攻略)
热门推荐
- mysql中怎么删除整张表(MySQL如何优雅的删除大表实例详解)
- docker配置源不生效(解决docker CMD/ENTRYPOINT执行sh脚本报: not found/run.sh:)
- jquery隐藏动画教程(jquery插件实现鼠标隐藏)
- phpstudy默认不支持64位php的解决方法(phpstudy默认不支持64位php的解决方法)
- aspwebserver怎么操作(EasyWebServer怎么用?EasyWebServer网站服务器软件使用教程)
- html5自定义字体图标(HTML5给汉字加拼音收起展开组件的实现代码)
- mysql5.5.36版本介绍(WDCP控制面板升级mysql为5.7.11的方法)
- linux telnet命令使用(Linux telnet命令的使用)
- dede调用栏目路径(dede栏目列表首页与第一页链接出现重复的解决办法)
- dedecms授权付费(dedecms实现删除垃圾会员的方法)
排行榜
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9