本文將和大家分享一下微信支付JsApi 40163錯誤以及解決方案代碼。
錯誤:
未定義陣列索引:openid 。
經過檢查發現是:微信支付授權取得openId {“errcode”:40163,“errmsg”:“code been used”,}
原因為:微信支付code 只能使用一次,第二次重複使用時就會出現此錯誤。
解決相關參考:https://www.e-learn.cn/content/php/1102683
參考中的方法本人嘗試無果,故自己根據原因重寫:
經過檢查發現問題出在:
WxPay.JsApiPay.php中的GetOpenid方法,原始碼為:
/** * * 通过跳转获取用户的openid,跳转流程如下: * 1、设置自己需要调回的url及其其他参数,跳转到微信服务器https://open.weixin.qq.com/connect/oauth2/authorize * 2、微信服务处理完成之后会跳转回用户redirect_uri地址,此时会带上一些参数,如:code * * @return 用户的openid */ public function GetOpenid() { //通过code获得openid if (!isset($_GET['code']) ){ //触发微信返回code码 $baseUrl = urlencode('http://'.$_SERVER['HTTP_HOST'].$_SERVER['REQUEST_URI']); $url = $this->__CreateOauthUrlForCode($baseUrl); Header("Location: $url"); exit(); } else { //获取code码,以获取openid $code = $_GET['code']; $openid = $this->getOpenidFromMp($code); return $openid; } }
改後程式碼為:
/** * * 通过跳转获取用户的openid,跳转流程如下: * 1、设置自己需要调回的url及其其他参数,跳转到微信服务器https://open.weixin.qq.com/connect/oauth2/authorize * 2、微信服务处理完成之后会跳转回用户redirect_uri地址,此时会带上一些参数,如:code * * @return 用户的openid */ public function GetOpenid() { //通过code获得openid if (!isset($_GET['code']) ){ //触发微信返回code码 $baseUrl = urlencode('http://'.$_SERVER['HTTP_HOST'].$_SERVER['REQUEST_URI']); $url = $this->__CreateOauthUrlForCode($baseUrl); Header("Location: $url"); exit(); } else { //获取code码,以获取openid $code = $_GET['code']; if(session("?$code")){ $openid = $this->getOpenidFromMp($code); }else{ $openid= session($code); } session($code, $openid);// ###### 2019.03.01 加 为解决code been used return $openid; } }
邏輯為將取得到的openid以code為名存入session;當再次請求時,查詢該次請求中以code為名的session是否存在,以此防止二次使用code。
相關教學:PHP影片教學
#以上是【PHP】微信支付JsApi 40163錯誤的詳細內容。更多資訊請關注PHP中文網其他相關文章!