美文网首页
一文解决wx.config没响应、configfail没具体原因

一文解决wx.config没响应、configfail没具体原因

作者: 小遁哥 | 来源:发表于2024-02-21 20:52 被阅读0次

我们的前端系统 cat 是被 animal 系统以 iframe 嵌套的,animal 系统 是政务微信里的一个应用,这事坏就坏在 iframe 上。

微信开放社区帖子绝大多数没人回答,又因为牵扯到多方,主要是我自己方向没搞对,花了不少时间。

解决办法就是调用 wx 的方法都在 window.parent.wx 上进行,鉴权的 url 也要是 window.parent.location.href

关键代码

import CryptoJS from 'crypto-js'
import wxApi from '@/api/wxApi'
import { showFailToast } from 'vant'
export default function () {
    return {
        startWxConfig(callback = () => {}) {
            let signature = ref(null)
            let noncestr = ref('')
            let timestamp = ref('')
            let queryParams = ref('')
            let jsapi_ticket
            function randomString(len) {
                len = len || 32
                var $chars = 'ABCDEFGHJKMNPQRSTWXYZabcdefhijkmnprstwxyz2345678'
                var maxPos = $chars.length
                var pwd = ''
                for (let i = 0; i < len; i++) {
                    pwd += $chars.charAt(Math.floor(Math.random() * maxPos))
                }
                return pwd
            }

            // 生成签名
            function createSignature() {
                noncestr.value = randomString(16)
                timestamp.value = Date.now()
                queryParams.value = randomString(32).toLowerCase()

                let str = `jsapi_ticket=${jsapi_ticket}&noncestr=${noncestr.value}&timestamp=${timestamp.value}&url=${window.parent.location.href}`

                signature.value = CryptoJS.SHA1(str).toString()
            }
            wxApi.getJsapiTicket().then((rsp) => {
                if (rsp.success) {
                    jsapi_ticket = rsp.result
                    createSignature()
                    window.parent.wx.ready(function () {
                        console.info('微信鉴权成功')
                        callback(true)
                    })
                    window.parent.wx.error(function (res) {
                        showFailToast('微信鉴权失败')
                        console.info('微信鉴权失败', res)
                        callback(false)
                    })

                    let configParams = {
                        beta: true,
                        debug: true,
                        appId: '',
                        timestamp: timestamp.value,
                        nonceStr: noncestr.value,
                        signature: signature.value,
                        jsApiList: ['getLocation'],
                    }

                    window.parent.wx.config(configParams)
                }
            })
        },
    }
}

wx.config 没反应

wx.config 调用了,不触发 read 也不触发 error,而我通过手机微信扫码是有响应的,突破点是同事提点政务微信有扫一扫的功能,可以判定问题是因为 iframe 嵌套导致的。

线上会议后,animal 系统的人同意将https://res.wx.qq.com/open/js/jweixin-1.6.0.js
放在他们的系统引入

config:fail 但是没说什么原因

这是因为我鉴权的 url 不是 window.parent.location.href,而是 window.location.href

这回我直接用政务微信扫描生产环境的二维码是行的通的,之前为什么不这么做?是因为报登录失败,我问 animal 系统的对接人说我们是不能直接登生产环境,后来我们这边的同事说是可以的,并提供了生产环境的用户名密码。

基于此就要考虑由 animal 系统的人来提供鉴权,我们传一些动态参数。线上会议讨论,提到我们的代码他们哪些要改的时候,animal 系统的前端提到鉴权 url 的问题,我修改后试了一下可以了。

总结

有时候解决问题是需要多个角度,问题也具备一定的随机性,比如换一个人来做,他可能首先想到的就是 iframe,animal 系统和我们都有一个测试环境,在里面虽然不同域,但是调用 wx.config 的现象是相同的。除非有明确的经验,否则经验也极有可能限制住思路。

我看网上挺多 wx.config 的问题但没有明确答案,其中 jsapi_ticket 是 animal 系统提供的,剩下的有我自己完成,这也一度是我怀疑的。中间还拉了几次政务微信的人开会,结论是可能签名算法不对,虽然我认为不是这个问题,但也想借着这个由子让他们完整的提供参数,从代码设计的角度来看也是合理的。

每当遇到这种问题,都会想起很早之前结论,问题的解决最终还是要靠自己,一定是某些没注意到的点,到了后面我的心态也很不好了,失误很多,尤其是没注意到 iframe 这个问题上,总觉得是别人的问题,总想着让人家配合,这都要反思。

相关文章

  • Scrapy踩坑:请求无响应,requests正常

    问题说明:Scrapy运行不报错,callback回调函数没响应 问题原因:请求的 header请求头 错误 解决...

  • UICollectionView点击没响应

    下拉刷新UICollectionView的时候,如果UICollectionView的内容很少,点击页面上的按钮、...

  • 不具体就没意义

    我们大概很多人都看到过这样的资讯信息。其实就和书籍的作者有编者作者一样,里面完全是两个水平。 一个编者他可能基本就...

  • iOS:右划返回手势与scrollView左右滑冲突

    原因: scrollView的优先响应了手势事件,导致右划事件未响应 解决:

  • 日精进-2018年10月9日

    今日问题: 1.106车子充不上电。 问题原因:CC、CP没信号所以充不上电。(对CC、CP没概念) 解决方法:没...

  • vant list 请求多次

    这个问题之前遇到过多次了 一直改改就行了 具体什么原因没查过 也没总结过。。。首先,考虑 进列表请求多次是什么原因...

  • 读书笔记——社交的真谛

    富兰克林说:有交往没友情,有友情没实力,有实力没主见,有主见没行动,有行动没好处,有好处没品德,终究还是一文不值。...

  • 没更新的原因

    我昨天没更新是因为我去了外婆家,其实我也知道,我晚上回来是来不及写简书的,主要是我晚上有课,所以耽误了,不过也...

  • 没发火的原因

    是因为,我写了分享,我说过,发火是无能的表现,进入我潜意识,所以,我今天早上没发火,内心有个声音在想,他背后什么没...

  • 监控系统出现插件没响应的解决方案

    关于有的学校智慧教室系统出现打开平台后台的监控系统,会出现插件没响应的情况,目前解决方案为升级视频监控插件。 视频...

网友评论

      本文标题:一文解决wx.config没响应、configfail没具体原因

      本文链接:https://www.haomeiwen.com/subject/fslwadtx.html