关于wx.config报错 invalid url domain 及 invalid signature 错误原因及解决方式

wx.config的初始化配置

wx.config({debug: true, // 开启调试模式,调用的所有api的返回值会在客户端alert出来,若要查看传入的参数,可以在pc端打开,参数信息会通过log打出,仅在pc端时才会打印。appId: res.data.data.appId, // 必填,公众号的唯一标识timestamp: res.data.data.timestamp, // 必填,生成签名的时间戳nonceStr: res.data.data.nonceStr, // 必填,生成签名的随机串signature: res.data.data.signature,// 必填,签名jsApiList: ["checkJsApi",] // 必填,需要使用的JS接口列表});

1、 invalid url domain        (错误的url)

当报错 invalid url domain时 ,错误原因就是url并没有在公众号设置里正确设置。

  • appid 是否正确(查看在 微信公众平台-> 登陆公众号后台 -> 基本配置-> 开发者ID(AppID))

  • 域名绑定是否正确(查看在 微信公众平台-> 登陆公众号后台 -> 公众号设置-> 功能设置 -> JS接口安全域名)

注意:在域名绑定时,请确定绑定域名与你H5进行wx.config发起域名一致,http与https一致

2、 invalid signature   (错误的签名)

当报错 invalid signature 时,错误原因是生成签名的url与当前页面的url不一致,一定要重点检查。

        遇到这个报错就是url地址不一致,在调用接口获取签名时我们通过 location.href.split('#')[0] 来获取当前url地址。

        vue中路由有history和hash两种模式;在history模式下,理想的设计方案是,当进入到需要用到JS-SDK组件时,获取以下当前url(也就是通过 location.href.split(‘#’)[0]获得到的地址)传递到服务端进行签名。

        在我们获取当前地址传递的时候有时需要进行 encodeURIComponent(window.location.href.split('#')[0]) 编码,有的时候又不需要,因为浏览器获取时会帮我们编码,所以根据情况而定。

      但是IOS获取的url并不是调用微信js的时候所在页面的地址,而是进入到网站第一个页面的地址,所以我们需要在需要获取url的页面重新刷新获取,或者将进入页面时先将当前url记录下来,到授权页面时将记录的url传递给服务端进行签名。(此方法也可用于url在ios系统中拼了参数)

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

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

相关文章

第三届仿真模拟、电子信息科学与技术国际学术会议(SMEI 2024,8月02-04)

随着仿真模拟技术的成熟和进步,仿真模拟技术越来越广泛地应用于工业工程、管理科学、社会经济、交通运输、生态环境、军事装备等各个科学领域,并深刻影响着信息技术和信息产业的发展。围绕仿真模拟、电子信息科学与技术等方面内容,为更好地促…

Gartner发布2024年企业高管增长议程:使网络安全投资与业务增长保持一致

网络安全投资和准备被视为推动企业发展的关键因素。除了避免损失之外,高管还应利用有效的以业务为中心的安全方法,通过大规模实现敏捷性和创新来推动收入增长。 主要发现 高增长公司通过扩大商业足迹来推动业绩,这需要大规模的创新、敏捷性和…

CUDA生态系统架构是什么样的?CUDA的技术原理是什么?底层原理是什么?怎么开发相关产品

CUDA生态系统架构是什么样的?CUDA的技术原理是什么?底层原理是什么?怎么开发相关产品 CUDA 生态系统及其技术原理 CUDA(Compute Unified Device Architecture)是由 NVIDIA 开发的一种并行计算平台和编程模型&#xf…

爬虫 pandas Linux Flume Pig填空题

目录 试卷:Python网络数据处理 答案 试卷:Pandas基础操作 答案 试卷:Linux基础指令 答案 试卷:Apache Flume基础指令 答案 试卷:Apache Pig基础指令 答案: Hadoop题 答案 试卷:Pyth…

002 使用kibana操作ElasticSearch7.x

文章目录 4.使用kibana操作es4.1.文档操作1.put方式发送数据2.post方式发送数据3.查看索引文档 GET4.更新文档 POST5.删除文档&索引 DELETE6.批量添加数据_bulk 4.2.Query DLS(查询领域对象语言)1.url 检索数据语法2.查询所有数据3.查询全部数据并排序4.查询全部数据排序并…

时序分析基本概念介绍——min period 最小时钟周期

文章目录 前言一、什么是 min period?二、为什么检查 min period?三、如何设置 min period?四、如何检查 min period?五、如何修复 min period?总结 前言 我们在实际设计中可能会碰到这种情况,如果我们的m…

openstack Y版在ubuntu22.04上不能创建超过8个cpu的虚拟机问题解决

环境 openstack 版本: Y版25.2.1 操作系统:ubuntu22.04 问题 创建16 vcpu的虚拟机,报错: Failed to build and run instance: libvirt.libvirtError: error from service: GDBus.Error:org.freedesktop.DBus.Error.InvalidArgs…

leetcode-16-[530]二叉搜索树的最小绝对差[501]二叉搜索树中的众数[236]二叉树的最近公共祖先

一、[530]二叉搜索树的最小绝对差 重点:双指针 class Solution {int minResInteger.MAX_VALUE;TreeNode prenull;public int getMinimumDifference(TreeNode root) {traversal(root);return minRes;}void traversal(TreeNode cur){//中序遍历if(curnull){return;}…

介绍ES6中的class类:(一) 类的基本语法

一、类的由来与简介 1. 简介 很早很早之前,在JavaScript的世界里,生成实例对象的传统方法是通过构造函数。 嗯哼? function Point(x, y) {this.x x;this.y y; }Point.prototype.toString function () {return ( this.x , this.y )…

计算机图形学入门18:阴影映射

1.前言 前面几篇关于光栅化的文章中介绍了如何计算物体表面的光照,但是着色并不会进行阴影的计算,阴影需要单独进行处理,目前最常用的阴影计算技术之一就是Shadow Mapping技术,也就是俗称的阴影映射技术。 2.阴影映射 Shadow Map…

Kubernetes面试整理-如何配置和应用网络策略来控制Pod之间的通信

在 Kubernetes 中,网络策略(NetworkPolicy)用于控制 Pod 之间的通信以及 Pod 与外部网络之间的通信。通过定义网络策略,您可以指定哪些流量可以进出特定的 Pod,从而增强集群的安全性和隔离性。 配置网络策略 网络策略是基于命名空间的,并使用标签选择器(Label Selector)…

提升用户转化率秘诀!Xinstall的H5拉起应用技术让您领先一步!

在移动互联网时代,App的推广和运营面临着诸多挑战。其中,H5页面如何高效、便捷地拉起应用,成为了一个亟待解决的问题。今天,我们就来谈谈如何利用Xinstall品牌,轻松解决这一痛点,提升用户体验,助…

boss直聘招聘数据爬取及可视化分析2.0

boss直聘招聘数据爬取及可视化分析2.0 一、需求介绍二、完整代码2.1 爬虫代码2.2 数据可视化模块一、需求介绍 笔者在前两篇介绍boss直聘招聘数据爬取和可视化分析的博客的基础上,对代码和功能进行了完善。在数据爬取的模块,代码更加简洁易懂,且性能更加稳定;在数据可视化…

SpringBoot | 使用jwt令牌实现登录认证,使用Md5加密实现注册

对于登录认证中的令牌,其实就是一段字符串,那为什么要那么麻烦去用jwt令牌?其实对于登录这个业务,在平常我们实现这个功能时,可能大部分都是通过比对用户名和密码,只要正确,就登录成功&#xff…

关于 AD21导入电子元器件放置“3D体”STEP模型失去3D纹理贴图 的解决方法

若该文为原创文章,转载请注明原文出处 本文章博客地址:https://hpzwl.blog.csdn.net/article/details/139969415 长沙红胖子Qt(长沙创微智科)博文大全:开发技术集合(包含Qt实用技术、树莓派、三维、OpenCV…

C++高频面试题——内存管理、堆栈、指针

一、内存管理 1.1什么是动态内存分配?在C中,如何进行动态内存分配? 动态内存分配是在程序运行时,根据需要从堆中分配内存空间,以便于灵活地管理数据。 在C中,可以使用以下操作符进行动态内存分配&#x…

https网站安全证书的作用与申请办法

HTTPS网站安全证书,正式名称为超文本传输安全协议证书,是通过SSL/TLS加密协议,保障互联网用户与网站间数据交换的安全性的关键技术。 一:HTTPS网站安全证书的作用 1 消除不安全提示:未使用https协议的网站&#xff0c…

threejs的学习(一)

1.万事开头难 先把环境搭好 https://github.com/mrdoob/three.js/tree/dev/src 把这个项目clone下来 yarn install 安装依赖 yarn start 启动项目 然后用vite新建一个项目 npm init vite@latest 选择第一个 Vanilla就行 然后选择js 然后成功创建之后,npm start npm …

云计算【第一阶段(22)】进程和计划任务管理

一、查看进程 1.1、程序和进程的关系 程序 保存在硬盘,光盘等介质中的可执行代码和数据静态保存的代码 进程 在cpu及内存中运行的程序代码动态执行的代码父,子进程:每个程序可以创建一个或多个进程 1.2、查看进程 1.2.1、静态查看进程…

深度学习优化器深度解析:SGD、Adam、RMSprop的比较与应用

在深度学习中,优化器是用于调整神经网络权重的关键组件,它们直接影响到模型训练的效率和最终性能。随机梯度下降(SGD)及其变体,如Adam和RMSprop,是目前最流行的几种优化算法。本文将详细探讨这些优化器的工…