• 微信授权,重定向两次


    做微信支付的时候,需要微信授权拿openId

    大概流程就是,把用户重定向到微信一个地址,然后微信带着code重定向回来,然后拿code换用户的openId

    这期间发生了一件比较有意思的事情,android版的微信授权失败导致没法支付,看了一下服务器上报错如下

    System.Collections.Generic.KeyNotFoundException: 给定关键字不在字典中。
       在 System.Collections.Generic.Dictionary`2.get_Item(TKey key)
       在 WxPayAPI.JsApiPay.GetOpenidAndAccessTokenFromCode(String code)
    {"errcode":40163,"errmsg":"code been used, hints: [ req_id: tivCza01272165 ]"}

    我支付代码是和官方demo一样的,基本没改。

    然后看到这个错误,我第一反映是打一下日志,我把授权页面打上了日志,记录了一下访问时间和访问的url完整地址,也就是包含参数部分的。

    然后再把用code换openId的result也用日志记录了。

    然后发现

    我请求拿code后,微信同一个code给我重定向回来了两次,第一次我换取到了openId,第二次没换到openI的,错误内容是 code has been used,也就是code被使用过了。

    所以问题肯定是出在两次重定向。但是为什么会同一个code重定向两次?我搜了一下,很多开发同学都碰到过,有的人请求授权的时候加了一个参数  &connect_redirect=1 ,我看了一下很多人的反馈,有些人是可以解决问题的,有些人依然没解决,比如我。。。。。

    然后搜来搜去,还有人在园子里说是360搞的鬼,见帖子: http://www.cnblogs.com/Can-daydayup/p/10128324.html

    然后我服务器也安装了 360 ,然后我一退出就不会了。所以我想问问@MJ0011,为什么我们服务器发起请求,你360要做一次?

    360能给个说法么?这是要解决什么问题所以要重发一个请求?

  • 相关阅读:
    ssh出错 sign_and_send_pubkey: signing failed: agent refused operation
    使用dd命令制作U盘启动盘wodim刻录光盘cd dvd
    Python示例项目学习
    Python知乎上推荐的项目
    Python10大热门项目
    Python开源项目Top30
    Python适合练手的项目
    Python80个练手项目列表
    Python爬虫实例项目
    Python实例100个(基于最新Python3.7版本)
  • 原文地址:https://www.cnblogs.com/Jerseyblog/p/10137929.html
Copyright © 2020-2023  润新知