1. 程式人生 > >微信支付--"errcode":40163

微信支付--"errcode":40163

code wim 用戶 rom err span flv 錯誤 style

{"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。

微信支付--"errcode":40163