本文将和人人分享一下微信付出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毛病的细致内容,更多请关注ki4网别的相干文章!