一个商城小程序前后弄了七天,头大屁股大,不全面的文档,什么都要自己摸索
关于上线后,必须要基于https通行,同时版本大于1.2,可以在阿里云申请免费的CA证书,网上一大堆教程,2018.4.16亲测可以申请到,不过要在申请证书的导航里乱点一通,点出免费的CA证书
windows 2008 r2 通过WindowsPower把版本升级到1.2以上,网上也是一大堆教程
下面主要讲开发中遇到的坑
一:首先登陆坑
获取session_key和openid
https://developers.weixin.qq.com/miniprogram/dev/api/api-login.html
前端代码
wx.login({
success: (loginRes) =>
{
loginRes.code
}
})
通过得到的code去
服务端,为什么要去服务端,不在前段完成?
官方提供的文档里有一段话:
会话密钥session_key 是对用户数据进行加密签名的密钥。为了应用自身的数据安全,开发者服务器不应该把会话密钥下发到小程序,也不应该对外提供这个密钥。
服务端php通过https://api.weixin.qq.com/sns/jscode2session获取session_key和openid
至于用户的头像 昵称等可以通过前端 wx.getUserInfo 接口得到
为了防止数据被篡改,微信官方提供一个 encryptedData返回值,通过下面页面提供的各种语言在服务端通过算法解开
https://developers.weixin.qq.com/miniprogram/dev/api/signature.html?t=20161122
一:支付坑
这个我要重点表扬微信官方,文档真的是乱,这儿一个页面,那儿一个页面,尤其在最后一步支付验证签名失败,绝对是大小写问题,要反复校对,例如一个appId 所有地方都是appid,这儿它偏要弄个大写,下面我会贴出php的绕坑代码,如果哪里不确定,官方提供了一个在线校验
https://pay.weixin.qq.com/wiki/tools/signverify/
支付步骤
用户前端发起支付->与服务器通信->服务器提交参数去微信支付接口(https://api.mch.weixin.qq.com/pay/unifiedorder)获取prepay_id->服务器生成校验参数发送到前端->前端执行wx.requestPayment
统一下单文档:https://pay.weixin.qq.com/wiki/doc/api/wxa/wxa_api.php?chapter=9_1
wx.requestPayment文档:https://developers.weixin.qq.com/miniprogram/dev/api/api-pay.html
经过统一下单接口后,千万要注意大小写,我在appid和nonce_Str这两个错误的写法反复检查了整整半天,下面提供个例子,我还会提供几个便捷转换函数,用于Array和伪Query的转换
$params=array(
'appId'=>'',
'package'=>'prepay_id='.'',
'timeStamp'=>'',
'signType'=>'MD5',
'nonceStr'=>''
);
$params['paySign']=md5Sign($params);
unset($params['appId']);
接着把$params传到前端调起wx.requestPayment接口
下面几个是php端开发,我常用的封好的函数
/*
by 醉亦逝愁
md5Sign用于小程序服务端签名校验
*/
function md5Sign($params){
ksort($params);
$stringA=arr2str($params);
$stringSignTemp=$stringA.'&key='.'商户key(mch_key)';
$sign=strtoupper(md5($stringSignTemp));
return $sign;
}
/*
by 醉亦逝愁
arr2str用于小程序服务端Array转伪Query
*/
function arr2str($array){
$string = [];
if($array && is_array($array)){
foreach ($array as $key=> $value){
$string[] = $key.'='.$value;
}
}
return implode('&',$string);
}
/*
by 醉亦逝愁
arr2str用于小程序服务端Array转Xml
用途https://api.mch.weixin.qq.com/pay/unifiedorder
*/
function arr2xml($arr,$item='root'){
$dom = new DOMDocument("1.0");
$item = $dom->createElement($item);
$dom->appendChild($item);
foreach ($arr as $key=>$val){
$itemx = $dom->createElement(is_string($key)?$key:"item");
$item->appendChild($itemx);
if (!is_array($val)){
$text = $dom->createCDATASection($val);
$itemx->appendChild($text);
}else {
arrayToXml($val,$dom,$itemx);
}
}
return $dom->saveXML($item);
}
https://api.mch.weixin.qq.com/pay/unifiedorder接口返回的xml通过如下函数变成Array
$xmlstring=simplexml_load_string($data, 'SimpleXMLElement', LIBXML_NOCDATA);
$data=get_object_vars($xmlstring);
其他的后面在补充。
,