微信支付JsApi 40163錯誤
錯誤:
未定義數組索引:openid 。
經過檢查發現是 :微信支付授權獲取 openId {“errcode”:40163,“errmsg”:“code been used”,}
原因為:微信支付code 只能使用一次,當第二次重復使用時就會出現此錯誤。
解決相關參考:https://www.e-learn.cn/content/php/1102683
參考中的方法本人嘗試無果,故自己根據原因重寫:
經排查發現問題出在:
WxPay.JsApiPay.php中的GetOpenid方法,源碼為:
錯誤:
未定義數組索引: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()
{
*
* 通過跳轉獲取用戶的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;
}
}
改后代碼為:
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()
{
*
* 通過跳轉獲取用戶的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
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。
}
}
邏輯為將獲取到的openid以code為名存入session;當再次請求時,查詢該次請求中以code為名的session是否存在,以此防止二次使用code。