微信支付那些坑,先说哪些坑。
1.redirect_url参数错误。我在这个错误纠结了很久。终于发现错误的原因在哪了。报这个错误是因为获取openid失败。官方给的demo是通过Getopenid()这个方法获取openid。
我们来看看Getopenid这个方法写了哪些。
public function GetOpenid()
{
//通过code获得openid
if (!isset($_GET['code'])) {
//触发微信返回code码
$baseUrl = urlencode('http://wx.zion-washing.com/WxpayAPI_php_v3/example/jsapi.php');
// **$baseUrl = urlencode('http://'.$_SERVER['HTTP_HOST'].$_SERVER['REQUEST_URI'].$_SERVER['QUERY_STRING']);**
$url = $this->__CreateOauthUrlForCode($baseUrl);
Header("Location: $url");
exit();
} else {
//获取code码,以获取openid
$code = $_GET['code'];
$openid = $this->getOpenidFromMp($code);
return $openid;
}
}
.
它会先获取code,获取code就需要请求服务器的url($baseurl)进行网页授权获取用户信息。如果授权成功会返回一个code值,然后根据code值获取openid。
问题的关键就在请求这个url,这里面我写死了。如果我没有写死的话它就会请求你在微信公众号的网页授权地址。(不过首先要保证你的服务器是有网络的)
成功跳转到这个url,并且获取code,然后在通过code获取openid。这些代码全部要在服务器上才可以。
2.invalide code。原因:code码执行一次就失效,需要重新获取哦。