这里给大家分享我在网上总结出来的一些知识,希望对大家有所帮助

测试环境好好地功能,上了生产,莫名其妙报错,开始以为是没有设置Js安全接口域名,结果让相应人员一查,已经设置了相应的域名,再看下公众号内的接口权限部分,相关js权限也都是已授权,没办法,只能按照微信文档上的常见错误及解决方法,设置debug: true,然后测试出现如下错误提示:

网上按realAuthUrl搜了下,居然没搜到任何这方面的内容,奇了怪了,然后再按invalid signature搜索,这次搜到的内容就比较多了,但所有的内容都在描述一件事情:这东西只能猜!!

既然只能猜,而且后端有没有对签名这个过程做日志,生产也不能反复发布,那就猜吧,因为提示内容里有Url,js的签名也需要Url,所以是不是这个地址不对呢?让用户将微信网页的地址共享出来,结果发现地址没错,的确是正确的地址,那是不是后端的签名的地址与前端的地址不一致呢?因为项目是MVC项目,后端用于获取请求地址的代码如下:

        public static string GetJsSdkSignatureUrl(string url = null)
{
if (string.IsNullOrWhiteSpace(url))
{
url = HttpContext.Current.Request.Url.ToString();
}
var idx = url.IndexOf('#');
if (idx > 0)
{
return url.Substring(0, idx);
}
return url;
}

代码在默认调用时,都是没有传递参数进来,所以怀疑是不是请求地址发生了变化,想了下生产环境有可能是通过路由进行了转发,所以HttpContext.Current.Request.Url有可能与前端的地址不一致,于是在调用的代码上,额外再封装了一次,通过域名和路径来获取请求地址,域名从配置文件读取(当前应用是.Net Framework,不是.Net Core)

        private string GetRequestUrl(string path)
{
string url = null;
var host = ConfigurationManager.AppSettings["Host.Local"];
if (!string.IsNullOrWhiteSpace(path) && !string.IsNullOrWhiteSpace(host))
{
url = $"{host}{path}";
}
return JSSDKLocalHelper.GetJsSdkSignatureUrl(url);
}

测试环境测试了下没问题,然后又故意将测试环境的域名配置写成了错误的配置,测试环境也报了和生产环境类似的错误,于是将代码发到生产,果然该生产页面可以正确访问了,但过了一会,又有新的问题过来说另外一个页面也不对!查了下代码,因为GetJsSdkSignatureUrl是基础的公用方法,引用有好多个,不可能每个页面都自己组织地址,于是调整了下方法代码,当未传入请求地址且配置了本地域名时,用本地域名替换请求地址的域名

        public static string GetJsSdkSignatureUrl(string url = null)
{
if (string.IsNullOrWhiteSpace(url))
{
var host = ConfigurationManager.AppSettings["Host.Local"];
if (!string.IsNullOrWhiteSpace(host))
{
url = $"{host}{HttpContext.Current.Request.Url.PathAndQuery}";
}
else
{
url = HttpContext.Current.Request.Url.ToString();
}
}
var idx = url.IndexOf('#');
if (idx > 0)
{
return url.Substring(0, idx);
}
return url;
}

测试无误后,再发布到生产,问题顺利解决,再想想如果是前后端分离的项目,那页面请求地址应该是只能由前端传递到后端,这样估计也就没这篇博客的问题了。

微信公众号-分享报错invalid url domain的解决方法

微信公众号开发-自定义分享报错显示“invalid url domain”
前端微信公众号中的wx.config中开启调试模式,前端弹出信息“errMsg:config:invalid url domain”,出现这种错误的原因可能是:
1、前端域名没有授权
部署微信前端页面的服务器的域名要在在公众平台授权。

下载一个txt文件进行验证,修改JS接口安全域名后,再次调用公众号的分享,即可弹出config:ok的消息

目前还有一个疑惑:使用H5写的微信公众号,重写了分享功能,页面上定义了分享按钮,点击分享按钮,只会弹出config:ok消息,并未弹出到分享的页面;但使用公众号右上角的三个小点进行分享,已重写了分享的方法。

本文转载于:

https://blog.csdn.net/weixin_44934104/article/details/122457423

https://blog.csdn.net/starfd/article/details/122985269

如果对您有所帮助,欢迎您点个关注,我会定时更新技术文档,大家一起讨论学习,一起进步。

