当前位置: 首页 > news >正文

基于微信公众号开发h5的前端流程

1.首先公众号进行配置,必须要https域名

还有个txt文件,有弹框提示需要下载放在服务器上

前端处理code的代码封装

// 微信公众号授权
export function wxAuthorize(calback) {// 非静默授权,第一次有弹框 这里的回调页面就是放在服务器上微信会跳转回来反值如openid的页面let redirect_uri =config.redirect_uri || window.location.host; // 重定向地址console.log(redirect_uri, '重定向地址')let appid = config.appid  // 公众号appidlet code = getUrlCode().code; // 截取code// 获取之前的codelet oldCode = uni.getStorageSync('wechatCode')if (code == null || code === '' || code == 'undefined' || code == oldCode) {// 如果没有code,就去请求获取codeconsole.log('当前没有code,进入授权页面')let uri = encodeURIComponent(redirect_uri)// 设置旧的code为0,避免死循环uni.setStorageSync('wechatCode', 0)const urll =`https://open.weixin.qq.com/connect/oauth2/authorize?appid=${appid}&redirect_uri=${uri}&response_type=code&scope=snsapi_userinfo&state=State#wechat_redirect`console.log(urll, '------------urll-------------------');window.location.href = urll} else {console.log('存在code,使用code换取用户信息',code)// 保存最新codeuni.setStorageSync('wechatCode', code)wxCallback(`?code=${code}&state=123`).then(res => {// 成功data为tokencalback && calback({success: true,data:res})}).catch((err) => {if(err.code == '9997'){ //code失效重新进入window.location.reload()}else if(err.code == '9999'){ // 手机号未绑定calback && calback(err)}})}
}export function getUrlCode() {// 截取url中的code方法var url = location.search;// this.winUrl = url;var theRequest = new Object();if (url.indexOf('?') != -1) {var str = url.substr(1);var strs = str.split('&');for (var i = 0; i < strs.length; i++) {theRequest[strs[i].split('=')[0]] = strs[i].split('=')[1];}}console.log(theRequest,'spdspdop')return theRequest;
}export function getParams(url) {const searchParams = new URLSearchParams(url.split("?")[1]);const params = {};for (const [key, value] of searchParams.entries()) {params[key] = value;}return params;
}

http://www.lryc.cn/news/372696.html

相关文章:

  • python操作数据库,django操作数据库
  • React框架资源
  • 【数据结构】初识数据结构之复杂度与链表
  • word怎么单页横向设置(页码不连续版)
  • 搭建 Tomcat 集群【Nginx 负载均衡】
  • 深入理解指针(二)
  • 【Qt 学习笔记】Qt窗口 | 标准对话框 | 文件对话框QFileDialog
  • 换卡槽=停机?新手机号使用指南!
  • 主题切换之根元素CSS自定义类
  • 如何在 ASP.NET Core Web Api 项目中应用 NLog 写日志?
  • selenium execute_script常用方法汇总
  • 如何选择最佳的APP封装平台-小猪APP分发为您解忧
  • Linux基础 (十八):Libevent 库的安装与使用
  • 冒泡排序的详细介绍 , 以及c , python , Java的实现方法
  • 使用llama.cpp实现LLM大模型的格式转换、量化、推理、部署
  • 给你一个扫码支付的二维码,如何写测试用例?
  • 计算机专业在未来的发展与抉择
  • 【Linux】基础IO——文件描述符,重定向
  • 1.0 Android中Activity的基础知识
  • 线代知识点总结
  • 案例学习-存量更新规划实施探索(武汉)
  • C#操作MySQL从入门到精通(17)——使用联结
  • MyBatis 关于查询语句上配置的详细内容
  • 基于STM32和人工智能的智能家居监控系统
  • 这三款使用的视频、图片设计工具,提供工作效率
  • [Algorithm][贪心][最长递增子序列][递增的三元子序列][最长连续递增序列][买卖股票的最佳时机][买卖股票的最佳时机Ⅱ]详细讲解
  • 手把手教你入门vue+springboot开发(三)--登录功能后端
  • 三款有3D效果的js图表库
  • 【SQLAlChemy】表之间的关系,外键如何使用?
  • Linux 基础IO 二