微信支付--"errcode":40163

{"errcode":40163,"errmsg":"code been used, hints: [ req_id: zd0638th44 ]"}

微信支付获取用户openid时,报出错误。原因是apache中同时配置了http和https,微信网页oauth认证通知了两次

$openId = $tools->GetOpenid();
public function GetOpenid()
{
//通过code获得openid
if (!isset($_GET['code'])) {
//触发微信返回code码
$baseUrl = urlencode('https://' . $_SERVER['HTTP_HOST'] . $_SERVER['REQUEST_URI']);
$url = $this->__CreateOauthUrlForCode($baseUrl);
Log::write('$url:' .$url);
Header("Location: $url");
exit();
} else {
//获取code码,以获取openid
$code = $_GET['code'];
Log::write('code:' .$code);
$openid = $this->getOpenidFromMp($code);
return $openid;
}
}
错误消息提示code己经被使用过了,微信支付只调用一次GetOpenid()怎么会出现这种情况呢

[ log ] GetOpenidFromMp: {"access_token":"DwiMImR_Cc8NmHsi4IZ4jAb8mrs6v5fEbiHDkS3Zv_UpiGF-LxaLWdC8S9YQ1yQAhHQ2IQpa6AvXNnFOUYbjP6KhxMwHZCeqhAi12rXtN3o","expires_in":7200,"refresh_token":"5Xn4mKIc7aRq08LFjf1Aw1EZS7v_KF10jeZP1Yd1-eFzlmdK-Tjeuw7SQ1wpFyI-44vEW7pQOlfy69FLvQuFXTXhFHK00lPWr-Uv1uPQXaw","openid":"o6DPDtwo9grbSux1UT9aD8mgyFvU","scope":"snsapi_base"}

[ log ] GetOpenidFromMp: {"errcode":40163,"errmsg":"code been used, hints: [ req_id: zd0638th44 ]"}

上面的两条日志是在一次支付中出现的,证明code确实被使用了两次。

bug是在配置https以后出现的,这个提示让我最终找到了原因。

我删除apache配置文件中http保留https,原因嘛就是微信通知2017-12-31日前微信开发必须使用https。

 

转载于:https://www.cnblogs.com/domain-li/p/7652076.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值