PHP開發(fā)APP端微信支付功能
用PHP開發(fā)APP端微信支付的一點個人心得
最近因為公司需求,要開發(fā)APP端上的微信支付,看了微信文檔,感覺還不錯,沒有遇到太大的坑,需要注意的點不算太多。
寫一個記事文檔,作為備忘錄。
APP支付流程
從上面的圖片中,可以看出來,需要注意的流程是一共是3部分;
第一部分:調(diào)用下單API,返回預支付訂單,簽名之后再返回信息(4、5、6、7)
第二部分:異步通知(15、16)
第三部分:最后的判斷支付結果
最需要注意的就是第一部分:調(diào)用下單API,返回預支付訂單,簽名之后再返回信息
微信文檔中有詳細的說明,這里不再贅述。
附錄一下我的代碼,伸手黨,稍微改點代碼就可以用了。
//入口函數(shù) function weChatPay(){ $json = array(); //生成預支付交易單的必選參數(shù): $newPara = array(); //應用ID $newPara["appid"] = "wx2421b1c4370ec43b"; //商戶號 $newPara["mch_id"] = "10000100"; //設備號 $newPara["device_info"] = "WEB"; //隨機字符串,這里推薦使用函數(shù)生成 $newPara["nonce_str"] = "1add1a30ac87aa2db72f57a2375d8fec"; //商品描述 $newPara["body"] = "APP支付測試"; //商戶訂單號,這里是商戶自己的內(nèi)部的訂單號 $newPara["out_trade_no"] = "1415659990"; //總金額 $newPara["total_fee"] = 1; //終端IP $newPara["spbill_create_ip"] = $_SERVER["REMOTE_ADDR"]; //通知地址,注意,這里的url里面不要加參數(shù) $newPara["notify_url"] = "http://wxpay.wxutil.com/pub_v2/pay/notify.v2.php"; //交易類型 $newPara["trade_type"] = "APP"; //第一次簽名 $newPara["sign"] = produceWeChatSign($newPara); //把數(shù)組轉化成xml格式 $xmlData = getWeChatXML($newPara); //利用PHP的CURL包,將數(shù)據(jù)傳給微信統(tǒng)一下單接口,返回正常的prepay_id $get_data = sendPrePayCurl($xmlData); //返回的結果進行判斷。 if($get_data['return_code'] == "SUCCESS" && $get_data['result_code'] == "SUCCESS"){ //根據(jù)微信支付返回的結果進行二次簽名 //二次簽名所需的隨機字符串 $newPara["nonce_str"] = "5K8264ILTKCH16CQ2502SI8ZNMTM67VS"; //二次簽名所需的時間戳 $newPara['timeStamp'] = time().""; //二次簽名剩余參數(shù)的補充 $secondSignArray = array( "appid"=>$newPara['appid'], "noncestr"=>$newPara['nonce_str'], "package"=>"Sign=WXPay", "prepayid"=>$get_data['prepay_id'], "partnerid"=>$newPara['mch_id'], "timestamp"=>$newPara['timeStamp'], ); $json['datas'] = $secondSignArray; $json['ordersn'] = $newPara["out_trade_no"]; $json['datas']['sign'] = weChatSecondSign($newPara,$get_data['prepay_id']); $json['message'] = "預支付完成"; //預支付完成,在下方進行自己內(nèi)部的業(yè)務邏輯 /*****************************/ return json_encode($json); } else{ $json['message'] = $get_data['return_msg']; } } return json_encode($json); } //第一次簽名的函數(shù)produceWeChatSign function produceWeChatSign($newPara){ $stringA = self::getSignContent($newPara); $stringSignTemp=$stringA."&key=192006250b4c09247ec02edce69f6a2d"; return strtoupper(MD5($stringSignTemp)); } //生成xml格式的函數(shù) public static function getWeChatXML($newPara){ $xmlData = "<xml>"; foreach ($newPara as $key => $value) { $xmlData = $xmlData."<".$key.">".$value."</".$key.">"; } $xmlData = $xmlData."</xml>"; return $xmlData; } //通過curl發(fā)送數(shù)據(jù)給微信接口的函數(shù) function sendPrePayCurl($xmlData) { $url = "https://api.mch.weixin.qq.com/pay/unifiedorder"; $header[] = "Content-type: text/xml"; $curl = curl_init(); curl_setopt($curl, CURLOPT_HTTPHEADER, $header); curl_setopt($curl, CURLOPT_URL, $url); curl_setopt($curl, CURLOPT_RETURNTRANSFER, true); curl_setopt($curl, CURLOPT_POST, 1); curl_setopt($curl, CURLOPT_POSTFIELDS, $xmlData); $data = curl_exec($curl); if (curl_errno($curl)) { print curl_error($curl); } curl_close($curl); return self::XMLDataParse($data); } //xml格式數(shù)據(jù)解析函數(shù) public static function XMLDataParse($data){ $msg = array(); $msg = (array)simplexml_load_string($data, 'SimpleXMLElement', LIBXML_NOCDATA); return $msg; } //二次簽名的函數(shù) function weChatSecondSign($newPara,$prepay_id){ $secondSignArray = array( "appid"=>$newPara['appid'], "noncestr"=>$newPara['nonce_str'], "package"=>"Sign=WXPay", "prepayid"=>$prepay_id, "partnerid"=>$newPara['mch_id'], "timestamp"=>$newPara['timeStamp'], ); $stringA = self::getSignContent($secondSignArray); $stringSignTemp=$stringA."&key=192006250b4c09247ec02edce69f6a2d"; return strtoupper(MD5($stringSignTemp)); }
兩個注意點:
1.二次簽名需要在后臺完成,并且完成之后,連帶著二次簽名所用的所有信息一起傳給前端,讓前段喚起微信支付。這樣不容易出現(xiàn)沒法吊起微信支付的情況。
2.兩次簽名,用的是不同的隨機字符串。
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關文章
Laravel框架集成UEditor編輯器的方法圖文與實例詳解
這篇文章主要介紹了Laravel框架集成UEditor編輯器的方法,結合圖文與實例形式詳細分析了Laravel框架整合集成UEditor編輯器的相關操作步驟與具體實現(xiàn)技巧,需要的朋友可以參考下2019-04-04php_screw安裝使用教程(另一個PHP代碼加密實現(xiàn))
這篇文章主要介紹了php_screw安裝使用教程,php_screw是另一個PHP代碼加密實現(xiàn),和Zend的encoder類似,需要的朋友可以參考下2014-05-05PHP實現(xiàn)RSA加解密算法示例(生成密鑰位數(shù)為1024位的方法)
下面小編就為大家分享一篇PHP實現(xiàn)RSA加解密算法示例(生成密鑰位數(shù)為1024位的方法),具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-03-03