限制。搖一搖是按照最近的同時搖手機的用戶配對,如果附近沒有,那么就會給你配對其他相對較近的。
4、活動推廣
基于活動推廣的可分為線上和線下,線......>>
一. 支付
支付主要分為幾個步驟:
1前端攜帶支付需要的數據(商品id,購買數量等)發起支付請求
2后端在接收到支付請求后,處理支付數據,然后攜帶處理后的數據請求 買粉絲服務器 的 支付統一下單接口
3后端接收到上一步請求買粉絲服務器的返回數據,再次處理,然后返回前端讓前端可以開始支付。
4前端進行支付動作
5前端支付完成后,買粉絲服務器會向后端發送支付通知(也就是買粉絲要告訴你客戶已經付過錢了),后端根據這個通知確定支付完成,然后就去做支付完成后的相應動作,比如修改訂單狀態,添加交易日志啊等等。
從這幾個步驟可以看出,后端主要的作用就是將支付需要的數據傳給買粉絲服務器,再根據買粉絲服務器的響應確定支付是否完成。
這個流程還是蠻容易理解的。形象的說,前端就是個顧客,后端就是店家,買粉絲服務器的統一下單接口就像收銀員。顧客跟店家說,我是誰誰誰,現在我要付多少多少錢給你買什么什么。店家就跟收銀員說,那個誰誰誰要付多少錢,你準備收錢吧。收銀員收到錢后,就去告訴店家,我已經收到錢了,你給他東西吧。
下面就詳細的說明一下 各個步驟的具體實現。
1. 前端請求支付
前端請求支付,就是簡單的攜帶支付需要的數據,例如用戶標識,支付金額,支付訂單 ID 等等跟 **你的業務邏輯有關** 或者跟 **下一步請求買粉絲服務器支付統一下單接口需要的數據有關** 的相關數據,使用買粉絲小程序的 wx.request( ) 去請求后端的支付接口。
2. 后端請求買粉絲服務器
后端接收到前端發送的支付請求后,可以進行一下相關驗證,例如判斷一下用戶有沒有問題,支付金額對不對等等。
在驗證沒什么問題,可以向買粉絲服務器申請支付之后,后端需要使用 買粉絲規定的數據格式 去請求買粉絲的支付統一下單接口。
買粉絲規定的請求數據:
這需要較多代碼實現。因為需要的數據個數較多,而且還需要加密并以 XML 格式發送。
首先,有以下數據是使用小程序支付必須提供給買粉絲服務器的參數。
小程序 appid。寫小程序的大概沒有不知道這個的。。。
用戶標識 openid。也就是用戶的小程序標識,在我上篇博客中說明了如何獲取。
商戶號 mch_id 。申請開通買粉絲支付商戶認證成功后買粉絲發給你的郵件里有
商戶訂單號 out_trade_no 。商戶為這次支付生成的訂單號
總金額 total_fee 。訂單總金額,很重要的一點是單位是分,要特別注意。
買粉絲服務器回調通知接口地址 notify_url。買粉絲確認錢已經到賬后,會往這個地址多次發送消息,告訴你顧客已經付完錢了,你需要返回消息給買粉絲表示你已經收到了通知。。這個地址不能有端口號,同時要能直接接受POST方法請求。
交易類型 trade_type 。買粉絲小程序支付此值統一為 JSAPI
商品信息 Body。類似"騰訊-游戲"這種格式
終端IP地址 spbill_create_ip 。終端地址IP,也就是請求支付的 IP 地址。
隨機字符串 nonce_str 。需要后端隨機生成的字符串用于保證數據安全。買粉絲要求不長于32位。
簽名 sign 。使用上面的所有參數進行相應處理加密生成簽名。(具體處理方式可見下文代碼,可直接復用。)
在處理好以上所有數據后,將這些數據以 XML 格式整理并以 POST 方法發送到 買粉絲支付統一下單接口 買粉絲s://api.mch.weixin.qq.買粉絲/pay/unifiedorder 。
3.后端接受買粉絲服務器返回數據
買粉絲服務器在接收到支付數據之后,如果數據沒有問題,其會返回用于支付的相應數據,其中非常重要的是 名稱為 prepay_id 的數據字段,需要將此數據返回前端,前端才能繼續支付。
因此,在后端接收到買粉絲服務器的返回數據后,需要進行相應的處理,最終返回到前端如下數據:
appid 不需多說
timeStamp 當前時間戳
nonceStr 隨機字符串
package 就是上面提到的 prepay_id,不過切記格式如 “prepay_id= prepay_id_item“。否則會導致錯誤。
signType 加密方式,一般應該是 MD5
paySign 對以上數據進行相應處理并加密。
到這里,后端的支付接口已經完成了接收前端支付請求,并返回了前端支付所需數據的功能。
4. 前端發起支付
前端在接收到返回數據后,使用 wx.requestPayment() 來請求發起支付。此 API 需要的對象參數各項值就是我們上一步返回的各個數據。
5.后端接受買粉絲服務器回調
前端完成支付后,買粉絲服務器確認支付已經完成。就會向第一步中設置的回調地址發送通知。后端的接收回調接口在接收到通知后,就可以判斷支付是否完成,從而決定后續動作。
需要注意的是,在接收到買粉絲服務器的回調通知后,根據通知的result_買粉絲de字段判斷支付是否成功。在接受到成功的通知后,后端需要返回success數據向買粉絲服務器告知已得到回調通知。否則買粉絲服務器會不停的向后端發送消息。另外買粉絲的通知是以XML格式發送的,在接受處理時需要注意。
買粉絲的大概支付流程就是這樣。以下是PHP語法的買粉絲支付類,可以比照上面的步驟介紹,加深理解。在需要支付時,直接傳入參數實例化此類再調用類的 pay 方法即可。
//買粉絲支付類
class WeiXinPay{
//=======【基本信息設置】=====================================
//買粉絲買粉絲身份的唯一標識
protected $APPID = appid;//填寫您的appid。買粉絲公眾平臺里的
protected $APPSECRET = secret;
//受理商ID,身份標識
protected $MCHID = '11111111';//商戶id
//商戶支付密鑰Key
protected $KEY = '192006250b4c09247ec02edce69f6a2d';
//回調通知接口
protected $APPURL = '買粉絲s://smart.afei.買粉絲/receivesuc';
//交易類型
protected $TRADETYPE = 'JSAPI';
//商品類型信息
protected $BODY = 'wx/book';
//買粉絲支付類的構造函數
function __買粉絲nstruct($openid,$outTradeNo,$totalFee){
$this->openid = $openid; //用戶唯一標識
$this->outTradeNo = $outTradeNo; //商品編號
$this->totalFee = $totalFee; //總價
}
//買粉絲支付類向外暴露的支付接口
public function pay(){
$result = $this->weixinapp();
return $result;
}
//對買粉絲統一下單接口返回的支付相關數據進行處理
private function weixinapp(){
$unifiedorder=$this->unifiedorder();
$parameters=array(
'appId'=>$this->APPID,//小程序ID
'timeStamp'=>''.time().'',//時間戳
'nonceStr'=>$this->createNoncestr(),//隨機串
'package'=>'prepay_id='.$unifiedorder['prepay_id'],//數據包
'signType'=>'MD5'//簽名方式
);
$parameters['paySign']=$this->getSign($parameters);
return $parameters;
}
/
**請求買粉絲統一下單接口
*/
private function unifiedorder(){
$parameters = array(
'appid' => $this->APPID,//小程序id
'mch_id'=> $this->MCHID,//商戶id
'spbill_create_ip'=>$_SERVER['REMOTE_ADDR'],//終端ip
'notify_url'=>$this->APPURL, //通知地址
'nonce_str'=> $this->createNoncestr(),//隨機字符串
'out_trade_no'=>$this->outTradeNo,//商戶訂單編號