记录--JS-SDK页面打开提示realAuthUrl错误的更多相关文章

  1. browser-sync第一次打开提示路径错误,path.js应该输出字符串;之后重启一直提示插入代码片段,插入后无效依然提示

    网上找到gulp类似提示,是node版本问题. nvm派上用场, browser-sync@2.23.6,node用的8.3.0 解决办法: nvm install 7.8.0 nvm use 7.8 ...

  2. JS关闭页面无提示

    window.opener=null; window.open('','_self'); window.close();

  3. tomcat + jenkins启动tomcat后打开jenkins页面提示404错误的解决方案

    首先下载tomcat和jenkins,将下载的jenkins2.12 war放到tomcat的webapps文件夹下后执行/bin文件夹下的start启动后,打开http://localhost:80 ...

  4. win7打开或关闭windows功能 提示“出现错误,并非所有的功能被更改”,管理员权限惹的祸

    2013-07-25 18:12:06 最近要用到windows的telnet功能,本来是很简单的事情,因为管理员权限的问题,花了不少时间,才发现是管理员权限惹的祸,更滑稽的是,自己一直以来都不是管理 ...

  5. jquery.validate.unobtrusive.js实现气泡提示mvc错误

    改写jquery.validate.unobtrusive.js实现气泡提示mvc错误 个人对于这个js.css不是很擅长,所以这个气泡提醒的样式网上找了下,用了这个http://www.cnblog ...

  6. JS 在open打开的子窗口页面中调用父窗口页面的JS方法

    需求的情景如下: 1:做新增或修改等操作的时候打开一个新的浏览器窗口(使用window.open(参数等)方法) 2:在新增或修改等的页面上有返回按钮.重置按钮.保存按钮,对于返回就直接关闭此窗口(使 ...

  7. Asp.net MVC Form认证,IIS改成集成模式后,FormsAuthentication.SetAuthCookie无效,Request.IsAuthenticated值,始终为false,页面提示HTTP 错误 401.0 - Unauthorized,您无权查看此目录或页面

    最近公司领导要求,IIS网站要由经典模式改为集成模式,以提高性能.改完之后,登录成功跳转到主页之后,页面提示“”HTTP 错误 401.0 - Unauthorized“,“您无权查看此目录或页面”, ...

  8. js判断页面在pc端打开还是移动端打开

    js判断页面在pc端打开还是移动端打开,分别跳转不同的index.html window.addEventListener('load', function() { // true为手机,false为 ...

  9. 解决HTML加载时,外部js文件引用较多,影响页面打开速度问题

    解决HTML加载时,外部js文件引用较多,影响页面打开速度问题   通常HTML文件在浏览器中加载时,浏览器都会按照<script>元素在页面中出现的先后顺序,对它们依次加载,一旦加载的j ...

  10. Powerdesigner打开工程提示打印错误 解决方法

    在使用PowerDesigner打开工程时, 提示打印错误的问题,具体错误信息提示如下: 在您可以执行与打印机有关的任务(例如页面设置或打印一个文档)之前,您必须已经安装打印机.您想现在安装打印机么? ...

随机推荐

  1. keras建模的3种方式——序列模型、函数模型、子类模型

    1 前言 keras是Google公司于2016年发布的以tensorflow为后端的用于深度学习网络训练的高阶API,因接口设计非常人性化,深受程序员的喜爱. keras建模有3种实现方式--序列模 ...

  2. 李宏毅2022机器学习HW3 Image Classification

    Homework3 数据集下载 在本地环境下进行实验总是令人安心,但是又苦于网上找不到数据集,虽然kaggle上有数据集但是下载存在问题 于是有了一个天才的想法,间接从kaggle上下载(利用outp ...

  3. ubuntu 20.4安装docker

    ubuntu 20.4 安装docker 目录 查看版本并升级套件 安装必要软件 添加阿里云的GPG密钥,命令设置存储库 执行安装,查看版本 查看版本并升级套件 cat /proc/version L ...

  4. win32 - PeekNamedPipe的用法

    PeekNamedPipe: 将数据从命名管道或匿名管道复制到缓冲区中,而不将其从管道中删除.它还返回有关管道中数据的信息. 示例: #include <iostream> #includ ...

  5. Ansible Ad-hoc,命令执行模块

    目录 Ad-hoc Ad-hoc简介 Ad-hoc命令说明 Ad-hoc示例 命令执行模块 1. command模块 2. shell模块 3. raw模块 4. script模块 Ad-hoc Ad ...

  6. 如何快速使用LayUI MINI框架

    是什么 LayUI MINI是基于LayUI框架开发的一套最简洁.易用的后台框架模板,它已经是一个非常完整的脚手架,有现成的页面模板可以参考甚至是直接使用. 通常来说,如果我们准备开发一套管理系统的W ...

  7. Java 使用 itext 向PDF插入数据和图片

    Java 使用 itext 向PDF插入数据和图片 一.下载Adobe Acrobat DC 二.制作模板 1.准备一个word模板,并转换成PDF格式 2.使用Adobe Acrobat DC打开P ...

  8. 关于Image的mode属性(多图示例)

    一.总览 Image的mode是指图片裁剪.缩放的模式,共有14个合法值,分别是: /** 缩放模式,不保持纵横比缩放图片,使图片的宽高完全拉伸至填满 image 元素 */ scaleToFill ...

  9. 图数据库认证考试 NGCP 错题解析 vol.02:这 10 道题竟无一人全部答对

    如果你读过「NebulaGraph 错题解析第一期」,大概知道在错题解析未出来之前,NebulaGraph 专业技能认证 NGCP(全称 NebulaGraph Certified Professio ...

  10. Java 异常整合练习

    1 package com.bytezero.throwable2; 2 3 /** 4 * 5 * @Description 异常练习 6 * @author Bytezero·zhenglei! ...